summaryrefslogtreecommitdiffstats
path: root/src/select-context.cpp
diff options
context:
space:
mode:
authorMarkus Engel <markus.engel@tum.de>2013-04-13 16:13:17 +0000
committerMarkus Engel <markus.engel@tum.de>2013-04-13 16:13:17 +0000
commitfbdc8b84ff670c684dafc7d7d403ed01e7077e70 (patch)
tree964a82e4e94d8d6602e90893ac51ac9e2f7ec362 /src/select-context.cpp
parentMade factory a template. (diff)
downloadinkscape-fbdc8b84ff670c684dafc7d7d403ed01e7077e70.tar.gz
inkscape-fbdc8b84ff670c684dafc7d7d403ed01e7077e70.zip
Replaced casting macros for EventContext tree; added contructors.
(bzr r11608.1.96)
Diffstat (limited to 'src/select-context.cpp')
-rw-r--r--src/select-context.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/src/select-context.cpp b/src/select-context.cpp
index 7b811e16e..604b4c7cc 100644
--- a/src/select-context.cpp
+++ b/src/select-context.cpp
@@ -69,6 +69,21 @@ static gint xp = 0, yp = 0; // where drag started
static gint tolerance = 0;
static bool within_tolerance = false;
+
+#include "sp-factory.h"
+
+namespace {
+ SPEventContext* createSelectContext() {
+ return new SPSelectContext();
+ }
+
+ bool selectContextRegistered = ToolFactory::instance().registerObject("/tools/select", createSelectContext);
+}
+
+const std::string& CSelectContext::getPrefsPath() {
+ return SPSelectContext::prefsPath;
+}
+
const std::string SPSelectContext::prefsPath = "/tools/select";
G_DEFINE_TYPE(SPSelectContext, sp_select_context, SP_TYPE_EVENT_CONTEXT);
@@ -97,6 +112,7 @@ SPSelectContext::SPSelectContext() : SPEventContext() {
sc->cselectcontext = new CSelectContext(sc);
delete sc->ceventcontext;
sc->ceventcontext = sc->cselectcontext;
+ types.insert(typeid(SPSelectContext));
sc->grabbed = 0;
sc->item = 0;