diff options
author | Anton Samokhvalov <pg83@yandex.ru> | 2022-02-10 16:45:17 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:45:17 +0300 |
commit | d3a398281c6fd1d3672036cb2d63f842d2cb28c5 (patch) | |
tree | dd4bd3ca0f36b817e96812825ffaf10d645803f2 /library/cpp/xml/init/init.cpp | |
parent | 72cb13b4aff9bc9cf22e49251bc8fd143f82538f (diff) | |
download | ydb-d3a398281c6fd1d3672036cb2d63f842d2cb28c5.tar.gz |
Restoring authorship annotation for Anton Samokhvalov <pg83@yandex.ru>. Commit 2 of 2.
Diffstat (limited to 'library/cpp/xml/init/init.cpp')
-rw-r--r-- | library/cpp/xml/init/init.cpp | 62 |
1 files changed, 31 insertions, 31 deletions
diff --git a/library/cpp/xml/init/init.cpp b/library/cpp/xml/init/init.cpp index 9ecdb974d8..aa96c2dd31 100644 --- a/library/cpp/xml/init/init.cpp +++ b/library/cpp/xml/init/init.cpp @@ -1,39 +1,39 @@ -#include "init.h" - +#include "init.h" + #include <libxml/xmlIO.h> #include <libxml/parser.h> #include <libxml/parserInternals.h> #include <libxml/tree.h> - + #include <library/cpp/charset/recyr.hh> -#include <util/generic/singleton.h> - -namespace { +#include <util/generic/singleton.h> + +namespace { int CharEncodingInput(unsigned char* out, int* outlen, const unsigned char* in, int* inlen) { - size_t read = 0, written = 0; - RECODE_RESULT r = Recode(CODES_WIN, CODES_UTF8, (const char*)in, (char*)out, (size_t)*inlen, (size_t)*outlen, read, written); - if (r == RECODE_EOOUTPUT) - return -1; - if (r != RECODE_OK) - return -2; - *inlen = (int)read; - *outlen = (int)written; - return (int)written; - } - - class TLibXml2 { - public: - inline TLibXml2() { - xmlInitParser(); + size_t read = 0, written = 0; + RECODE_RESULT r = Recode(CODES_WIN, CODES_UTF8, (const char*)in, (char*)out, (size_t)*inlen, (size_t)*outlen, read, written); + if (r == RECODE_EOOUTPUT) + return -1; + if (r != RECODE_OK) + return -2; + *inlen = (int)read; + *outlen = (int)written; + return (int)written; + } + + class TLibXml2 { + public: + inline TLibXml2() { + xmlInitParser(); xmlNewCharEncodingHandler("windows-1251", CharEncodingInput, nullptr); - } - + } + inline ~TLibXml2() { - xmlCleanupParser(); - } - }; -} - -void NXml::InitEngine() { - Singleton<TLibXml2>(); -} + xmlCleanupParser(); + } + }; +} + +void NXml::InitEngine() { + Singleton<TLibXml2>(); +} |