Skip to content

Commit

Permalink
Merge pull request #4450 from mapnik/svg-refactor
Browse files Browse the repository at this point in the history
Svg refactor
  • Loading branch information
artemp committed Apr 30, 2024
2 parents 6e81004 + 3176749 commit f84c30f
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 61 deletions.
6 changes: 5 additions & 1 deletion include/mapnik/svg/svg_converter.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -73,7 +73,11 @@ class svg_converter : util::noncopyable
current_group_ = &current_group_->elements.back().get<group>();
}

void end_group() { current_group_ = current_group_->parent; }
void end_group()
{
if (current_group_->parent != nullptr)
current_group_ = current_group_->parent;
}

void begin_path()
{
Expand Down
99 changes: 39 additions & 60 deletions src/svg/svg_parser.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -500,7 +500,7 @@ void traverse_tree(svg_parser& parser, rapidxml::xml_node<char> const* node)

switch (node->type())
{
case rapidxml::node_element: {
case rapidxml::node_element:
parser.font_sizes_.push_back(parser.font_sizes_.back());
switch (name)
{
Expand All @@ -525,57 +525,43 @@ void traverse_tree(svg_parser& parser, rapidxml::xml_node<char> const* node)
case "radialGradient"_case:
parse_radial_gradient(parser, node);
break;
}

if (!parser.is_defs_) // FIXME
{
switch (name)
{
case "g"_case:
if (node->first_node() != nullptr)
{
parser.path_.push_attr();
parse_id(parser, node);
if (parser.css_style_)
process_css(parser, node);
parse_attr(parser, node);
parser.path_.begin_group();
}
break;
case "use"_case:
parser.path_.push_attr();
parse_id(parser, node);
if (parser.css_style_)
process_css(parser, node);
parse_attr(parser, node);
case "g"_case:
parser.path_.push_attr();
parse_id(parser, node);
if (parser.css_style_)
process_css(parser, node);
parse_attr(parser, node);
parser.path_.begin_group();
break;
case "use"_case:
parser.path_.push_attr();
parse_id(parser, node);
if (parser.css_style_)
process_css(parser, node);
parse_attr(parser, node);
if (parser.path_.cur_attr().opacity < 1.0)
parser.path_.begin_group();
parse_use(parser, node);
if (parser.path_.cur_attr().opacity < 1.0)
parser.path_.end_group();
parser.path_.pop_attr();
break;
default:
parser.path_.push_attr();
parse_id(parser, node);
if (parser.css_style_)
process_css(parser, node);
parse_attr(parser, node);
if (parser.path_.display())
{
if (parser.path_.cur_attr().opacity < 1.0)
parser.path_.begin_group();
parse_use(parser, node);
parse_element(parser, node->name(), node);
if (parser.path_.cur_attr().opacity < 1.0)
parser.path_.end_group();
parser.path_.pop_attr();
break;
default:
parser.path_.push_attr();
parse_id(parser, node);
if (parser.css_style_)
process_css(parser, node);
parse_attr(parser, node);
if (parser.path_.display())
{
if (parser.path_.cur_attr().opacity < 1.0)
parser.path_.begin_group();
parse_element(parser, node->name(), node);
if (parser.path_.cur_attr().opacity < 1.0)
parser.path_.end_group();
}
parser.path_.pop_attr();
}
}
else
{
// save node for later
parse_id(parser, node);
}
parser.path_.pop_attr();
break;
}

if ("style"_case == name)
Expand Down Expand Up @@ -607,8 +593,7 @@ void traverse_tree(svg_parser& parser, rapidxml::xml_node<char> const* node)
}

end_element(parser, node);
}
break;
break;
default:
break;
}
Expand All @@ -618,20 +603,14 @@ void end_element(svg_parser& parser, rapidxml::xml_node<char> const* node)
{
parser.font_sizes_.pop_back();
auto name = name_to_int(node->name());
if (!parser.is_defs_ && (name == "g"_case))
if (name == "g"_case)
{
parser.path_.end_group();
if (node->first_node() != nullptr)
{
parser.path_.pop_attr();
}
parser.path_.pop_attr();
}
else if (name == "svg"_case)
{
// if (node->first_node() != nullptr)
//{
// parser.path_.pop_attr();
//}
parser.path_.pop_attr();
}
else if (name == "defs"_case)
{
Expand Down Expand Up @@ -680,7 +659,7 @@ void parse_element(svg_parser& parser, char const* name, rapidxml::xml_node<char
parse_ellipse(parser, node);
break;
case "svg"_case:
// parser.path_.push_attr();
parser.path_.push_attr();
parse_dimensions(parser, node);
parse_attr(parser, node);
parser.path_.set_opacity(parser.path_.cur_attr().opacity);
Expand Down

0 comments on commit f84c30f

Please sign in to comment.