diff --git a/src/layer-manager.h b/src/layer-manager.h
index b4d827089ce0238d401289c92d22be649a21f5db..5b5d25eb2aaf5deb342bae5baa017fe2f94b0bae 100644 (file)
--- a/src/layer-manager.h
+++ b/src/layer-manager.h
#include "document-subset.h"
#include "gc-finalized.h"
#include "gc-soft-ptr.h"
+#include <vector>
+#include <map>
class SPDesktop;
class SPDocument;
{
public:
LayerManager(SPDesktop *desktop);
+ virtual ~LayerManager();
+
+ void setCurrentLayer( SPObject* obj );
+ void renameLayer( SPObject* obj, gchar const *label, bool uniquify );
sigc::connection connectCurrentLayerChanged(const sigc::slot<void, SPObject *> & slot) {
- return _layer_changed_signal.connect(slot);
+ return _layer_changed_signal.connect(slot);
}
sigc::connection connectLayerDetailsChanged(const sigc::slot<void, SPObject *> & slot) {
- return _details_changed_signal.connect(slot);
+ return _details_changed_signal.connect(slot);
}
private:
- static void _objectModifiedCB( SPObject* obj, guint flags, LayerManager* mgr );
+ friend class LayerWatcher;
+ class LayerWatcher;
void _objectModified( SPObject* obj, guint flags );
void _setDocument(SPDocument *document);
GC::soft_ptr<SPDesktop> _desktop;
SPDocument *_document;
+ std::vector<LayerWatcher*> _watchers;
+
sigc::signal<void, SPObject *> _layer_changed_signal;
sigc::signal<void, SPObject *> _details_changed_signal;
};