summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMichael G. Sloan <mgsloan@gmail.com>2007-08-18 02:17:00 +0000
committermgsloan <mgsloan@users.sourceforge.net>2007-08-18 02:17:00 +0000
commit9abe06fbb7b13c9f5162159f54cb0fef08fce34e (patch)
tree0850bce022b63a7b7a9be50eae1d3b10b517dd86 /src
parentfew changes in import from ocal dialog (diff)
downloadinkscape-9abe06fbb7b13c9f5162159f54cb0fef08fce34e.tar.gz
inkscape-9abe06fbb7b13c9f5162159f54cb0fef08fce34e.zip
Fixing a possible segfault in the sbasis to path code (also committed to 2geom))
(bzr r3503)
Diffstat (limited to 'src')
-rw-r--r--src/2geom/sbasis-to-bezier.cpp9
-rw-r--r--src/live_effects/n-art-bpath-2geom.cpp3
2 files changed, 7 insertions, 5 deletions
diff --git a/src/2geom/sbasis-to-bezier.cpp b/src/2geom/sbasis-to-bezier.cpp
index 731680075..e823b29ca 100644
--- a/src/2geom/sbasis-to-bezier.cpp
+++ b/src/2geom/sbasis-to-bezier.cpp
@@ -172,17 +172,19 @@ void build_from_sbasis(Geom::PathBuilder &pb, D2<SBasis> const &B, double tol) {
}
}
-void
-path_from_sbasis(Geom::Path &p, D2<SBasis> const &B, double tol) {
+Path
+path_from_sbasis(D2<SBasis> const &B, double tol) {
PathBuilder pb;
pb.moveTo(B.at0());
build_from_sbasis(pb, B, tol);
- p = pb.peek().front();
+ pb.finish();
+ return pb.peek().front();
}
//TODO: some of this logic should be lifted into svg-path
std::vector<Geom::Path>
path_from_piecewise(Geom::Piecewise<Geom::D2<Geom::SBasis> > const &B, double tol) {
+
Geom::PathBuilder pb;
if(B.size() == 0) return pb.peek();
Geom::Point start = B[0].at0();
@@ -206,6 +208,7 @@ path_from_piecewise(Geom::Piecewise<Geom::D2<Geom::SBasis> > const &B, double to
}
build_from_sbasis(pb, B[i], tol);
}
+ pb.finish();
return pb.peek();
}
diff --git a/src/live_effects/n-art-bpath-2geom.cpp b/src/live_effects/n-art-bpath-2geom.cpp
index 5f4e4c7b9..e71e28b99 100644
--- a/src/live_effects/n-art-bpath-2geom.cpp
+++ b/src/live_effects/n-art-bpath-2geom.cpp
@@ -45,8 +45,7 @@ static void curve_to_svgd(std::ostream & f, Geom::Curve const* c) {
// }
else {
//this case handles sbasis as well as all other curve types
- Geom::Path sbasis_path;
- path_from_sbasis(sbasis_path, c->sbasis(), 0.1);
+ Geom::Path sbasis_path = path_from_sbasis(sbasis_path, c->sbasis(), 0.1);
//recurse to convert the new path resulting from the sbasis to svgd
for(Geom::Path::iterator iter = sbasis_path.begin(); iter != sbasis_path.end(); ++iter) {