diff options
-rw-r--r-- | Area.py | 8 | ||||
-rw-r--r-- | toolbox.py | 2 |
2 files changed, 8 insertions, 2 deletions
@@ -663,13 +663,18 @@ class Area(gtk.DrawingArea): widget.queue_draw() self.drawing = False self.desenha = False - if not private_undo: + if not private_undo and self.tool['name'] != 'bucket': + # We have to avoid saving an undo state if the bucket tool + # is selected because this undo state is called before the + # gobject.idle_add (with the fill_flood function) finishes + # and an unconsistent undo state is saved self.enableUndo(widget) def fast_flood_fill(self, widget, x, y, width, height): fill(self.pixmap, self.gc, x, y, width, height, self.gc_line.foreground.pixel) widget.queue_draw() + self.enableUndo(widget) display = gtk.gdk.display_get_default() cursor = gtk.gdk.cursor_new_from_name(display, 'paint-bucket') self.window.set_cursor(cursor) @@ -709,6 +714,7 @@ class Area(gtk.DrawingArea): self.pixmap.draw_image(self.gc, gdk_image, 0, 0, 0, 0, width, height) self.queue_draw() + self.enableUndo(self) display = gtk.gdk.display_get_default() cursor = gtk.gdk.cursor_new_from_name(display, 'paint-bucket') @@ -352,7 +352,7 @@ class ToolsToolbarBuilder(): # Check if there is an area selected or if the "stamp" tool is # being used sensitive = self._activity.area.is_selected() or \ - self.tool['name'] == 'stamp' + self.properties['name'] == 'stamp' self._tool_stamp.set_sensitive(sensitive) |