summaryrefslogtreecommitdiffstats
path: root/src/live_effects/parameter/array.cpp
diff options
context:
space:
mode:
authorJabier Arraiza Cenoz <jabier.arraiza@marker.es>2015-02-15 18:29:48 +0000
committerJabiertxof <jtx@jtx.marker.es>2015-02-15 18:29:48 +0000
commit99fb2239028e72f8773bff39e43f7af33b4252d4 (patch)
tree23e96adea9f08b37f066559b28aac842cb230879 /src/live_effects/parameter/array.cpp
parentupdate to trunk (diff)
downloadinkscape-99fb2239028e72f8773bff39e43f7af33b4252d4.tar.gz
inkscape-99fb2239028e72f8773bff39e43f7af33b4252d4.zip
first steps
(bzr r13645.1.9)
Diffstat (limited to 'src/live_effects/parameter/array.cpp')
-rw-r--r--src/live_effects/parameter/array.cpp51
1 files changed, 30 insertions, 21 deletions
diff --git a/src/live_effects/parameter/array.cpp b/src/live_effects/parameter/array.cpp
index bd2bf1870..d17f28c4f 100644
--- a/src/live_effects/parameter/array.cpp
+++ b/src/live_effects/parameter/array.cpp
@@ -6,8 +6,7 @@
#include "live_effects/parameter/array.h"
-#include "svg/svg.h"
-#include "svg/stringstream.h"
+#include "helper-fns.h"
#include <2geom/coord.h>
#include <2geom/point.h>
@@ -48,37 +47,47 @@ ArrayParam<Geom::Point>::readsvg(const gchar * str)
}
return Geom::Point(Geom::infinity(),Geom::infinity());
}
-void
-sp_svg_satellite_read_d(gchar const *str, satellite *sat){
- gchar ** strarray = g_strsplit(str, "*", 0);
- if(strarray.size() != 6){
+//TODO: move maybe to svg-lenght.cpp
+unsigned int
+sp_svg_satellite_read_d(gchar const *str, Geom::Satellite *sat){
+ if (!str) {
+ return 0;
+ }
+ gchar ** strarray = g_strsplit(str, " * ", 0);
+ if(strarray[6] && !strarray[7]){
+ std::map< gchar const *, Geom::SatelliteType> gts = sat->GcharMapToSatelliteType;
+ sat->setSatelliteType(gts[strarray[0]]);
+ sat->setIsTime(helperfns_read_bool(strarray[1], true));
+ sat->setActive(helperfns_read_bool(strarray[2], true));
+ sat->setHasMirror(helperfns_read_bool(strarray[3], false));
+ sat->setHidden(helperfns_read_bool(strarray[4], false));
+ double time,size;
+ sp_svg_number_read_d(strarray[5], &time);
+ sp_svg_number_read_d(strarray[6], &size);
+ sat->setTime(time);
+ sat->setSize(size);
g_strfreev (strarray);
- return NULL;
+ return 1;
}
- sat->setSatelliteType(SatelliteTypeMap[strarray[0]]);
- sat->setActive(helperfns_read_bool(strarray[1], true));
- sat->sethasMirror(helperfns_read_bool(strarray[2], false));
- sat->setHidden(helperfns_read_bool(strarray[3], false));
- sat->setHidden(helperfns_read_bool(strarray[3], false));
- sat->setTime(sp_svg_number_read_d(strarray[4], 0.0));
- sat->setSize(sp_svg_number_read_d(strarray[5], 0.0));
g_strfreev (strarray);
+ return 0;
}
template <>
-std::pair<int, satellite>
-ArrayParam<Geom::Point>::readsvg(const gchar * str)
+std::pair<int, Geom::Satellite>
+ArrayParam<std::pair<int, Geom::Satellite> >::readsvg(const gchar * str)
{
gchar ** strarray = g_strsplit(str, ",", 2);
- int index;
- Geom::satellite sat = NULL;
- unsigned int success = sp_svg_number_read_d(strarray[0], &index);
+ double index;
+ std::pair<int, Geom::Satellite> result;
+ unsigned int success = (int)sp_svg_number_read_d(strarray[0], &index);
+ Geom::Satellite sat;
success += sp_svg_satellite_read_d(strarray[1], &sat);
g_strfreev (strarray);
if (success == 2) {
- return std::pair<index, sat>;
+ return std::make_pair(index, sat);
}
- return std::pair<Geom::infinity(),NULL>;
+ return std::make_pair((int)Geom::infinity(),sat);
}
} /* namespace LivePathEffect */