Hans Leidekker : webservices: Implement WsCreateReader and WsFreeReader.

Alexandre Julliard julliard at wine.codeweavers.com
Tue Sep 15 09:50:50 CDT 2015


Module: wine
Branch: master
Commit: a3004d11de2ace91b4e9646741406e59b2dababf
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=a3004d11de2ace91b4e9646741406e59b2dababf

Author: Hans Leidekker <hans at codeweavers.com>
Date:   Tue Sep 15 11:15:06 2015 +0200

webservices: Implement WsCreateReader and WsFreeReader.

---

 dlls/webservices/reader.c         | 111 ++++++++++++++++++++++++++++++++++++++
 dlls/webservices/webservices.spec |   4 +-
 2 files changed, 113 insertions(+), 2 deletions(-)

diff --git a/dlls/webservices/reader.c b/dlls/webservices/reader.c
index a0123aa..84802fc 100644
--- a/dlls/webservices/reader.c
+++ b/dlls/webservices/reader.c
@@ -250,6 +250,117 @@ void WINAPI WsFreeHeap( WS_HEAP *handle )
     heap_free( heap );
 }
 
+static const struct
+{
+    ULONG size;
+    BOOL  readonly;
+}
+reader_props[] =
+{
+    { sizeof(ULONG), FALSE },      /* WS_XML_READER_PROPERTY_MAX_DEPTH */
+    { sizeof(BOOL), FALSE },       /* WS_XML_READER_PROPERTY_ALLOW_FRAGMENT */
+    { sizeof(ULONG), FALSE },      /* WS_XML_READER_PROPERTY_MAX_ATTRIBUTES */
+    { sizeof(BOOL), FALSE },       /* WS_XML_READER_PROPERTY_READ_DECLARATION */
+    { sizeof(WS_CHARSET), FALSE }, /* WS_XML_READER_PROPERTY_CHARSET */
+    { sizeof(ULONGLONG), TRUE },   /* WS_XML_READER_PROPERTY_ROW */
+    { sizeof(ULONGLONG), TRUE },   /* WS_XML_READER_PROPERTY_COLUMN */
+    { sizeof(ULONG), FALSE },      /* WS_XML_READER_PROPERTY_UTF8_TRIM_SIZE */
+    { sizeof(ULONG), FALSE },      /* WS_XML_READER_PROPERTY_STREAM_BUFFER_SIZE */
+    { sizeof(BOOL), TRUE },        /* WS_XML_READER_PROPERTY_IN_ATTRIBUTE */
+    { sizeof(ULONG), FALSE },      /* WS_XML_READER_PROPERTY_STREAM_MAX_ROOT_MIME_PART_SIZE */
+    { sizeof(ULONG), FALSE },      /* WS_XML_READER_PROPERTY_STREAM_MAX_MIME_HEADERS_SIZE */
+    { sizeof(ULONG), FALSE },      /* WS_XML_READER_PROPERTY_MAX_MIME_PARTS */
+    { sizeof(BOOL), FALSE },       /* WS_XML_READER_PROPERTY_ALLOW_INVALID_CHARACTER_REFERENCES */
+    { sizeof(ULONG), FALSE },      /* WS_XML_READER_PROPERTY_MAX_NAMESPACES */
+};
+
+struct reader
+{
+    ULONG                   prop_count;
+    WS_XML_READER_PROPERTY  prop[sizeof(reader_props)/sizeof(reader_props[0])];
+};
+
+static struct reader *alloc_reader(void)
+{
+    static const ULONG count = sizeof(reader_props)/sizeof(reader_props[0]);
+    struct reader *ret;
+    ULONG i, size = sizeof(*ret) + count * sizeof(WS_XML_READER_PROPERTY);
+    char *ptr;
+
+    for (i = 0; i < count; i++) size += reader_props[i].size;
+    if (!(ret = heap_alloc_zero( size ))) return NULL;
+
+    ptr = (char *)&ret->prop[count];
+    for (i = 0; i < count; i++)
+    {
+        ret->prop[i].value = ptr;
+        ret->prop[i].valueSize = reader_props[i].size;
+        ptr += ret->prop[i].valueSize;
+    }
+    ret->prop_count = count;
+    return ret;
+}
+
+static HRESULT set_reader_prop( struct reader *reader, WS_XML_READER_PROPERTY_ID id, const void *value, ULONG size )
+{
+    if (id >= reader->prop_count || size != reader_props[id].size || reader_props[id].readonly)
+        return E_INVALIDARG;
+
+    memcpy( reader->prop[id].value, value, size );
+    return S_OK;
+}
+
+/**************************************************************************
+ *          WsCreateReader		[webservices.@]
+ */
+HRESULT WINAPI WsCreateReader( const WS_XML_READER_PROPERTY *properties, ULONG count,
+                               WS_XML_READER **handle, WS_ERROR *error )
+{
+    struct reader *reader;
+    ULONG i, max_depth = 32, max_attrs = 128, max_ns = 32;
+    WS_CHARSET charset = WS_CHARSET_UTF8;
+    BOOL read_decl = TRUE;
+    HRESULT hr;
+
+    TRACE( "%p %u %p %p\n", properties, count, handle, error );
+    if (error) FIXME( "ignoring error parameter\n" );
+
+    if (!handle) return E_INVALIDARG;
+    if (!(reader = alloc_reader())) return E_OUTOFMEMORY;
+
+    set_reader_prop( reader, WS_XML_READER_PROPERTY_MAX_DEPTH, &max_depth, sizeof(max_depth) );
+    set_reader_prop( reader, WS_XML_READER_PROPERTY_MAX_ATTRIBUTES, &max_attrs, sizeof(max_attrs) );
+    set_reader_prop( reader, WS_XML_READER_PROPERTY_READ_DECLARATION, &read_decl, sizeof(read_decl) );
+    set_reader_prop( reader, WS_XML_READER_PROPERTY_CHARSET, &charset, sizeof(charset) );
+    set_reader_prop( reader, WS_XML_READER_PROPERTY_MAX_NAMESPACES, &max_ns, sizeof(max_ns) );
+
+    for (i = 0; i < count; i++)
+    {
+        hr = set_reader_prop( reader, properties[i].id, properties[i].value, properties[i].valueSize );
+        if (hr != S_OK)
+        {
+            heap_free( reader );
+            return hr;
+        }
+    }
+
+    *handle = (WS_XML_READER *)reader;
+    return S_OK;
+}
+
+/**************************************************************************
+ *          WsFreeReader		[webservices.@]
+ */
+void WINAPI WsFreeReader( WS_XML_READER *handle )
+{
+    struct reader *reader = (struct reader *)handle;
+
+    TRACE( "%p\n", handle );
+
+    if (!reader) return;
+    heap_free( reader );
+}
+
 /**************************************************************************
  *          WsGetErrorProperty		[webservices.@]
  */
diff --git a/dlls/webservices/webservices.spec b/dlls/webservices/webservices.spec
index 4cb35f6..7e0a86b 100644
--- a/dlls/webservices/webservices.spec
+++ b/dlls/webservices/webservices.spec
@@ -29,7 +29,7 @@
 @ stub WsCreateMessage
 @ stub WsCreateMessageForChannel
 @ stub WsCreateMetadata
-@ stub WsCreateReader
+@ stdcall WsCreateReader(ptr long ptr ptr)
 @ stub WsCreateServiceEndpointFromTemplate
 @ stub WsCreateServiceHost
 @ stub WsCreateServiceProxy
@@ -54,7 +54,7 @@
 @ stub WsFreeListener
 @ stub WsFreeMessage
 @ stub WsFreeMetadata
-@ stub WsFreeReader
+@ stdcall WsFreeReader(ptr)
 @ stub WsFreeSecurityToken
 @ stub WsFreeServiceHost
 @ stub WsFreeServiceProxy




More information about the wine-cvs mailing list