2002-08-12 00:15:19 +00:00
|
|
|
#include <config.h>
|
|
|
|
|
|
|
|
#include "ParagraphList.h"
|
|
|
|
|
|
|
|
#include "paragraph.h"
|
|
|
|
|
|
|
|
////////// The ParagraphList::iterator
|
|
|
|
|
|
|
|
ParagraphList::iterator::iterator()
|
|
|
|
: ptr(0)
|
|
|
|
{}
|
|
|
|
|
|
|
|
|
|
|
|
ParagraphList::iterator::iterator(Paragraph * p)
|
|
|
|
: ptr(p)
|
|
|
|
{}
|
|
|
|
|
|
|
|
|
|
|
|
ParagraphList::iterator::reference
|
|
|
|
ParagraphList::iterator::operator*()
|
|
|
|
{
|
|
|
|
return *ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ParagraphList::iterator::pointer
|
|
|
|
ParagraphList::iterator::operator->()
|
|
|
|
{
|
|
|
|
return ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ParagraphList::iterator &
|
|
|
|
ParagraphList::iterator::operator++()
|
|
|
|
{
|
|
|
|
ptr = ptr->next();
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ParagraphList::iterator
|
|
|
|
ParagraphList::iterator::operator++(int)
|
|
|
|
{
|
|
|
|
iterator tmp = *this;
|
|
|
|
++*this;
|
|
|
|
return tmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ParagraphList::iterator &
|
|
|
|
ParagraphList::iterator::operator--()
|
|
|
|
{
|
|
|
|
ptr = ptr->previous();
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ParagraphList::iterator
|
|
|
|
ParagraphList::iterator::operator--(int)
|
|
|
|
{
|
|
|
|
iterator tmp = *this;
|
|
|
|
--*this;
|
|
|
|
return tmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool operator==(ParagraphList::iterator const & i1,
|
2002-08-14 18:40:10 +00:00
|
|
|
ParagraphList::iterator const & i2)
|
2002-08-12 00:15:19 +00:00
|
|
|
{
|
2002-08-13 17:43:40 +00:00
|
|
|
return &(*const_cast<ParagraphList::iterator&>(i1))
|
|
|
|
== &(*const_cast<ParagraphList::iterator&>(i2));
|
2002-08-12 00:15:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool operator!=(ParagraphList::iterator const & i1,
|
2002-08-14 18:40:10 +00:00
|
|
|
ParagraphList::iterator const & i2)
|
2002-08-12 00:15:19 +00:00
|
|
|
{
|
|
|
|
return !(i1 == i2);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
////////// The ParagraphList proper
|
|
|
|
ParagraphList::ParagraphList()
|
|
|
|
: parlist(0)
|
|
|
|
{}
|
|
|
|
|
|
|
|
|
2003-03-04 21:40:36 +00:00
|
|
|
ParagraphList::iterator
|
|
|
|
ParagraphList::insert(ParagraphList::iterator it, Paragraph * par)
|
|
|
|
{
|
2003-03-05 09:41:49 +00:00
|
|
|
if (it != end()) {
|
|
|
|
Paragraph * prev = it->previous();
|
|
|
|
par->next(&*it);
|
|
|
|
par->previous(prev);
|
|
|
|
prev->next(par);
|
|
|
|
it->previous(par);
|
2003-03-06 21:01:04 +00:00
|
|
|
} else if (parlist == 0) {
|
|
|
|
parlist = par;
|
2003-03-05 09:41:49 +00:00
|
|
|
} else {
|
|
|
|
// Find last par.
|
|
|
|
Paragraph * last = parlist;
|
|
|
|
while (last->next())
|
|
|
|
last = last->next();
|
|
|
|
last->next(par);
|
|
|
|
par->previous(last);
|
|
|
|
}
|
2003-03-04 21:40:36 +00:00
|
|
|
return iterator(par);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-08-12 00:15:19 +00:00
|
|
|
void ParagraphList::clear()
|
|
|
|
{
|
|
|
|
while (parlist) {
|
|
|
|
Paragraph * tmp = parlist->next();
|
|
|
|
delete parlist;
|
|
|
|
parlist = tmp;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2003-03-04 20:45:02 +00:00
|
|
|
void ParagraphList::erase(ParagraphList::iterator it)
|
|
|
|
{
|
|
|
|
Paragraph * prev = it->previous();
|
|
|
|
Paragraph * next = it->next();
|
|
|
|
|
2003-03-05 09:41:49 +00:00
|
|
|
if (prev)
|
|
|
|
prev->next(next);
|
|
|
|
if (next)
|
|
|
|
next->previous(prev);
|
2003-03-04 20:45:02 +00:00
|
|
|
|
|
|
|
delete &*it;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-08-14 18:40:10 +00:00
|
|
|
ParagraphList::iterator ParagraphList::begin()
|
2002-08-12 00:15:19 +00:00
|
|
|
{
|
|
|
|
return iterator(parlist);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ParagraphList::iterator ParagraphList::begin() const
|
|
|
|
{
|
|
|
|
return iterator(parlist);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ParagraphList::iterator ParagraphList::end()
|
|
|
|
{
|
|
|
|
return iterator();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ParagraphList::iterator ParagraphList::end() const
|
|
|
|
{
|
|
|
|
return iterator();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2003-03-06 21:01:04 +00:00
|
|
|
Paragraph const & ParagraphList::front() const
|
|
|
|
{
|
|
|
|
return *parlist;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Paragraph & ParagraphList::front()
|
|
|
|
{
|
|
|
|
return *parlist;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Paragraph const & ParagraphList::back() const
|
|
|
|
{
|
|
|
|
Paragraph * tmp = parlist;
|
|
|
|
while (tmp->next())
|
|
|
|
tmp = tmp->next();
|
|
|
|
return *tmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Paragraph & ParagraphList::back()
|
|
|
|
{
|
|
|
|
Paragraph * tmp = parlist;
|
|
|
|
while (tmp->next())
|
|
|
|
tmp = tmp->next();
|
|
|
|
return *tmp;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-08-12 00:15:19 +00:00
|
|
|
void ParagraphList::set(Paragraph * p)
|
|
|
|
{
|
|
|
|
parlist = p;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-08-13 17:43:40 +00:00
|
|
|
void ParagraphList::push_back(Paragraph * p)
|
|
|
|
{
|
|
|
|
if (!parlist) {
|
|
|
|
parlist = p;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
Paragraph * pos = parlist;
|
|
|
|
while (pos->next())
|
|
|
|
pos = pos->next();
|
|
|
|
pos->next(p);
|
|
|
|
p->previous(pos);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2002-08-12 00:15:19 +00:00
|
|
|
int ParagraphList::size() const
|
|
|
|
{
|
|
|
|
// When we switch to a std::container this will be O(1)
|
|
|
|
// instead of O(n). (Lgb)
|
|
|
|
Paragraph * tmp = parlist;
|
|
|
|
int c = 0;
|
|
|
|
while (tmp) {
|
|
|
|
++c;
|
|
|
|
tmp = tmp->next();
|
|
|
|
}
|
|
|
|
return c;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool ParagraphList::empty() const
|
|
|
|
{
|
|
|
|
return parlist == 0;
|
|
|
|
}
|