diff options
| author | finder <[email protected]> | 2022-02-10 16:49:24 +0300 | 
|---|---|---|
| committer | Daniil Cherednik <[email protected]> | 2022-02-10 16:49:24 +0300 | 
| commit | 2ab6bab688484680d3ebc5c4a7e9cd3ff04fda04 (patch) | |
| tree | 5d5cb817648f650d76cf1076100726fd9b8448e8 /library/cpp/xml/document/node-attr.h | |
| parent | abbbaf4075fbaa0ff4ce9faa1188089466a21dbe (diff) | |
Restoring authorship annotation for <[email protected]>. Commit 2 of 2.
Diffstat (limited to 'library/cpp/xml/document/node-attr.h')
| -rw-r--r-- | library/cpp/xml/document/node-attr.h | 174 | 
1 files changed, 87 insertions, 87 deletions
| diff --git a/library/cpp/xml/document/node-attr.h b/library/cpp/xml/document/node-attr.h index 1c4082e6fed..6e74403943c 100644 --- a/library/cpp/xml/document/node-attr.h +++ b/library/cpp/xml/document/node-attr.h @@ -1,13 +1,13 @@ -#pragma once  -  +#pragma once +  #include "xml-document-decl.h"  #include "libxml-guards.h" -#include <util/stream/str.h>  +#include <util/stream/str.h>  #include <util/string/cast.h> -  -namespace NXml {  + +namespace NXml {  #define THROW(x, y) ythrow yexception() << #x << ": " << y -  +      // libxml defines unsigned char -> xmlChar,      // and all functions use xmlChar.      inline static const char* CAST2CHAR(const xmlChar* x) { @@ -17,123 +17,123 @@ namespace NXml {          return reinterpret_cast<const xmlChar*>(x);      } -    template <class T>  +    template <class T>      void TNode::AttrInternal(TCharPtr& value, T& res, TStringBuf errContext) const { -        try {  -            res = FromString<T>(CAST2CHAR(value.Get()));  +        try { +            res = FromString<T>(CAST2CHAR(value.Get()));          } catch (TFromStringException&) {              THROW(XmlException, "Failed to convert string " << TString{TStringBuf(CAST2CHAR(value.Get())).substr(0, 50)}.Quote() << " from '" << errContext << "' to requested type"); -        }  -    }  -  -    template <>  +        } +    } + +    template <>      inline void TNode::AttrInternal(TCharPtr& value, TString& res, TStringBuf /*errContext*/) const {          TString tmp(CAST2CHAR(value.Get())); -        res.swap(tmp);  -    }  -  -    template <class T>  +        res.swap(tmp); +    } + +    template <class T>      T TNode::Attr(TZtStringBuf name) const {          TCharPtr value(xmlGetProp(NodePointer, XMLCHAR(name.c_str())));          if (!value) {              THROW(AttributeNotFound, Path() << "@" << name); -        }  -  -        T t;  +        } + +        T t;          AttrInternal(value, t, name); -        return t;  -    }  -  -    template <class T>  +        return t; +    } + +    template <class T>      T TNode::Attr(TZtStringBuf name, const T& defvalue) const {          TCharPtr attr(xmlGetProp(NodePointer, XMLCHAR(name.c_str())));          if (!attr) { -            return defvalue;  -        }  -  -        T t;  +            return defvalue; +        } + +        T t;          AttrInternal(attr, t, name); -        return t;  -    }  -  -    template <class T>  +        return t; +    } + +    template <class T>      void TNode::Attr(TZtStringBuf name, T& value) const {          TCharPtr attr(xmlGetProp(NodePointer, XMLCHAR(name.c_str())));          if (!attr) {              THROW(AttributeNotFound, Path() << name); -        }  -  +        } +          AttrInternal(attr, value, name); -    }  -  -    template <class T>  +    } + +    template <class T>      void TNode::Attr(TZtStringBuf name, T& value, const T& defvalue) const {          TCharPtr attr(xmlGetProp(NodePointer, XMLCHAR(name.c_str()))); -  +          if (!attr) { -            value = defvalue;  +            value = defvalue;          } else {              AttrInternal(attr, value, name); -        }  -    }  -  -    template <class T>  +        } +    } + +    template <class T>      T TNode::Value() const {          if (!NodePointer || xmlIsBlankNode(NodePointer)) {              THROW(NodeIsBlank, Path()); -        }  -  +        } +          TCharPtr val(xmlNodeGetContent(NodePointer)); -        T t;  +        T t;          AttrInternal(val, t, this->Name()); -        return t;  -    }  -  -    template <class T>  +        return t; +    } + +    template <class T>      T TNode::Value(const T& defvalue) const {          if (!NodePointer || xmlIsBlankNode(NodePointer)) { -            return defvalue;  -        }  -  +            return defvalue; +        } +          TCharPtr val(xmlNodeGetContent(NodePointer)); -        T t;  +        T t;          AttrInternal(val, t, this->Name()); -        return t;  -    }  -  -    template <class T>  +        return t; +    } + +    template <class T>      typename std::enable_if<!std::is_convertible_v<T, TStringBuf>, void>::type      TNode::SetValue(const T& value) { -        TStringStream ss;  -        ss << value;  +        TStringStream ss; +        ss << value;          SetValue(ss.Str());      }      inline void TNode::SetValue(TStringBuf value) { -        xmlNodeSetContent(NodePointer, XMLCHAR(""));  +        xmlNodeSetContent(NodePointer, XMLCHAR(""));          xmlNodeAddContentLen(NodePointer, XMLCHAR(value.data()), value.Size()); -    }  -  +    } +      inline void TNode::SetAttr(TZtStringBuf name, TZtStringBuf value) {          xmlAttr* attr = xmlSetProp(NodePointer, XMLCHAR(name.c_str()), XMLCHAR(value.c_str())); -  +          if (!attr) {              THROW(XmlException, "Can't set node attribute <"                                      << name                                      << "> to <"                                      << value                                      << ">"); -        }  -    }  -  -    template <class T>  +        } +    } + +    template <class T>      typename std::enable_if<!std::is_convertible_v<T, TZtStringBuf>, void>::type      TNode::SetAttr(TZtStringBuf name, const T& value) { -        TStringStream ss;  -        ss << value;  +        TStringStream ss; +        ss << value;          SetAttr(name, TZtStringBuf(ss.Str())); -    }  -  +    } +      inline void TNode::SetAttr(TZtStringBuf name) {          xmlAttr* attr = xmlSetProp(NodePointer, XMLCHAR(name.c_str()), nullptr); @@ -151,37 +151,37 @@ namespace NXml {                                      << ">");      } -    template <class T>  +    template <class T>      typename std::enable_if<!std::is_convertible_v<T, TZtStringBuf>, TNode>::type      TNode::AddChild(TZtStringBuf name, const T& value) { -        TStringStream ss;  -        ss << value;  +        TStringStream ss; +        ss << value;          return AddChild(name, TZtStringBuf(ss.Str())); -    }  -  +    } +      inline TNode TNode::AddChild(TZtStringBuf name, TZtStringBuf value) {          if (IsNull()) {              THROW(XmlException, "addChild [name=" << name << ", value=" << value                                                    << "]: can't add child to null node"); -        }  -  +        } +          xmlNode* child = nullptr; -  +          if (value.empty()) {              child = xmlNewTextChild(NodePointer, nullptr, XMLCHAR(name.c_str()), nullptr);          } else { -            child = xmlNewTextChild(  +            child = xmlNewTextChild(                  NodePointer, nullptr, XMLCHAR(name.c_str()), XMLCHAR(value.c_str())); -        }  -  +        } +          if (!child) {              THROW(XmlException, "addChild [name=" << name << ", value=" << value                                                    << "]: xmlNewTextChild returned NULL"); -        }  -  +        } +          return TNode(DocPointer, child); -    }  -  +    } +      template <class T>      typename std::enable_if<!std::is_convertible_v<T, TStringBuf>, TNode>::type      TNode::AddText(const T& value) { | 
