#ifndef INK_EXTENSION_PARAMSTRING_H_SEEN #define INK_EXTENSION_PARAMSTRING_H_SEEN /* * Copyright (C) 2005-2007 Authors: * Ted Gould * Johan Engelen * * Released under GNU GPL, read the file 'COPYING' for more information */ #include #include #include #include "parameter.h" namespace Inkscape { namespace Extension { class ParamString : public Parameter { private: /** \brief Internal value. This should point to a string that has been allocated in memory. And should be free'd. */ gchar * _value; /** \brief Internal value. This indicates the maximum leght of the string. Zero meaning unlimited. */ gint _max_length; public: ParamString(const gchar * name, const gchar * guitext, const gchar * desc, const Parameter::_scope_t scope, bool gui_hidden, const gchar * gui_tip, Inkscape::Extension::Extension * ext, Inkscape::XML::Node * xml); virtual ~ParamString(void); /** \brief Returns \c _value, with a \i const to protect it. */ const gchar * get (const SPDocument * /*doc*/, const Inkscape::XML::Node * /*node*/) { return _value; } const gchar * set (const gchar * in, SPDocument * doc, Inkscape::XML::Node * node); Gtk::Widget * get_widget(SPDocument * doc, Inkscape::XML::Node * node, sigc::signal * changeSignal); void string (std::string &string); void setMaxLength(int maxLenght) { _max_length = maxLenght; } int getMaxLength(void) { return _max_length; } }; } /* namespace Extension */ } /* namespace Inkscape */ #endif /* INK_EXTENSION_PARAMSTRING_H_SEEN */ /* 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 :