summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 9a0751b)
raw | patch | inline | side by side (parent: 9a0751b)
author | albinsunnanbo <albinsunnanbo@users.sourceforge.net> | |
Thu, 13 Mar 2008 14:23:42 +0000 (14:23 +0000) | ||
committer | albinsunnanbo <albinsunnanbo@users.sourceforge.net> | |
Thu, 13 Mar 2008 14:23:42 +0000 (14:23 +0000) |
src/extension/init.cpp | patch | blob | history |
diff --git a/src/extension/init.cpp b/src/extension/init.cpp
index 0964ab4f48ddd06a48161b3fd27b25553eb13996..97179f3d80d5d810c861141254e88c3dd82568e9 100644 (file)
--- a/src/extension/init.cpp
+++ b/src/extension/init.cpp
if (Inkscape::Extension::Extension::search_path.size() == 0)
{
Inkscape::Extension::Extension::search_path.push_back(profile_path("extensions"));
+
+#ifdef WIN32
+/*
+ * The native Windows Save dialogs change the current directory of Inkscape to the path selected in the dialog
+ * Putting relative paths in the search_path breaks things after the Save dialog ha been shown
+ * Especially the XAML-save: https://bugs.launchpad.net/inkscape/+bug/168896
+ * This code inserts an absolute path based on the current working dir when Inkscape starts.
+ * Only included in WIN32 to avoid messing around with other platforms for the moment
+ * After testing on other platforms this code can be enabled on other platforms (it "should" not break anything).
+ */
+ gchar * cwd = g_get_current_dir();
+ gchar * fname = g_build_filename(
+ cwd,
+ g_strdup(INKSCAPE_EXTENSIONDIR),
+ NULL);
+ Glib::ustring filename = fname;
+ Inkscape::Extension::Extension::search_path.push_back(g_strdup(filename.c_str()));
+ g_free(cwd);
+ g_free(fname);
+#else
Inkscape::Extension::Extension::search_path.push_back(g_strdup(INKSCAPE_EXTENSIONDIR));
+#endif
+
}
for (unsigned int i=0; i<Inkscape::Extension::Extension::search_path.size(); i++) {