// SPDX-License-Identifier: GPL-2.0-or-later /** @file * Parameters for extensions. *//* * Author: * Patrick Storz * * Copyright (C) 2019 Authors * * Released under GNU GPL v2+, read the file 'COPYING' for more information. */ #include "parameter.h" #include "widget.h" #include "widget-label.h" #include #include #include "extension/extension.h" #include "xml/node.h" namespace Inkscape { namespace Extension { InxWidget *InxWidget::make(Inkscape::XML::Node *in_repr, Inkscape::Extension::Extension *in_ext) { InxWidget *widget = nullptr; const char *name = in_repr->name(); if (!strncmp(name, INKSCAPE_EXTENSION_NS_NC, strlen(INKSCAPE_EXTENSION_NS_NC))) { name += strlen(INKSCAPE_EXTENSION_NS); } if (name[0] == '_') { // allow leading underscore in tag names for backwards-compatibility name++; } if (!name) { // we can't create a widget without name g_warning("InxWidget without name in extension '%s'.", in_ext->get_id()); } else if (!strcmp(name, "description")) { widget = new WidgetLabel(in_repr, in_ext); } else if (!strcmp(name, "param")) { widget = InxParameter::make(in_repr, in_ext); } else { g_warning("Unknown widget name ('%s') in extension '%s'", name, in_ext->get_id()); } // Note: widget could equal nullptr return widget; } bool InxWidget::is_valid_widget_name(const char *name) { // keep in sync with names supported in InxWidget::make() above static const std::vector valid_names = {"description", "param"}; if (std::find(valid_names.begin(), valid_names.end(), name) != valid_names.end()) { return true; } else { return false; } } InxWidget::InxWidget (Inkscape::XML::Node *in_repr, Inkscape::Extension::Extension *ext) : _extension(ext) { // translatable (optional) const char *translatable = in_repr->attribute("translatable"); if (translatable) { if (!strcmp(translatable, "yes")) { _translatable = YES; } else if (!strcmp(translatable, "no")) { _translatable = NO; } else { g_warning("Invalid value ('%s') for translatable attribute of widget '%s' in extension '%s'", translatable, in_repr->name(), _extension->get_id()); } } // context (optional) const char *context = in_repr->attribute("context"); if (!context) { context = in_repr->attribute("msgctxt"); // backwards-compatibility with previous name } if (context) { _context = g_strdup(context); } // gui-hidden (optional) const char *gui_hidden = in_repr->attribute("gui-hidden"); if (gui_hidden != nullptr) { if (strcmp(gui_hidden, "true") == 0) { _hidden = true; } } // indent (optional) const char *indent = in_repr->attribute("indent"); if (indent != nullptr) { _indent = strtol(indent, nullptr, 0); } // appearance (optional, does not apply to all parameters) const char *appearance = in_repr->attribute("appearance"); if (appearance) { _appearance = g_strdup(appearance); } } InxWidget::~InxWidget() { g_free(_context); _context = nullptr; g_free(_appearance); _appearance = nullptr; } /** Basically, if there is no widget pass a NULL. */ Gtk::Widget * InxWidget::get_widget (SPDocument * /*doc*/, Inkscape::XML::Node * /*node*/, sigc::signal * /*changeSignal*/) { return nullptr; } const char *InxWidget::get_translation(const char* msgid) { return _extension->get_translation(msgid, _context); } } // namespace Extension } // namespace Inkscape /* Local Variables: mode:c++ c-file-style:"stroustrup" c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +)) indent-tabs-mode:nil fill-column:99 End: */ // vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:fileencoding=utf-8:textwidth=99 :