diff options
| author | Marc Jeanmougin <marc@jeanmougin.fr> | 2017-07-01 16:58:40 +0000 |
|---|---|---|
| committer | Marc Jeanmougin <marc@jeanmougin.fr> | 2017-07-01 16:58:40 +0000 |
| commit | b01ea98e75ffee1fa243a929e5f3eac87f63e4e2 (patch) | |
| tree | f15eddd9a2a7ca8c94cafffc73bdf5b865bb5f5a /src/extension | |
| parent | Merge branch 'speed_up_drawing' of gitlab.com:psychon/inkscape (diff) | |
| parent | Introduce get_filenames which scans paths for all filenames. (diff) | |
| download | inkscape-b01ea98e75ffee1fa243a929e5f3eac87f63e4e2.tar.gz inkscape-b01ea98e75ffee1fa243a929e5f3eac87f63e4e2.zip | |
Merge branch 'master' of gitlab.com:inkscape/inkscape
Diffstat (limited to 'src/extension')
| -rw-r--r-- | src/extension/internal/filter/filter-file.cpp | 77 | ||||
| -rw-r--r-- | src/extension/internal/filter/filter.h | 1 |
2 files changed, 18 insertions, 60 deletions
diff --git a/src/extension/internal/filter/filter-file.cpp b/src/extension/internal/filter/filter-file.cpp index dfe889ddf..c18879430 100644 --- a/src/extension/internal/filter/filter-file.cpp +++ b/src/extension/internal/filter/filter-file.cpp @@ -30,71 +30,19 @@ namespace Extension { namespace Internal { namespace Filter { -void filters_load_domain(Domain domain, gchar *menuname); - -void Filter::filters_all_files(void) -{ - filters_load_domain(SYSTEM, _("Bundled")); - filters_load_domain(USER, _("Personal")); -} - -#define INKSCAPE_FILTER_FILE ".svg" - -void filters_load_domain(Domain domain, gchar *menuname) -{ - char const *dirname = get_path(domain, FILTERS); - - if (!dirname) { - g_warning("%s", _("Null external module directory name. Filters will not be loaded.")); - return; - } - - if (!Glib::file_test(std::string(dirname), Glib::FILE_TEST_EXISTS | Glib::FILE_TEST_IS_DIR)) { - return; - } - - GError *err; - GDir *directory = g_dir_open(dirname, 0, &err); - if (!directory) { - gchar *safeDir = Inkscape::IO::sanitizeString(dirname); - g_warning(_("Modules directory (%s) is unavailable. External modules in that directory will not be loaded."), safeDir); - g_free(safeDir); - return; - } - - gchar *filename; - while ((filename = (gchar *)g_dir_read_name(directory)) != NULL) { - if (strlen(filename) < strlen(INKSCAPE_FILTER_FILE)) { - continue; - } - - if (strcmp(INKSCAPE_FILTER_FILE, filename + (strlen(filename) - strlen(INKSCAPE_FILTER_FILE)))) { - continue; - } - - gchar *pathname = g_build_filename(dirname, filename, NULL); - Filter::filters_load_file(pathname, menuname); - g_free(pathname); - } - - g_dir_close(directory); - - return; -} - void -Filter::filters_load_file (gchar * filename, gchar * menuname) +filters_load_file (Glib::ustring filename, gchar * menuname) { - Inkscape::XML::Document *doc = sp_repr_read_file(filename, INKSCAPE_EXTENSION_URI); + Inkscape::XML::Document *doc = sp_repr_read_file(filename.c_str(), INKSCAPE_EXTENSION_URI); if (doc == NULL) { - g_warning("File (%s) is not parseable as XML. Ignored.", filename); + g_warning("File (%s) is not parseable as XML. Ignored.", filename.c_str()); return; } Inkscape::XML::Node * root = doc->root(); if (strcmp(root->name(), "svg:svg")) { Inkscape::GC::release(doc); - g_warning("File (%s) is not SVG. Ignored.", filename); + g_warning("File (%s) is not SVG. Ignored.", filename.c_str()); return; } @@ -104,7 +52,7 @@ Filter::filters_load_file (gchar * filename, gchar * menuname) for (Inkscape::XML::Node * defs = child->firstChild(); defs != NULL; defs = defs->next()) { if (!strcmp(defs->name(), "svg:filter")) { - filters_load_node(defs, menuname); + Filter::filters_load_node(defs, menuname); } // oh! a filter } //defs } // is defs @@ -114,6 +62,17 @@ Filter::filters_load_file (gchar * filename, gchar * menuname) return; } +void Filter::filters_all_files(void) +{ + for(auto &filename: get_filenames(USER, FILTERS, {".svg"})) { + filters_load_file(filename, _("Personal")); + } + for(auto &filename: get_filenames(SYSTEM, FILTERS, {".svg"})) { + filters_load_file(filename, _("Bundled")); + } +} + + #include "extension/internal/clear-n_.h" class mywriter : public Inkscape::IO::BasicWriter { @@ -150,8 +109,8 @@ Filter::filters_load_node (Inkscape::XML::Node * node, gchar * menuname) "<object-type>all</object-type>\n" "<effects-menu>\n" "<submenu name=\"" N_("Filters") "\">\n" - "<submenu name=\"%s\"/>\n" - "</submenu>\n" + "<submenu name=\"%s\"/>\n" + "</submenu>\n" "</effects-menu>\n" "<menu-tip>%s</menu-tip>\n" "</effect>\n" diff --git a/src/extension/internal/filter/filter.h b/src/extension/internal/filter/filter.h index d4728b69c..8fa086b69 100644 --- a/src/extension/internal/filter/filter.h +++ b/src/extension/internal/filter/filter.h @@ -53,7 +53,6 @@ public: /* File loader related */ static void filters_all_files(void); - static void filters_load_file(gchar * filename, gchar * menuname); static void filters_load_node(Inkscape::XML::Node * node, gchar * menuname); }; |
