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
ab522ac5
Commit
ab522ac5
authored
Sep 06, 2017
by
Hans Leidekker
Committed by
Alexandre Julliard
Sep 06, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
webservices: Parse the MessageID header.
Signed-off-by:
Hans Leidekker
<
hans@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
f9ae3097
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
3 deletions
+28
-3
msg.c
dlls/webservices/msg.c
+28
-3
No files found.
dlls/webservices/msg.c
View file @
ab522ac5
...
@@ -64,6 +64,7 @@ struct msg
...
@@ -64,6 +64,7 @@ struct msg
WS_MESSAGE_INITIALIZATION
init
;
WS_MESSAGE_INITIALIZATION
init
;
WS_MESSAGE_STATE
state
;
WS_MESSAGE_STATE
state
;
GUID
id
;
GUID
id
;
GUID
id_req
;
WS_ENVELOPE_VERSION
version_env
;
WS_ENVELOPE_VERSION
version_env
;
WS_ADDRESSING_VERSION
version_addr
;
WS_ADDRESSING_VERSION
version_addr
;
BOOL
is_addressed
;
BOOL
is_addressed
;
...
@@ -126,6 +127,7 @@ static void reset_msg( struct msg *msg )
...
@@ -126,6 +127,7 @@ static void reset_msg( struct msg *msg )
msg
->
state
=
WS_MESSAGE_STATE_EMPTY
;
msg
->
state
=
WS_MESSAGE_STATE_EMPTY
;
msg
->
init
=
0
;
msg
->
init
=
0
;
UuidCreate
(
&
msg
->
id
);
UuidCreate
(
&
msg
->
id
);
memset
(
&
msg
->
id_req
,
0
,
sizeof
(
msg
->
id_req
)
);
msg
->
is_addressed
=
FALSE
;
msg
->
is_addressed
=
FALSE
;
heap_free
(
msg
->
addr
.
chars
);
heap_free
(
msg
->
addr
.
chars
);
msg
->
addr
.
chars
=
NULL
;
msg
->
addr
.
chars
=
NULL
;
...
@@ -779,10 +781,31 @@ static BOOL match_current_element( WS_XML_READER *reader, const WS_XML_STRING *l
...
@@ -779,10 +781,31 @@ static BOOL match_current_element( WS_XML_READER *reader, const WS_XML_STRING *l
return
WsXmlStringEquals
(
elem
->
localName
,
localname
,
NULL
)
==
S_OK
;
return
WsXmlStringEquals
(
elem
->
localName
,
localname
,
NULL
)
==
S_OK
;
}
}
static
HRESULT
read_envelope_start
(
WS_XML_READER
*
reader
)
static
HRESULT
read_message_id
(
WS_XML_READER
*
reader
,
GUID
*
ret
)
{
const
WS_XML_NODE
*
node
;
const
WS_XML_TEXT_NODE
*
text
;
const
WS_XML_UNIQUE_ID_TEXT
*
id
;
HRESULT
hr
;
if
((
hr
=
WsReadNode
(
reader
,
NULL
))
!=
S_OK
)
return
hr
;
if
((
hr
=
WsGetReaderNode
(
reader
,
&
node
,
NULL
))
!=
S_OK
)
return
hr
;
if
(
node
->
nodeType
!=
WS_XML_NODE_TYPE_TEXT
)
return
WS_E_INVALID_FORMAT
;
text
=
(
const
WS_XML_TEXT_NODE
*
)
node
;
if
(
text
->
text
->
textType
!=
WS_XML_TEXT_TYPE_UNIQUE_ID
)
{
FIXME
(
"unhandled text type %u
\n
"
,
text
->
text
->
textType
);
return
E_NOTIMPL
;
}
id
=
(
const
WS_XML_UNIQUE_ID_TEXT
*
)
text
->
text
;
*
ret
=
id
->
value
;
return
S_OK
;
}
static
HRESULT
read_envelope_start
(
struct
msg
*
msg
,
WS_XML_READER
*
reader
)
{
{
static
const
WS_XML_STRING
envelope
=
{
8
,
(
BYTE
*
)
"Envelope"
},
body
=
{
4
,
(
BYTE
*
)
"Body"
};
static
const
WS_XML_STRING
envelope
=
{
8
,
(
BYTE
*
)
"Envelope"
},
body
=
{
4
,
(
BYTE
*
)
"Body"
};
static
const
WS_XML_STRING
header
=
{
6
,
(
BYTE
*
)
"Header"
};
static
const
WS_XML_STRING
header
=
{
6
,
(
BYTE
*
)
"Header"
}
,
msgid
=
{
9
,
(
BYTE
*
)
"MessageID"
}
;
HRESULT
hr
;
HRESULT
hr
;
if
((
hr
=
WsReadNode
(
reader
,
NULL
))
!=
S_OK
)
return
hr
;
if
((
hr
=
WsReadNode
(
reader
,
NULL
))
!=
S_OK
)
return
hr
;
...
@@ -793,6 +816,8 @@ static HRESULT read_envelope_start( WS_XML_READER *reader )
...
@@ -793,6 +816,8 @@ static HRESULT read_envelope_start( WS_XML_READER *reader )
for
(;;)
for
(;;)
{
{
if
((
hr
=
WsReadNode
(
reader
,
NULL
))
!=
S_OK
)
return
hr
;
if
((
hr
=
WsReadNode
(
reader
,
NULL
))
!=
S_OK
)
return
hr
;
if
(
match_current_element
(
reader
,
&
msgid
)
&&
(
hr
=
read_message_id
(
reader
,
&
msg
->
id_req
))
!=
S_OK
)
return
hr
;
if
(
match_current_element
(
reader
,
&
body
))
break
;
if
(
match_current_element
(
reader
,
&
body
))
break
;
}
}
}
}
...
@@ -833,7 +858,7 @@ HRESULT WINAPI WsReadEnvelopeStart( WS_MESSAGE *handle, WS_XML_READER *reader, W
...
@@ -833,7 +858,7 @@ HRESULT WINAPI WsReadEnvelopeStart( WS_MESSAGE *handle, WS_XML_READER *reader, W
return
WS_E_INVALID_OPERATION
;
return
WS_E_INVALID_OPERATION
;
}
}
if
((
hr
=
read_envelope_start
(
reader
))
==
S_OK
&&
if
((
hr
=
read_envelope_start
(
msg
,
reader
))
==
S_OK
&&
(
hr
=
create_header_buffer
(
reader
,
msg
->
heap
,
&
msg
->
buf
))
==
S_OK
)
(
hr
=
create_header_buffer
(
reader
,
msg
->
heap
,
&
msg
->
buf
))
==
S_OK
)
{
{
msg
->
reader_body
=
reader
;
msg
->
reader_body
=
reader
;
...
...
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