Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
dc2fe2a4
Commit
dc2fe2a4
authored
Nov 18, 2012
by
Nikolay Sivov
Committed by
Alexandre Julliard
Nov 20, 2012
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
xmllite: Store remaining reader input parameters.
parent
befbc8f5
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
50 additions
and
1 deletion
+50
-1
reader.c
dlls/xmllite/reader.c
+50
-1
No files found.
dlls/xmllite/reader.c
View file @
dc2fe2a4
...
@@ -29,6 +29,7 @@
...
@@ -29,6 +29,7 @@
#include "xmllite_private.h"
#include "xmllite_private.h"
#include "wine/debug.h"
#include "wine/debug.h"
#include "wine/unicode.h"
WINE_DEFAULT_DEBUG_CHANNEL
(
xmllite
);
WINE_DEFAULT_DEBUG_CHANNEL
(
xmllite
);
...
@@ -73,6 +74,9 @@ typedef struct _xmlreaderinput
...
@@ -73,6 +74,9 @@ typedef struct _xmlreaderinput
/* reference passed on IXmlReaderInput creation, is kept when input is created */
/* reference passed on IXmlReaderInput creation, is kept when input is created */
IUnknown
*
input
;
IUnknown
*
input
;
IMalloc
*
imalloc
;
IMalloc
*
imalloc
;
xml_encoding
encoding
;
BOOL
hint
;
WCHAR
*
baseuri
;
/* stream reference set after SetInput() call from reader,
/* stream reference set after SetInput() call from reader,
stored as sequential stream, cause currently
stored as sequential stream, cause currently
optimizations possible with IStream aren't implemented */
optimizations possible with IStream aren't implemented */
...
@@ -161,6 +165,21 @@ static inline void readerinput_free(xmlreaderinput *input, void *mem)
...
@@ -161,6 +165,21 @@ static inline void readerinput_free(xmlreaderinput *input, void *mem)
return
m_free
(
input
->
imalloc
,
mem
);
return
m_free
(
input
->
imalloc
,
mem
);
}
}
static
inline
WCHAR
*
readerinput_strdupW
(
xmlreaderinput
*
input
,
const
WCHAR
*
str
)
{
LPWSTR
ret
=
NULL
;
if
(
str
)
{
DWORD
size
;
size
=
(
strlenW
(
str
)
+
1
)
*
sizeof
(
WCHAR
);
ret
=
readerinput_alloc
(
input
,
size
);
if
(
ret
)
memcpy
(
ret
,
str
,
size
);
}
return
ret
;
}
static
HRESULT
init_encoded_buffer
(
xmlreaderinput
*
input
,
encoded_buffer
*
buffer
)
static
HRESULT
init_encoded_buffer
(
xmlreaderinput
*
input
,
encoded_buffer
*
buffer
)
{
{
const
int
initial_len
=
0x2000
;
const
int
initial_len
=
0x2000
;
...
@@ -195,6 +214,32 @@ static HRESULT get_code_page(xml_encoding encoding, xmlreaderinput *input)
...
@@ -195,6 +214,32 @@ static HRESULT get_code_page(xml_encoding encoding, xmlreaderinput *input)
return
S_OK
;
return
S_OK
;
}
}
static
xml_encoding
parse_encoding_name
(
const
WCHAR
*
encoding
)
{
int
min
,
max
,
n
,
c
;
if
(
!
encoding
)
return
XmlEncoding_Unknown
;
min
=
0
;
max
=
sizeof
(
xml_encoding_map
)
/
sizeof
(
struct
xml_encoding_data
)
-
1
;
while
(
min
<=
max
)
{
n
=
(
min
+
max
)
/
2
;
c
=
strcmpiW
(
xml_encoding_map
[
n
].
encoding
,
encoding
);
if
(
!
c
)
return
xml_encoding_map
[
n
].
enc
;
if
(
c
>
0
)
max
=
n
-
1
;
else
min
=
n
+
1
;
}
return
XmlEncoding_Unknown
;
}
static
HRESULT
alloc_input_buffer
(
xmlreaderinput
*
input
)
static
HRESULT
alloc_input_buffer
(
xmlreaderinput
*
input
)
{
{
input_buffer
*
buffer
;
input_buffer
*
buffer
;
...
@@ -688,6 +733,7 @@ static ULONG WINAPI xmlreaderinput_Release(IXmlReaderInput *iface)
...
@@ -688,6 +733,7 @@ static ULONG WINAPI xmlreaderinput_Release(IXmlReaderInput *iface)
if
(
This
->
input
)
IUnknown_Release
(
This
->
input
);
if
(
This
->
input
)
IUnknown_Release
(
This
->
input
);
if
(
This
->
stream
)
ISequentialStream_Release
(
This
->
stream
);
if
(
This
->
stream
)
ISequentialStream_Release
(
This
->
stream
);
if
(
This
->
buffer
)
free_input_buffer
(
This
->
buffer
);
if
(
This
->
buffer
)
free_input_buffer
(
This
->
buffer
);
readerinput_free
(
This
,
This
->
baseuri
);
readerinput_free
(
This
,
This
);
readerinput_free
(
This
,
This
);
if
(
imalloc
)
IMalloc_Release
(
imalloc
);
if
(
imalloc
)
IMalloc_Release
(
imalloc
);
}
}
...
@@ -747,7 +793,7 @@ HRESULT WINAPI CreateXmlReaderInputWithEncodingName(IUnknown *stream,
...
@@ -747,7 +793,7 @@ HRESULT WINAPI CreateXmlReaderInputWithEncodingName(IUnknown *stream,
xmlreaderinput
*
readerinput
;
xmlreaderinput
*
readerinput
;
HRESULT
hr
;
HRESULT
hr
;
FIXME
(
"%p %p %s %d %s %p: stub
\n
"
,
stream
,
imalloc
,
wine_dbgstr_w
(
encoding
),
TRACE
(
"%p %p %s %d %s %p
\n
"
,
stream
,
imalloc
,
wine_dbgstr_w
(
encoding
),
hint
,
wine_dbgstr_w
(
base_uri
),
ppInput
);
hint
,
wine_dbgstr_w
(
base_uri
),
ppInput
);
if
(
!
stream
||
!
ppInput
)
return
E_INVALIDARG
;
if
(
!
stream
||
!
ppInput
)
return
E_INVALIDARG
;
...
@@ -763,6 +809,9 @@ HRESULT WINAPI CreateXmlReaderInputWithEncodingName(IUnknown *stream,
...
@@ -763,6 +809,9 @@ HRESULT WINAPI CreateXmlReaderInputWithEncodingName(IUnknown *stream,
readerinput
->
imalloc
=
imalloc
;
readerinput
->
imalloc
=
imalloc
;
readerinput
->
stream
=
NULL
;
readerinput
->
stream
=
NULL
;
if
(
imalloc
)
IMalloc_AddRef
(
imalloc
);
if
(
imalloc
)
IMalloc_AddRef
(
imalloc
);
readerinput
->
encoding
=
parse_encoding_name
(
encoding
);
readerinput
->
hint
=
hint
;
readerinput
->
baseuri
=
readerinput_strdupW
(
readerinput
,
base_uri
);
hr
=
alloc_input_buffer
(
readerinput
);
hr
=
alloc_input_buffer
(
readerinput
);
if
(
hr
!=
S_OK
)
if
(
hr
!=
S_OK
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment