Files
scummvm-cursorfix/engines/ultima/shared/conf/xml_node.h
2026-02-02 04:50:13 +01:00

167 lines
4.7 KiB
C++

/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
#ifndef SHARED_CONF_XML_NODE_H
#define SHARED_CONF_XML_NODE_H
#include "common/array.h"
#include "common/hash-str.h"
#include "common/path.h"
#include "common/str.h"
#include "common/util.h"
namespace Ultima {
namespace Shared {
class XMLTree;
class XMLNode {
private:
XMLTree *_tree;
XMLNode *_parent;
Common::String _id;
Common::String _text;
Common::Array<XMLNode *> _nodeList;
Common::StringMap _attributes;
bool _noClose;
Common::String _emptyString;
private:
static void parseDocTypeElement(const Common::String &s, size_t &nn);
void parseNodeText(const Common::String &nodeText);
/**
* Trim down any whitespaces in the passed text
*/
static void trim(Common::String &s);
/**
* Parses a specified file and returns the root node for it
*/
static XMLNode *xmlParseFile(XMLTree *tree, const Common::Path &fname);
static Common::String closeTag(const Common::String &s);
static Common::String encodeEntity(const Common::String &s);
public:
XMLNode(XMLTree *tree, XMLNode *parent = nullptr) : _tree(tree), _parent(parent), _noClose(false) {}
XMLNode(const XMLNode &n) : _tree(n._tree), _parent(n._parent), _id(n._id),
_text(n._text), _nodeList(n._nodeList), _noClose(false) {}
~XMLNode();
XMLNode &operator=(const XMLNode &n) {
_id = n._id;
_text = n._text;
_nodeList = n._nodeList;
_noClose = n._noClose;
return *this;
}
const Common::String &reference(const Common::String &, bool &);
const XMLNode *subtree(const Common::String &) const;
const Common::String &id() const {
return _id;
}
const Common::String &text(void) const {
return _text;
}
bool nodeIsText() const {
return !_text.empty();
}
XMLNode *getParent() const {
return _parent;
}
bool hasChildren() const {
return !_nodeList.empty();
}
XMLNode *firstChild() const {
return _nodeList.empty() ? nullptr : _nodeList[0];
}
const Common::StringMap &attributes() const {
return _attributes;
}
bool hasProperty(const Common::String &attrName) const {
return _attributes.contains(attrName);
}
Common::String getProperty(const Common::String &attrName) const {
return _attributes.contains(attrName) ? _attributes[attrName] : "";
}
int getPropertyInt(const Common::String &attrName) const {
return _attributes.contains(attrName) ? atol(_attributes[attrName].c_str()) : 0;
}
bool getPropertyBool(const Common::String &attrName) const {
if (_attributes.contains(attrName)) {
Common::String str = _attributes[attrName];
return toupper(str[0]) == 'T' || str == "1";
} else {
return false;
}
}
Common::String operator[](const Common::String &attrName) const {
return getProperty(attrName);
}
const Common::Array<XMLNode *> &children() const {
return _nodeList;
}
typedef Common::Pair<Common::String, Common::String> KeyType;
typedef Common::Array<KeyType> KeyTypeList;
/**
* Returns a list of key->value pairs that are found under the provided 'basekey'.
* Ignores comments (<!-- ... --> and doesn't return them.
* Returns true if search is 'finished'
*/
bool searchPairs(KeyTypeList &ktl, const Common::String &basekey,
const Common::String &currkey, const unsigned int pos);
void selectPairs(KeyTypeList &ktl, const Common::String &currkey);
Common::String dump(int depth = 0);
void xmlAssign(const Common::String &key, const Common::String &value);
static XMLNode *xmlParseDoc(XMLTree *tree, const Common::String &s);
static XMLNode *xmlParse(XMLTree *tree, const Common::String &s, size_t &pos);
void listKeys(const Common::String &, Common::Array<Common::String> &,
bool longformat = true) const;
/**
* Deletes the entire tree this node belongs to, including itself
*/
void freeDoc();
/**
* Gets the prior sibling to this one
*/
XMLNode *getPrior() const;
/**
* Gets the following sibling to this one
*/
XMLNode *getNext() const;
};
} // End of namespace Shared
} // End of namespace Ultima
#endif