From 20d28e80a5c861a9d5f449ea911ab75b4f37ad0d Mon Sep 17 00:00:00 2001 From: Jef Date: Tue, 24 Sep 2024 14:54:57 +0200 Subject: Initial community commit --- Src/replicant/nswasabi/XMLString.cpp | 44 ++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 Src/replicant/nswasabi/XMLString.cpp (limited to 'Src/replicant/nswasabi/XMLString.cpp') diff --git a/Src/replicant/nswasabi/XMLString.cpp b/Src/replicant/nswasabi/XMLString.cpp new file mode 100644 index 00000000..4b22afd5 --- /dev/null +++ b/Src/replicant/nswasabi/XMLString.cpp @@ -0,0 +1,44 @@ +#include "XMLString.h" + +/* TODO: make and use some sort of nx_mutable_string_t object */ +XMLString::XMLString() +{ + data=0; +} + +XMLString::~XMLString() +{ + NXMutableStringDestroy(data); +} + + +void XMLString::Reset() +{ + if (data) + data->nx_string_data->len = 0; // TODO: make mutable string function for this +} + +nx_string_t XMLString::GetString() +{ + // TODO: make mutable string function for this + nx_string_t str = data->nx_string_data; + data->nx_string_data = 0; + NXMutableStringDestroy(data); + data=0; + return str; +} + +void XMLString::XMLCallback_OnStartElement(const nsxml_char_t *xmlpath, const nsxml_char_t *xmltag, ifc_xmlattributes *attributes) +{ + if (data) + data->nx_string_data->len = 0; // TODO: make mutable string function for this +} + +void XMLString::XMLCallback_OnCharacterData(const nsxml_char_t *xmlpath, const nsxml_char_t *xmltag, const nsxml_char_t *characters, size_t num_characters) +{ + if (!data) + data = NXMutableStringCreateFromXML(characters, num_characters); + else + NXMutableStringGrowFromXML(data, characters, num_characters); +} + -- cgit