Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
9208eef5
Commit
9208eef5
authored
Dec 19, 2006
by
Rob Shearman
Committed by
Alexandre Julliard
Dec 20, 2006
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ole32: Call the message filter for incoming calls.
parent
c0a25d35
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
40 additions
and
3 deletions
+40
-3
rpc.c
dlls/ole32/rpc.c
+39
-2
marshal.c
dlls/ole32/tests/marshal.c
+1
-1
No files found.
dlls/ole32/rpc.c
View file @
9208eef5
...
...
@@ -931,13 +931,15 @@ static HRESULT unmarshal_ORPCTHIS(RPC_MESSAGE *msg, ORPCTHIS *orpcthis,
void
RPC_ExecuteCall
(
struct
dispatch_params
*
params
)
{
struct
message_state
*
message_state
;
struct
message_state
*
message_state
=
NULL
;
RPC_MESSAGE
*
msg
=
(
RPC_MESSAGE
*
)
params
->
msg
;
char
*
original_buffer
=
msg
->
Buffer
;
ORPCTHIS
orpcthis
;
ORPC_EXTENT_ARRAY
orpc_ext_array
;
WIRE_ORPC_EXTENT
*
first_wire_orpc_extent
;
/* handle ORPCTHIS and server extensions */
params
->
hr
=
unmarshal_ORPCTHIS
(
msg
,
&
orpcthis
,
&
orpc_ext_array
,
&
first_wire_orpc_extent
);
if
(
params
->
hr
!=
S_OK
)
goto
exit
;
...
...
@@ -966,6 +968,41 @@ void RPC_ExecuteCall(struct dispatch_params *params)
msg
->
Handle
=
message_state
;
msg
->
BufferLength
-=
message_state
->
prefix_data_len
;
/* call message filter */
if
(
COM_CurrentApt
()
->
filter
)
{
DWORD
handlecall
;
INTERFACEINFO
interface_info
;
interface_info
.
pUnk
=
NULL
;
/* FIXME */
interface_info
.
iid
=
IID_NULL
;
/* FIXME */
interface_info
.
wMethod
=
msg
->
ProcNum
;
handlecall
=
IMessageFilter_HandleInComingCall
(
COM_CurrentApt
()
->
filter
,
CALLTYPE_TOPLEVEL
/* FIXME */
,
(
HTASK
)
GetCurrentProcessId
(),
0
/* FIXME */
,
&
interface_info
);
TRACE
(
"IMessageFilter_HandleInComingCall returned %d
\n
"
,
handlecall
);
switch
(
handlecall
)
{
case
SERVERCALL_REJECTED
:
params
->
hr
=
RPC_E_CALL_REJECTED
;
goto
exit
;
case
SERVERCALL_RETRYLATER
:
#if 0 /* FIXME: handle retries on the client side before enabling this code */
params->hr = RPC_E_RETRY;
goto exit;
#else
FIXME
(
"retry call later not implemented
\n
"
);
break
;
#endif
case
SERVERCALL_ISHANDLED
:
default:
break
;
}
}
/* invoke the method */
params
->
hr
=
IRpcStubBuffer_Invoke
(
params
->
stub
,
params
->
msg
,
params
->
chan
);
...
...
@@ -974,9 +1011,9 @@ void RPC_ExecuteCall(struct dispatch_params *params)
msg
->
Handle
=
message_state
->
binding_handle
;
msg
->
Buffer
=
(
char
*
)
msg
->
Buffer
-
message_state
->
prefix_data_len
;
msg
->
BufferLength
+=
message_state
->
prefix_data_len
;
HeapFree
(
GetProcessHeap
(),
0
,
message_state
);
exit:
HeapFree
(
GetProcessHeap
(),
0
,
message_state
);
IRpcStubBuffer_Release
(
params
->
stub
);
IRpcChannelBuffer_Release
(
params
->
chan
);
if
(
params
->
handle
)
SetEvent
(
params
->
handle
);
...
...
dlls/ole32/tests/marshal.c
View file @
9208eef5
...
...
@@ -1290,7 +1290,7 @@ static void test_message_filter(void)
ok_more_than_one_lock
();
hr
=
IClassFactory_CreateInstance
(
cf
,
NULL
,
&
IID_IUnknown
,
(
LPVOID
*
)
&
proxy
);
todo_wine
{
ok
(
hr
==
RPC_E_CALL_REJECTED
,
"Call should have returned RPC_E_CALL_REJECTED, but return 0x%08x instead
\n
"
,
hr
);
}
ok
(
hr
==
RPC_E_CALL_REJECTED
,
"Call should have returned RPC_E_CALL_REJECTED, but return 0x%08x instead
\n
"
,
hr
);
if
(
proxy
)
IUnknown_Release
(
proxy
);
proxy
=
NULL
;
...
...
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