summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlvin Penner <penner@vaxxine.com>2013-05-25 22:27:46 +0000
committerapenner <penner@vaxxine.com>2013-05-25 22:27:46 +0000
commitfa90512487d3efef01c614cd4c7552fd984e46a4 (patch)
tree4630498a83ae9fc63fc400058090fe5276b2da6b
parentReverting fix for Bug #1022543. (diff)
downloadinkscape-fa90512487d3efef01c614cd4c7552fd984e46a4.tar.gz
inkscape-fa90512487d3efef01c614cd4c7552fd984e46a4.zip
boolops. allow Division to create hole (Bug 499744)
Fixed bugs: - https://launchpad.net/bugs/499744 (bzr r12342)
-rw-r--r--src/livarot/ShapeMisc.cpp60
1 files changed, 35 insertions, 25 deletions
diff --git a/src/livarot/ShapeMisc.cpp b/src/livarot/ShapeMisc.cpp
index a7e5a6cdc..6fd40790f 100644
--- a/src/livarot/ShapeMisc.cpp
+++ b/src/livarot/ShapeMisc.cpp
@@ -374,6 +374,8 @@ Shape::ConvertToFormeNested (Path * dest, int nbP, Path * *orig, int wildPath,in
do
{
int dadContour=-1;
+ int childEdge = -1;
+ bool foundChild = false;
int startBord = -1;
{
int fi = 0;
@@ -389,6 +391,7 @@ Shape::ConvertToFormeNested (Path * dest, int nbP, Path * *orig, int wildPath,in
} else {
dadContour = GPOINTER_TO_INT(swdData[askTo].misc);
dadContour-=1; // pour compenser le decalage
+ childEdge = getPoint(fi).incidentEdge[FIRST];
}
}
lastPtUsed = fi + 1;
@@ -407,6 +410,9 @@ Shape::ConvertToFormeNested (Path * dest, int nbP, Path * *orig, int wildPath,in
{
// parcours en profondeur pour mettre les leF et riF a leurs valeurs
swdData[startBord].misc = (void *)(intptr_t)(1 + nbNest);
+ if (startBord == childEdge) {
+ foundChild = true;
+ }
//printf("part de %d\n",startBord);
int curBord = startBord;
bool back = false;
@@ -444,22 +450,23 @@ Shape::ConvertToFormeNested (Path * dest, int nbP, Path * *orig, int wildPath,in
}
else
{
- bool escapePath=false;
- int tb=curBord;
- while ( tb >= 0 && tb < numberOfEdges() ) {
- if ( ebData[tb].pathID == wildPath ) {
- escapePath=true;
- break;
- }
- tb=swdData[tb].precParc;
- }
+// bool escapePath=false;
+// int tb=curBord;
+// while ( tb >= 0 && tb < numberOfEdges() ) {
+// if ( ebData[tb].pathID == wildPath ) {
+// escapePath=true;
+// break;
+// }
+// tb=swdData[tb].precParc;
+// }
nesting=(int*)g_realloc(nesting,(nbNest+1)*sizeof(int));
contStart=(int*)g_realloc(contStart,(nbNest+1)*sizeof(int));
contStart[nbNest]=dest->descr_cmd.size();
- if ( escapePath ) {
- nesting[nbNest++]=-1; // contient des bouts de coupure -> a part
- } else {
+ if (foundChild) {
nesting[nbNest++]=dadContour;
+ foundChild = false;
+ } else {
+ nesting[nbNest++]=-1; // contient des bouts de coupure -> a part
}
swdData[curBord].suivParc = -1;
AddContour (dest, nbP, orig, startBord, curBord,splitWhenForced);
@@ -484,24 +491,24 @@ Shape::ConvertToFormeNested (Path * dest, int nbP, Path * *orig, int wildPath,in
if ( getEdge(curBord).en == curStartPt ) {
//printf("contour %i ",curStartPt);
- bool escapePath=false;
- int tb=curBord;
- while ( tb >= 0 && tb < numberOfEdges() ) {
- if ( ebData[tb].pathID == wildPath ) {
- escapePath=true;
- break;
- }
- tb=swdData[tb].precParc;
- }
+// bool escapePath=false;
+// int tb=curBord;
+// while ( tb >= 0 && tb < numberOfEdges() ) {
+// if ( ebData[tb].pathID == wildPath ) {
+// escapePath=true;
+// break;
+// }
+// tb=swdData[tb].precParc;
+// }
nesting=(int*)g_realloc(nesting,(nbNest+1)*sizeof(int));
contStart=(int*)g_realloc(contStart,(nbNest+1)*sizeof(int));
contStart[nbNest]=dest->descr_cmd.size();
- if ( escapePath ) {
- nesting[nbNest++]=-1; // contient des bouts de coupure -> a part
- } else {
+ if (foundChild) {
nesting[nbNest++]=dadContour;
+ foundChild = false;
+ } else {
+ nesting[nbNest++]=-1; // contient des bouts de coupure -> a part
}
-
swdData[curBord].suivParc = -1;
AddContour (dest, nbP, orig, startBord, curBord,splitWhenForced);
startBord=nb;
@@ -512,6 +519,9 @@ Shape::ConvertToFormeNested (Path * dest, int nbP, Path * *orig, int wildPath,in
swdData[nb].precParc = curBord;
swdData[curBord].suivParc = nb;
curBord = nb;
+ if (nb == childEdge) {
+ foundChild = true;
+ }
//printf("suite %d\n",curBord);
}
}