1
0
Fork 0

canvas.parsesvg: fix handling text without tspan or empty text.

This commit is contained in:
Thomas Geymayer 2013-07-20 00:53:34 +02:00
parent d384e19704
commit 68efae1cd8

View file

@ -366,7 +366,8 @@ var parsesvg = func(group, path, options = nil)
{ {
text = { text = {
"attr": attr, "attr": attr,
"style": style "style": style,
"text": ""
}; };
tspans = []; tspans = [];
return; return;
@ -375,7 +376,8 @@ var parsesvg = func(group, path, options = nil)
{ {
append(tspans, { append(tspans, {
"attr": attr, "attr": attr,
"style": style "style": style,
"text": ""
}); });
return; return;
} }
@ -562,14 +564,11 @@ var parsesvg = func(group, path, options = nil)
if( size(data) and tspans != nil ) if( size(data) and tspans != nil )
{ {
if( size(tspans) == 0 ) if( size(tspans) == 0 )
# If no tspan is found add a dummy one # If no tspan is found use text element itself
append(tspans, {}); append(tspans, text);
# If text contains xml entities it gets split at each entity. So let's # If text contains xml entities it gets split at each entity. So let's
# glue it back into a single text... # glue it back into a single text...
if( tspans[-1]["text"] == nil )
tspans[-1]["text"] = data;
else
tspans[-1]["text"] ~= data; tspans[-1]["text"] ~= data;
} }
}; };