More fixes.

git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@3143 a592a061-630c-0410-9148-cb99ea01b6c8
This commit is contained in:
Jürgen Vigna 2001-12-04 16:10:19 +00:00
parent ef9efa6c0d
commit 9d2abd4505
12 changed files with 138 additions and 56 deletions

View File

@ -1,3 +1,8 @@
2001-12-04 Juergen Vigna <jug@sad.it>
* undo_funcs.C (textHandleUndo): added a call to inset->update() so
that we force an update of the inset and it's owners if neccessary.
2001-12-03 Juergen Vigna <jug@sad.it> 2001-12-03 Juergen Vigna <jug@sad.it>
* text.C (rowLast): simplified code * text.C (rowLast): simplified code

View File

@ -1,3 +1,15 @@
2001-12-04 Juergen Vigna <jug@sad.it>
* insetert.C (edit): handle Inlined status.
* insettext.C (insertInset): trying John's fix for the trailing cursor
* insetert.C (insetButtonPress): added to handle inlined status
(insetMotionNotify): ditto.
* insettext.C (clearInset): changed Painter & in BufferView * param,
to be able to call ascent,descent methods.
2001-12-03 Juergen Vigna <jug@sad.it> 2001-12-03 Juergen Vigna <jug@sad.it>
* insettext.C (updateInsetInInset): use lt variable to forbid * insettext.C (updateInsetInInset): use lt variable to forbid

View File

@ -257,8 +257,14 @@ void InsetERT::edit(BufferView * bv, int x, int y, unsigned int button)
{ {
if (button == 3) if (button == 3)
return; return;
InsetCollapsable::edit(bv, x, y, button); if (status_ == Inlined) {
if (!bv->lockInset(this))
return;
inset.edit(bv, x, y, button);
} else {
InsetCollapsable::edit(bv, x, y, button);
}
updateStatus(0); updateStatus(0);
set_latex_font(bv); set_latex_font(bv);
} }
@ -280,6 +286,19 @@ void InsetERT::edit(BufferView * bv, bool front)
} }
void InsetERT::insetButtonPress(BufferView * bv,
int x, int y, int button)
{
if (status_ == Inlined) {
inset.insetButtonPress(bv, x, y, button);
} else {
InsetCollapsable::insetButtonPress(bv, x, y, button);
}
}
void InsetERT::insetButtonRelease(BufferView * bv, int x, int y, int button) void InsetERT::insetButtonRelease(BufferView * bv, int x, int y, int button)
{ {
if (button == 3) { if (button == 3) {
@ -306,6 +325,17 @@ void InsetERT::insetButtonRelease(BufferView * bv, int x, int y, int button)
} }
void InsetERT::insetMotionNotify(BufferView * bv,
int x, int y, int state)
{
if (status_ == Inlined) {
inset.insetMotionNotify(bv, x, y, state);
} else {
InsetCollapsable::insetMotionNotify(bv, x, y, state);
}
}
int InsetERT::latex(Buffer const *, std::ostream & os, bool /*fragile*/, int InsetERT::latex(Buffer const *, std::ostream & os, bool /*fragile*/,
bool /*free_spc*/) const bool /*free_spc*/) const
{ {

View File

@ -71,8 +71,12 @@ public:
/// ///
SigC::Signal0<void> hideDialog; SigC::Signal0<void> hideDialog;
/// ///
void insetButtonPress(BufferView *, int x, int y, int button);
///
void insetButtonRelease(BufferView * bv, int x, int y, int button); void insetButtonRelease(BufferView * bv, int x, int y, int button);
/// ///
void insetMotionNotify(BufferView *, int x, int y, int state);
///
int latex(Buffer const *, std::ostream &, bool fragile, int latex(Buffer const *, std::ostream &, bool fragile,
bool free_spc) const; bool free_spc) const;
/// ///

View File

@ -587,6 +587,10 @@ void InsetTabular::insetUnlock(BufferView * bv)
void InsetTabular::updateLocal(BufferView * bv, UpdateCodes what, void InsetTabular::updateLocal(BufferView * bv, UpdateCodes what,
bool mark_dirty) const bool mark_dirty) const
{ {
if (what == INIT) {
LyXFont font;
calculate_dimensions_of_cells(bv, font, true);
}
if (need_update < what) // only set this if it has greater update if (need_update < what) // only set this if it has greater update
need_update = what; need_update = what;
if ((what == INIT) && hasSelection()) if ((what == INIT) && hasSelection())
@ -1244,6 +1248,8 @@ bool InsetTabular::calculate_dimensions_of_cells(BufferView * bv,
changed = tabular->SetAscentOfRow(i, maxAsc + ADD_TO_HEIGHT) || changed; changed = tabular->SetAscentOfRow(i, maxAsc + ADD_TO_HEIGHT) || changed;
changed = tabular->SetDescentOfRow(i, maxDesc + ADD_TO_HEIGHT) || changed; changed = tabular->SetDescentOfRow(i, maxDesc + ADD_TO_HEIGHT) || changed;
} }
if (changed)
tabular->reinit();
return changed; return changed;
} }

View File

@ -376,7 +376,7 @@ void InsetText::draw(BufferView * bv, LyXFont const & f,
// repaint the background if needed // repaint the background if needed
if (cleared && backgroundColor() != LColor::background) { if (cleared && backgroundColor() != LColor::background) {
top_x = int(x); top_x = int(x);
clearInset(pain, baseline, cleared); clearInset(bv, baseline, cleared);
top_x = old_x; top_x = old_x;
} }
@ -400,7 +400,7 @@ void InsetText::draw(BufferView * bv, LyXFont const & f,
if (!cleared && (top_x == int(x)) && if (!cleared && (top_x == int(x)) &&
((need_update&(INIT|FULL)) || (top_baseline!=baseline) || ((need_update&(INIT|FULL)) || (top_baseline!=baseline) ||
(last_drawn_width!=insetWidth))) { (last_drawn_width!=insetWidth))) {
clearInset(pain, baseline, cleared); clearInset(bv, baseline, cleared);
} }
top_x = int(x); top_x = int(x);
@ -419,9 +419,9 @@ void InsetText::draw(BufferView * bv, LyXFont const & f,
last_width = width(bv, f); last_width = width(bv, f);
last_height = ascent(bv, f) + descent(bv, f); last_height = ascent(bv, f) + descent(bv, f);
if (cleared || (last_drawn_width != insetWidth)) { if (last_drawn_width != insetWidth) {
if (!cleared) if (!cleared)
clearInset(pain, baseline, cleared); clearInset(bv, baseline, cleared);
need_update |= FULL; need_update |= FULL;
last_drawn_width = insetWidth; last_drawn_width = insetWidth;
} }
@ -1004,14 +1004,22 @@ void InsetText::insetMotionNotify(BufferView * bv, int x, int y, int state)
y - inset_y,state); y - inset_y,state);
return; return;
} }
LyXText * t = getLyXText(bv); bool clear = false;
if (!lt) {
lt = getLyXText(bv);
clear = true;
}
hideInsetCursor(bv); hideInsetCursor(bv);
t->setCursorFromCoordinates(bv, x - drawTextXOffset, y + insetAscent); lt->setCursorFromCoordinates(bv, x - drawTextXOffset, y + insetAscent);
t->setSelection(bv); lt->setSelection(bv);
if (t->toggle_cursor.par() != t->toggle_end_cursor.par() || if (lt->toggle_cursor.par() != lt->toggle_end_cursor.par() ||
t->toggle_cursor.pos() != t->toggle_end_cursor.pos()) lt->toggle_cursor.pos() != lt->toggle_end_cursor.pos())
{
updateLocal(bv, SELECTION, false); updateLocal(bv, SELECTION, false);
}
showInsetCursor(bv); showInsetCursor(bv);
if (clear)
lt = 0;
} }
@ -1782,7 +1790,7 @@ bool InsetText::insertInset(BufferView * bv, Inset * inset)
#endif #endif
bv->fitCursor(); bv->fitCursor();
updateLocal(bv, CURSOR_PAR|CURSOR, true); updateLocal(bv, CURSOR_PAR|CURSOR, true);
showInsetCursor(bv); // showInsetCursor(bv);
if (clear) if (clear)
lt = 0; lt = 0;
return true; return true;
@ -2282,10 +2290,12 @@ void InsetText::clearSelection(BufferView * bv)
} }
void InsetText::clearInset(Painter & pain, int baseline, bool & cleared) const void InsetText::clearInset(BufferView * bv, int baseline, bool & cleared) const
{ {
LyXFont dummy;
Painter & pain = bv->painter();
int w = insetWidth; int w = insetWidth;
int h = insetAscent + insetDescent; int h = ascent(bv, dummy) + descent(bv, dummy);
int ty = baseline - insetAscent; int ty = baseline - insetAscent;
if (ty < 0) { if (ty < 0) {
@ -2318,7 +2328,6 @@ Paragraph * InsetText::getParFromID(int id) const
#else #else
Paragraph * tmp = par; Paragraph * tmp = par;
while (tmp) { while (tmp) {
int tmp_id = tmp->id();
if (tmp->id() == id) { if (tmp->id() == id) {
return tmp; return tmp;
} }
@ -2365,6 +2374,14 @@ Paragraph * InsetText::paragraph() const
void InsetText::paragraph(Paragraph * p) void InsetText::paragraph(Paragraph * p)
{ {
// first we have to delete the old contents otherwise we'll have a
// memory leak!
the_locking_inset = 0;
while (par) {
Paragraph * tmp = par->next();
delete par;
par = tmp;
}
par = p; par = p;
// set ourself as owner for all the paragraphs inserted! // set ourself as owner for all the paragraphs inserted!
Paragraph * np = par; Paragraph * np = par;

View File

@ -320,7 +320,7 @@ private:
/// ///
void clearFrame(Painter &, bool cleared) const; void clearFrame(Painter &, bool cleared) const;
/// ///
void clearInset(Painter &, int baseline, bool & cleared) const; void clearInset(BufferView *, int baseline, bool & cleared) const;
/// ///
void saveLyXTextState(LyXText *) const; void saveLyXTextState(LyXText *) const;
void restoreLyXTextState(BufferView *, LyXText *) const; void restoreLyXTextState(BufferView *, LyXText *) const;

View File

@ -341,12 +341,20 @@ void LyXTabular::DeleteColumn(int column)
} }
void LyXTabular::Reinit() void LyXTabular::reinit()
{ {
for (int i = 0; i < rows_; ++i) { Reinit(false);
for (int j = 0; j < columns_; ++j) { }
cell_info[i][j].width_of_cell = 0;
cell_info[i][j].inset.setOwner(owner_);
void LyXTabular::Reinit(bool reset_widths)
{
if (reset_widths) {
for (int i = 0; i < rows_; ++i) {
for (int j = 0; j < columns_; ++j) {
cell_info[i][j].width_of_cell = 0;
cell_info[i][j].inset.setOwner(owner_);
}
} }
} }

View File

@ -394,6 +394,9 @@ public:
/// ///
std::vector<string> const getLabelList() const; std::vector<string> const getLabelList() const;
/// ///
/// recalculate the widths/heights only!
void reinit();
///
mutable int cur_cell; mutable int cur_cell;
private: private:
/// ///
@ -518,7 +521,7 @@ private:
/// ///
void Init(int columns_arg, int rows_arg, LyXTabular const * lt = 0); void Init(int columns_arg, int rows_arg, LyXTabular const * lt = 0);
/// ///
void Reinit(); void Reinit(bool reset_widths = true);
/// ///
void set_row_column_number_info(bool oldformat = false); void set_row_column_number_info(bool oldformat = false);
/// Returns true if a complete update is necessary, otherwise false /// Returns true if a complete update is necessary, otherwise false

View File

@ -181,7 +181,7 @@ unsigned char LyXText::transformChar(unsigned char c, Paragraph * par,
// Lgb // Lgb
int LyXText::singleWidth(BufferView * bview, Paragraph * par, int LyXText::singleWidth(BufferView * bview, Paragraph * par,
pos_type pos) const pos_type pos) const
{ {
char const c = par->getChar(pos); char const c = par->getChar(pos);
return singleWidth(bview, par, pos, c); return singleWidth(bview, par, pos, c);
@ -215,7 +215,10 @@ int LyXText::singleWidth(BufferView * bview, Paragraph * par,
} else if (c == Paragraph::META_INSET) { } else if (c == Paragraph::META_INSET) {
Inset * tmpinset = par->getInset(pos); Inset * tmpinset = par->getInset(pos);
if (tmpinset) { if (tmpinset) {
#if 0 // seems not to be needed, but ... #if 1
// this IS needed otherwise on initialitation we don't get the fill
// of the row right (ONLY on initialization if we read a file!)
// should be changed! (Jug 20011204)
tmpinset->update(bview, font); tmpinset->update(bview, font);
#endif #endif
return tmpinset->width(bview, font); return tmpinset->width(bview, font);
@ -1039,13 +1042,6 @@ int LyXText::fill(BufferView * bview, Row * row, int paper_width) const
} }
int const fill = paper_width - w - rightMargin(bview->buffer(), row); int const fill = paper_width - w - rightMargin(bview->buffer(), row);
#ifdef WITH_WARNINGS
#warning Please fix me (Jug!)
#endif
#if 0
if (fill < 0)
return 0;
#endif
return fill; return fill;
} }
@ -1515,35 +1511,34 @@ void LyXText::setHeightOfRow(BufferView * bview, Row * row_ptr) const
* start at the implicit given position */ * start at the implicit given position */
void LyXText::appendParagraph(BufferView * bview, Row * row) const void LyXText::appendParagraph(BufferView * bview, Row * row) const
{ {
bool not_ready = true; bool not_ready = true;
// The last character position of a paragraph is an invariant so we can // The last character position of a paragraph is an invariant so we can
// safely get it here. (Asger) // safely get it here. (Asger)
pos_type const lastposition = row->par()->size(); pos_type const lastposition = row->par()->size();
do { do {
// Get the next breakpoint // Get the next breakpoint
pos_type z = nextBreakPoint(bview, row, workWidth(bview)); pos_type z = nextBreakPoint(bview, row, workWidth(bview));
Row * tmprow = row; Row * tmprow = row;
// Insert the new row // Insert the new row
if (z < lastposition) { if (z < lastposition) {
++z; ++z;
insertRow(row, row->par(), z); insertRow(row, row->par(), z);
row = row->next(); row = row->next();
row->height(0); row->height(0);
} else } else
not_ready = false; not_ready = false;
// Set the dimensions of the row // Set the dimensions of the row
#ifdef WITH_WARNINGS // fixed fill setting now by calling inset->update() in
#warning Something is rotten here! (Jug) // SingleWidth when needed!
#endif tmprow->fill(fill(bview, tmprow, workWidth(bview)));
tmprow->fill(fill(bview, tmprow, workWidth(bview))); setHeightOfRow(bview, tmprow);
setHeightOfRow(bview, tmprow);
} while (not_ready); } while (not_ready);
} }

View File

@ -1054,7 +1054,7 @@ void LyXText::clearSelection() const
{ {
selection.set(false); selection.set(false);
selection.mark(false); selection.mark(false);
selection.end = selection.start = selection.cursor = cursor; last_sel_cursor = selection.end = selection.start = selection.cursor = cursor;
} }

View File

@ -168,6 +168,8 @@ bool textHandleUndo(BufferView * bv, Undo * undo)
it->getLyXText(bv)->setCursorIntern(bv, tmppar, undo->cursor_pos); it->getLyXText(bv)->setCursorIntern(bv, tmppar, undo->cursor_pos);
it->getLyXText(bv)->updateCounters(bv, it->getLyXText(bv)->cursor.row()); it->getLyXText(bv)->updateCounters(bv, it->getLyXText(bv)->cursor.row());
} }
LyXFont font;
it->update(bv, font, false);
#ifdef THIS_DOES_NOT_WORK #ifdef THIS_DOES_NOT_WORK
// we need this anyway as also if the undo was inside an inset // we need this anyway as also if the undo was inside an inset
// we have to redo the paragraph breaking // we have to redo the paragraph breaking