summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorArseny Kapoulkine <arseny.kapoulkine@gmail.com>2015-04-13 21:21:26 -0700
committerArseny Kapoulkine <arseny.kapoulkine@gmail.com>2015-04-13 21:49:08 -0700
commit2a3435274f0d7d0e3ccb4417e143e5957e820332 (patch)
tree2cbf0b29bf1bcfa84a8e014f6bdc3b2c956e577c /src
parent950693be7fb1182644b720d3044a73aaaccee1c9 (diff)
Refactor format_indent_attributes implementation
Fix code style and revert redundant parameters/whitespace changes. Also remove format_each_attribute_on_new_line - we're only introducing one extra formatting flag. The flag implies format_indent but does not include its bitmask. Also add a few more tests. Fixes #14.
Diffstat (limited to 'src')
-rw-r--r--src/pugixml.cpp25
-rw-r--r--src/pugixml.hpp8
2 files changed, 16 insertions, 17 deletions
diff --git a/src/pugixml.cpp b/src/pugixml.cpp
index bf5835f..590d07f 100644
--- a/src/pugixml.cpp
+++ b/src/pugixml.cpp
@@ -3480,26 +3480,23 @@ PUGI__NS_BEGIN
}
}
- PUGI__FN void node_output_attributes(xml_buffered_writer &writer, xml_node_struct *node, const char_t *indent, size_t indent_length, unsigned int flags, unsigned int depth)
+ PUGI__FN void node_output_attributes(xml_buffered_writer& writer, xml_node_struct* node, const char_t* indent, size_t indent_length, unsigned int flags, unsigned int depth)
{
const char_t* default_name = PUGIXML_TEXT(":anonymous");
- bool eachAttributeOnNewLine = PUGI__NODETYPE(node) != node_declaration
- && (flags & format_indent)
- && (flags & format_each_attribute_on_new_line)
- && (flags & format_raw) == 0;
-
for (xml_attribute_struct* a = node->first_attribute; a; a = a->next_attribute)
{
- if (eachAttributeOnNewLine)
+ if ((flags & (format_indent_attributes | format_raw)) == format_indent_attributes)
{
writer.write('\n');
+
text_output_indent(writer, indent, indent_length, depth + 1);
}
else
{
writer.write(' ');
}
+
writer.write_string(a->name ? a->name : default_name);
writer.write('=', '"');
@@ -3510,7 +3507,7 @@ PUGI__NS_BEGIN
}
}
- PUGI__FN bool node_output_start(xml_buffered_writer &writer, xml_node_struct *node, const char_t *indent, size_t indent_length, unsigned int flags, unsigned int depth)
+ PUGI__FN bool node_output_start(xml_buffered_writer& writer, xml_node_struct* node, const char_t* indent, size_t indent_length, unsigned int flags, unsigned int depth)
{
const char_t* default_name = PUGIXML_TEXT(":anonymous");
const char_t* name = node->name ? node->name : default_name;
@@ -3524,11 +3521,13 @@ PUGI__NS_BEGIN
if (!node->first_child)
{
writer.write(' ', '/', '>');
+
return false;
}
else
{
writer.write('>');
+
return true;
}
}
@@ -3543,7 +3542,7 @@ PUGI__NS_BEGIN
writer.write('>');
}
- PUGI__FN void node_output_simple(xml_buffered_writer &writer, xml_node_struct *node, const char_t *indent, size_t indent_length, unsigned int flags, unsigned int depth)
+ PUGI__FN void node_output_simple(xml_buffered_writer& writer, xml_node_struct* node, unsigned int flags)
{
const char_t* default_name = PUGIXML_TEXT(":anonymous");
@@ -3577,7 +3576,7 @@ PUGI__NS_BEGIN
case node_declaration:
writer.write('<', '?');
writer.write_string(node->name ? node->name : default_name);
- node_output_attributes(writer, node, indent, indent_length, flags, depth);
+ node_output_attributes(writer, node, PUGIXML_TEXT(""), 0, flags | format_raw, 0);
writer.write('?', '>');
break;
@@ -3607,7 +3606,7 @@ PUGI__NS_BEGIN
PUGI__FN void node_output(xml_buffered_writer& writer, xml_node_struct* root, const char_t* indent, unsigned int flags, unsigned int depth)
{
- size_t indent_length = ((flags & (format_indent | format_raw)) == format_indent) ? strlength(indent) : 0;
+ size_t indent_length = ((flags & (format_indent | format_indent_attributes)) && (flags & format_raw) == 0) ? strlength(indent) : 0;
unsigned int indent_flags = indent_indent;
xml_node_struct* node = root;
@@ -3619,7 +3618,7 @@ PUGI__NS_BEGIN
// begin writing current node
if (PUGI__NODETYPE(node) == node_pcdata || PUGI__NODETYPE(node) == node_cdata)
{
- node_output_simple(writer, node, indent, indent_length, flags, depth);
+ node_output_simple(writer, node, flags);
indent_flags = 0;
}
@@ -3654,7 +3653,7 @@ PUGI__NS_BEGIN
}
else
{
- node_output_simple(writer, node, indent, indent_length, flags, depth);
+ node_output_simple(writer, node, flags);
indent_flags = indent_newline | indent_indent;
}
diff --git a/src/pugixml.hpp b/src/pugixml.hpp
index 36ed955..02ca86b 100644
--- a/src/pugixml.hpp
+++ b/src/pugixml.hpp
@@ -203,13 +203,13 @@ namespace pugi
// Open file using text mode in xml_document::save_file. This enables special character (i.e. new-line) conversions on some systems. This flag is off by default.
const unsigned int format_save_file_text = 0x20;
- // Set each attribute to new line
- const unsigned int format_each_attribute_on_new_line = 0x40;
+ // Write every attribute on a new line with appropriate indentation. This flag is off by default.
+ const unsigned int format_indent_attributes = 0x40;
+
// The default set of formatting flags.
// Nodes are indented depending on their depth in DOM tree, a default declaration is output if document has none.
const unsigned int format_default = format_indent;
- const unsigned int format_indent_attributes = format_indent | format_each_attribute_on_new_line;
-
+
// Forward declarations
struct xml_attribute_struct;
struct xml_node_struct;