put two functions in one, remove global variables

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@7464 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
André Pönitz 2003-07-31 13:12:21 +00:00
parent acc3e7135c
commit 58fd3c844a
4 changed files with 45 additions and 71 deletions

View File

@ -1,7 +1,12 @@
2003-07-30 André Pönitz <poenitz@gmx.net> 2003-07-30 André Pönitz <poenitz@gmx.net>
* Paragraph.[Ch] (copyIntoMinibuffer) removed unused function * paragraph.[Ch] (copyIntoMinibuffer): removed unused function
* paragraph.[Ch] (cutIntoMinibuffer, insertFromMinibuffer):
create a single function...
* paragraph_funcs.C (moveItem): ... here.
2003-07-30 Martin Vermeer <martin.vermeer@hut.fi> 2003-07-30 Martin Vermeer <martin.vermeer@hut.fi>

View File

@ -58,17 +58,6 @@ using std::upper_bound;
using lyx::pos_type; using lyx::pos_type;
// this is a minibuffer
namespace {
char minibuffer_char;
LyXFont minibuffer_font;
InsetOld * minibuffer_inset;
} // namespace anon
Paragraph::Paragraph() Paragraph::Paragraph()
: pimpl_(new Paragraph::Pimpl(this)) : pimpl_(new Paragraph::Pimpl(this))
{ {
@ -251,44 +240,6 @@ void Paragraph::validate(LaTeXFeatures & features) const
} }
void Paragraph::cutIntoMinibuffer(BufferParams const & bparams, pos_type pos)
{
minibuffer_char = getChar(pos);
minibuffer_font = getFontSettings(bparams, pos);
minibuffer_inset = 0;
if (minibuffer_char == Paragraph::META_INSET) {
if (getInset(pos)) {
// the inset is not in a paragraph anymore
minibuffer_inset = insetlist.release(pos);
minibuffer_inset->parOwner(0);
} else {
minibuffer_inset = 0;
minibuffer_char = ' ';
// This reflects what GetInset() does (ARRae)
}
}
}
bool Paragraph::insertFromMinibuffer(pos_type pos)
{
if (minibuffer_char == Paragraph::META_INSET) {
if (!insetAllowed(minibuffer_inset->lyxCode()))
return false;
insertInset(pos, minibuffer_inset, minibuffer_font);
} else {
LyXFont f = minibuffer_font;
if (!checkInsertChar(f))
return false;
insertChar(pos, minibuffer_char, f);
}
return true;
}
// end of minibuffer
void Paragraph::eraseIntern(lyx::pos_type pos) void Paragraph::eraseIntern(lyx::pos_type pos)
{ {
pimpl_->eraseIntern(pos); pimpl_->eraseIntern(pos);

View File

@ -258,12 +258,6 @@ public:
InsetOld * getInset(lyx::pos_type pos); InsetOld * getInset(lyx::pos_type pos);
/// ///
InsetOld const * getInset(lyx::pos_type pos) const; InsetOld const * getInset(lyx::pos_type pos) const;
/** important for cut and paste
Temporary change from BufferParams to Buffer. Will revert when we
get rid of the argument to InsetOld::clone(Buffer const &) */
void cutIntoMinibuffer(BufferParams const &, lyx::pos_type pos);
///
bool insertFromMinibuffer(lyx::pos_type pos);
/// ///
bool isHfill(lyx::pos_type pos) const; bool isHfill(lyx::pos_type pos) const;

View File

@ -46,6 +46,36 @@ using std::endl;
using std::ostream; using std::ostream;
namespace {
bool moveItem(Paragraph & from, Paragraph & to,
BufferParams const & params, pos_type i, pos_type j)
{
char const tmpchar = from.getChar(i);
LyXFont tmpfont = from.getFontSettings(params, i);
if (tmpchar == Paragraph::META_INSET) {
InsetOld * tmpinset = 0;
if (from.getInset(i)) {
// the inset is not in a paragraph anymore
tmpinset = from.insetlist.release(i);
tmpinset->parOwner(0);
}
if (!to.insetAllowed(tmpinset->lyxCode()))
return false;
to.insertInset(j, tmpinset, tmpfont);
} else {
if (!to.checkInsertChar(tmpfont))
return false;
to.insertChar(j, tmpchar, tmpfont);
}
return true;
}
}
void breakParagraph(BufferParams const & bparams, void breakParagraph(BufferParams const & bparams,
ParagraphList & paragraphs, ParagraphList & paragraphs,
ParagraphList::iterator par, ParagraphList::iterator par,
@ -106,17 +136,16 @@ void breakParagraph(BufferParams const & bparams,
pos_type j = pos; pos_type j = pos;
for (; i <= pos_end; ++i) { for (; i <= pos_end; ++i) {
Change::Type change(par->lookupChange(i)); Change::Type change = par->lookupChange(i);
par->cutIntoMinibuffer(bparams, i); if (moveItem(*par, *tmp, bparams, i, j - pos)) {
if (tmp->insertFromMinibuffer(j - pos)) {
tmp->setChange(j - pos, change); tmp->setChange(j - pos, change);
++j; ++j;
} }
} }
for (i = pos_end; i >= pos; --i) {
for (i = pos_end; i >= pos; --i)
par->eraseIntern(i); par->eraseIntern(i);
} }
}
if (pos) if (pos)
return; return;
@ -163,17 +192,14 @@ void breakParagraphConservative(BufferParams const & bparams,
// paragraph // paragraph
pos_type pos_end = par->size() - 1; pos_type pos_end = par->size() - 1;
for (pos_type i = pos, j = pos; i <= pos_end; ++i) { for (pos_type i = pos, j = pos; i <= pos_end; ++i)
par->cutIntoMinibuffer(bparams, i); if (moveItem(*par, *tmp, bparams, i, j - pos))
if (tmp->insertFromMinibuffer(j - pos))
++j; ++j;
}
for (pos_type k = pos_end; k >= pos; --k) { for (pos_type k = pos_end; k >= pos; --k)
par->erase(k); par->erase(k);
} }
} }
}
void mergeParagraph(BufferParams const & bparams, void mergeParagraph(BufferParams const & bparams,
@ -191,11 +217,9 @@ void mergeParagraph(BufferParams const & bparams,
pos_type pos_insert = par->size(); pos_type pos_insert = par->size();
// ok, now copy the paragraph // ok, now copy the paragraph
for (pos_type i = 0, j = 0; i <= pos_end; ++i) { for (pos_type i = 0, j = 0; i <= pos_end; ++i)
the_next->cutIntoMinibuffer(bparams, i); if (moveItem(*the_next, *par, bparams, i, pos_insert + j))
if (par->insertFromMinibuffer(pos_insert + j))
++j; ++j;
}
paragraphs.erase(the_next); paragraphs.erase(the_next);
} }