[GB.QT4.EXT]

* NEW: Better undo/redo management.


git-svn-id: svn://localhost/gambas/trunk@5293 867c0c6c-44f3-4631-809d-bfa615b0a4ec
This commit is contained in:
Benoît Minisini 2012-11-02 17:54:47 +00:00
parent 6704db30ee
commit 6ec8947f88

View file

@ -103,6 +103,7 @@ public:
GCommandDocument(GDocument *doc);
void process(GDocument *doc) const;
void print() const;
bool equals(GCommandDocument *o) const;
};
GCommandDocument::GCommandDocument(GDocument *doc)
@ -134,6 +135,12 @@ void GCommandDocument::print() const
qDebug("- %d %d [%d %d %d %d]", cx, cy, sx, sy, sx2, sy2);
}
bool GCommandDocument::equals(GCommandDocument *o) const
{
return view == o->view && cx == o->cx && cy == o->cy
&& sx == o->sx && sy == o->sy && sx2 == o->sx2 && sy2 == o->sy2;
}
class GCommand
{
public:
@ -141,6 +148,7 @@ public:
{
None, Begin, End, Move, Insert, Delete, Indent, Unindent
};
GCommandDocument info;
virtual ~GCommand() { }
virtual Type type() const { return None; }
@ -156,7 +164,6 @@ class GBeginCommand: public GCommand
{
public:
bool _linked;
GCommandDocument info;
GBeginCommand(GCommandDocument *info, bool linked = false) { _linked = linked; this->info = *info; }
Type type() const { return Begin; }
@ -184,7 +191,6 @@ class GDeleteCommand: public GCommand
public:
int x, y, x2, y2;
GString str;
GCommandDocument info;
GDeleteCommand(GCommandDocument *info, int y, int x, int y2, int x2, const GString &str)
{
@ -205,13 +211,13 @@ public:
if (info.view != o->info.view)
return false;
if (x2 != o->x || y2 != o->y)
if (x2 != o->x || y2 != o->y || o->y != o->y2)
return false;
o->str.prepend(str);
o->x = x;
o->y = y;
o->info = info;
//o->info = info;
return true;
}
@ -924,19 +930,42 @@ void GDocument::addUndo(GCommand *c)
{
if (c->merge(undoList.last()))
{
//qDebug(" MERGE");
#if DEBUG_UNDO
qDebug(" MERGE");
#endif
delete c;
return;
}
else if (c->remove(undoList.last()))
{
//qDebug(" REMOVE");
#if DEBUG_UNDO
qDebug(" REMOVE");
#endif
delete c;
delete undoList.take();
return;
}
}
if (c->type() == GCommand::End && undoList.count() >= 2 && undoList.at(undoList.count() - 2)->type() == GCommand::Begin)
{
GCommand *o = undoList.take();
GCommand *begin = undoList.take();
#if DEBUG_UNDO
qDebug(" NO BEGIN / END");
#endif
o->info = begin->info;
delete begin;
delete c;
addUndo(o);
return;
/*else
{
undoList.append(begin);
undoList.append(o);
}*/
}
undoList.append(c);
if (!redoList.isEmpty())