Mercurial > fife-parpg
diff clients/editor/scripts/mapcontroller.py @ 266:475f83e227e0
Fixed undo/redo for remove- and placeInstance
author | cheesesucker@33b003aa-7bff-0310-803a-e67f0ece8222 |
---|---|
date | Sat, 13 Jun 2009 15:47:16 +0000 |
parents | 51cc05d862f2 |
children | 7ddec4ce99b3 |
line wrap: on
line diff
--- a/clients/editor/scripts/mapcontroller.py Sat Jun 13 15:08:42 2009 +0000 +++ b/clients/editor/scripts/mapcontroller.py Sat Jun 13 15:47:16 2009 +0000 @@ -8,6 +8,8 @@ import events import undomanager +from pychan.tools import callbackWithArguments as cbwa + class MapController(object): """ MapController provides an interface for editing maps """ def __init__(self, map): @@ -185,22 +187,39 @@ return if self.debug: print 'Placing instance of ' + object.getId() + ' at ' + str(position) - + # Remove instances from target position if not self._undo: + instances = self.getInstancesFromPosition(position) + if len(instances) == 1: + # Check if the only instance at position has the same object + objectId = instances[0].getObject().getId() + objectNs = instances[0].getObject().getNamespace() + if objectId == object.getId() and objectNs == object.getNamespace(): + if self.debug: print "Tried to place duplicate instance" + return + self._undomanager.startGroup("Placed instance") - self.removeInstances(self.getInstancesFromPosition(position)) + self.removeInstances(instances) inst = self._layer.createInstance(object, position) fife.InstanceVisual.create(inst) if not self._undo: - redocall = lambda: self.placeInstance(position, object) - undocall = lambda: self.removeInstances([inst]) + redocall = cbwa(self.placeInstance, position, object) + undocall = cbwa(self.removeInstanceOfObjectAt, position, object) undoobject = undomanager.UndoObject(undocall, redocall, "Placed instance") self._undomanager.addAction(undoobject) self._undomanager.endGroup() + def removeInstanceOfObjectAt(self, position, object): + """ Removes the first instance of object it can find on position """ + instances = self.getInstancesFromPosition(position) + for i in instances: + if i.getObject().getId() == object.getId() and i.getObject().getNamespace() == object.getNamespace(): + self.removeInstances([i]) + return + def removeInstances(self, instances): """ Removes all provided instances """ mname = 'removeInstances' @@ -213,10 +232,9 @@ if not self._undo: object = i.getObject() - position = i.getLocation().getExactLayerCoordinates() - undocall = lambda: self.placeInstance(position, object) - redocall = lambda: self.removeInstances([i]) + undocall = cbwa(self.placeInstance, position, object) + redocall = cbwa(self.removeInstanceOfObjectAt, position, object) undoobject = undomanager.UndoObject(undocall, redocall, "Removed instance") self._undomanager.addAction(undoobject)