Code

fix pasting style after copying a text span
[inkscape.git] / src / shape-editor.h
index bd93668f77bcab9762c4d30da481d9346c7d5358..f30f1aa12f7d0bf045c63dc2a7eb4aae5ea8d994 100644 (file)
  */
 
 #include <forward.h>
+#include <libnr/nr-forward.h>
 
-namespace Inkscape {
-namespace NodePath {
-class Path;
-typedef enum NodeType;
-}
-}
+namespace Inkscape { namespace NodePath { class Path; } }
+namespace Inkscape { namespace XML { class Node; } }
 
 #include "libnr/nr-path-code.h"
 #include "libnr/nr-point.h"
+#include <boost/optional.hpp>
+#include <vector>
 
-class SPKnotHolder;
+class KnotHolder;
 class SPDesktop;
 class SPNodeContext;
 class ShapeEditorsCollective;
 
+enum SubType{
+    SH_NODEPATH,
+    SH_KNOTHOLDER
+};
+
 class ShapeEditor {
 public:
 
     ShapeEditor(SPDesktop *desktop);
     ~ShapeEditor();
 
-    void set_item (SPItem *item);
-    void unset_item ();
-
-    SPItem *get_item ();
+    void set_item (SPItem *item, SubType type, bool keep_knotholder = false);
+    void set_item_lpe_path_parameter(SPItem *item, SPObject *lpeobject, const char * key);
+    void unset_item (SubType type, bool keep_knotholder = false);
 
-    bool has_nodepath ();
-    bool has_knotholder ();
+    bool has_nodepath (); //((deprecated))
+    void update_knotholder (); //((deprecated))
 
-    bool has_local_change ();
-    void decrement_local_change ();
+    bool has_local_change (SubType type);
+    void decrement_local_change (SubType type);
 
     GList *save_nodepath_selection ();
     void restore_nodepath_selection (GList *saved);
@@ -53,7 +56,7 @@ public:
 
     void update_statusbar ();
 
-    bool is_over_stroke (NR::Point event_p, bool remember);
+    bool is_over_stroke (Geom::Point event_p, bool remember);
 
     void add_node_near_point(); // uses the shapeeditor's remembered point, if any
 
@@ -67,7 +70,7 @@ public:
 
     void finish_drag ();
 
-    void select_rect (NR::Rect  const &rect, bool add);
+    void select_rect (Geom::Rect  const &rect, bool add);
 
     bool has_selection ();
     void deselect ();
@@ -79,18 +82,20 @@ public:
 
     void delete_nodes();
     void delete_nodes_preserving_shape();
+    void delete_segment();
 
-    void set_node_type(Inkscape::NodePath::NodeType type);
+    void set_node_type(int type);
 
     void break_at_nodes();
     void join_nodes();
+    void join_segments();
 
     void duplicate_nodes();
 
     void set_type_of_segments(NRPathcode code);
 
     void move_nodes(gdouble dx, gdouble dy);
-    void move_nodes_screen(gdouble dx, gdouble dy);
+    void move_nodes_screen(SPDesktop *desktop, gdouble dx, gdouble dy);
 
     void rotate_nodes(gdouble angle, int which, bool screen);
 
@@ -102,16 +107,30 @@ public:
     void select_next ();
     void select_prev ();
 
-    void flip (NR::Dim2 axis);
+    void show_handles (bool show);
+    void show_helperpath (bool show);
+
+    void flip (Geom::Dim2 axis, boost::optional<Geom::Point> center = boost::optional<Geom::Point>());
+
+    void distribute (Geom::Dim2 axis);
+    void align (Geom::Dim2 axis);
 
-    void distribute (NR::Dim2 axis);
-    void align (NR::Dim2 axis);
+    bool nodepath_edits_repr_key(gchar const *name);
+
+    // this one is only public because it's called from non-C++ repr changed callback
+    void shapeeditor_event_attr_changed(gchar const *name);
 
 private:
+    bool has_knotholder ();
+    void reset_item (SubType type, bool keep_knotholder = true);
+    const SPItem *get_item (SubType type);
+
     SPDesktop *desktop;
 
     Inkscape::NodePath::Path *nodepath;
-    SPKnotHolder *knotholder;
+
+    // TODO: std::list<KnotHolder *> knotholders;
+    KnotHolder *knotholder;
 
     ShapeEditorsCollective *container;
 
@@ -120,8 +139,10 @@ private:
     double grab_t;
     int grab_node; // number of node grabbed by sp_node_context_is_over_stroke
     bool hit;
-    NR::Point curvepoint_event; // int coords from event
-    NR::Point curvepoint_doc; // same, in doc coords
+    Geom::Point curvepoint_event; // int coords from event
+    Geom::Point curvepoint_doc; // same, in doc coords
+
+    Inkscape::XML::Node *listener_attached_for;
 };