[PATCH 1/2] xmllite: Recognize us-ascii encoding
Nikolay Sivov
nsivov at codeweavers.com
Thu Mar 30 13:35:16 CDT 2017
Signed-off-by: Nikolay Sivov <nsivov at codeweavers.com>
---
dlls/xmllite/reader.c | 6 ++++--
dlls/xmllite/tests/writer.c | 7 +++++++
dlls/xmllite/xmllite_private.h | 1 +
3 files changed, 12 insertions(+), 2 deletions(-)
diff --git a/dlls/xmllite/reader.c b/dlls/xmllite/reader.c
index eb23f3aa96..238b0bcb07 100644
--- a/dlls/xmllite/reader.c
+++ b/dlls/xmllite/reader.c
@@ -83,6 +83,7 @@ typedef enum
StringValue_Last
} XmlReaderStringValue;
+static const WCHAR usasciiW[] = {'U','S','-','A','S','C','I','I',0};
static const WCHAR utf16W[] = {'U','T','F','-','1','6',0};
static const WCHAR utf8W[] = {'U','T','F','-','8',0};
@@ -153,8 +154,9 @@ struct xml_encoding_data
};
static const struct xml_encoding_data xml_encoding_map[] = {
+ { usasciiW, XmlEncoding_USASCII, 20127 },
{ utf16W, XmlEncoding_UTF16, ~0 },
- { utf8W, XmlEncoding_UTF8, CP_UTF8 }
+ { utf8W, XmlEncoding_UTF8, CP_UTF8 },
};
const WCHAR *get_encoding_name(xml_encoding encoding)
@@ -718,7 +720,7 @@ xml_encoding parse_encoding_name(const WCHAR *name, int len)
if (!name) return XmlEncoding_Unknown;
min = 0;
- max = sizeof(xml_encoding_map)/sizeof(struct xml_encoding_data) - 1;
+ max = sizeof(xml_encoding_map)/sizeof(xml_encoding_map[0]) - 1;
while (min <= max)
{
diff --git a/dlls/xmllite/tests/writer.c b/dlls/xmllite/tests/writer.c
index 0508466ab7..74546e0151 100644
--- a/dlls/xmllite/tests/writer.c
+++ b/dlls/xmllite/tests/writer.c
@@ -275,6 +275,7 @@ static void test_writer_create(void)
static void test_writeroutput(void)
{
static const WCHAR utf16W[] = {'u','t','f','-','1','6',0};
+ static const WCHAR usasciiW[] = {'u','s','-','a','s','c','i','i',0};
IXmlWriterOutput *output;
IUnknown *unk;
HRESULT hr;
@@ -312,6 +313,12 @@ todo_wine
/* releasing 'unk' crashes on native */
IUnknown_Release(output);
IUnknown_Release(output);
+
+ /* create with us-ascii */
+ output = NULL;
+ hr = CreateXmlWriterOutputWithEncodingName(&testoutput, NULL, usasciiW, &output);
+ ok(hr == S_OK, "got %08x\n", hr);
+ IUnknown_Release(output);
}
static void test_writestartdocument(void)
diff --git a/dlls/xmllite/xmllite_private.h b/dlls/xmllite/xmllite_private.h
index fa292650c7..702fadbd67 100644
--- a/dlls/xmllite/xmllite_private.h
+++ b/dlls/xmllite/xmllite_private.h
@@ -64,6 +64,7 @@ static inline void m_free(IMalloc *imalloc, void *mem)
typedef enum
{
+ XmlEncoding_USASCII,
XmlEncoding_UTF16,
XmlEncoding_UTF8,
XmlEncoding_Unknown
--
2.11.0
More information about the wine-patches
mailing list