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
5c7c5faf
Commit
5c7c5faf
authored
Aug 02, 2004
by
Robert Shearman
Committed by
Alexandre Julliard
Aug 02, 2004
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
- Add static to non-exported marshal functions.
- Remove unused marshal functions. - Rename several RPC functions.
parent
0ba37e23
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
36 additions
and
78 deletions
+36
-78
marshal.c
dlls/ole32/marshal.c
+12
-54
rpc.c
dlls/ole32/rpc.c
+24
-24
No files found.
dlls/ole32/marshal.c
View file @
5c7c5faf
...
...
@@ -107,22 +107,6 @@ void MARSHAL_Invalidate_Stub_From_MID(wine_marshal_id *mid) {
}
HRESULT
MARSHAL_Find_Stub_Server
(
wine_marshal_id
*
mid
,
LPUNKNOWN
*
punk
)
{
int
i
;
for
(
i
=
0
;
i
<
nrofstubs
;
i
++
)
{
if
(
!
stubs
[
i
].
valid
)
continue
;
if
(
MARSHAL_Compare_Mids_NoInterface
(
mid
,
&
(
stubs
[
i
].
mid
)))
{
*
punk
=
stubs
[
i
].
pUnkServer
;
IUnknown_AddRef
((
*
punk
));
return
S_OK
;
}
}
return
E_FAIL
;
}
HRESULT
MARSHAL_Find_Stub_Buffer
(
wine_marshal_id
*
mid
,
IRpcStubBuffer
**
stub
)
{
int
i
;
...
...
@@ -138,7 +122,7 @@ MARSHAL_Find_Stub_Buffer(wine_marshal_id *mid,IRpcStubBuffer **stub) {
return
E_FAIL
;
}
HRESULT
static
HRESULT
MARSHAL_Find_Stub
(
wine_marshal_id
*
mid
,
LPUNKNOWN
*
pUnk
)
{
int
i
;
...
...
@@ -154,7 +138,7 @@ MARSHAL_Find_Stub(wine_marshal_id *mid,LPUNKNOWN *pUnk) {
return
E_FAIL
;
}
HRESULT
static
HRESULT
MARSHAL_Register_Stub
(
wine_marshal_id
*
mid
,
LPUNKNOWN
pUnk
,
IRpcStubBuffer
*
stub
)
{
LPUNKNOWN
xPunk
;
if
(
!
MARSHAL_Find_Stub
(
mid
,
&
xPunk
))
{
...
...
@@ -175,19 +159,6 @@ MARSHAL_Register_Stub(wine_marshal_id *mid,LPUNKNOWN pUnk,IRpcStubBuffer *stub)
}
HRESULT
MARSHAL_Find_Proxy
(
wine_marshal_id
*
mid
,
LPUNKNOWN
*
punk
)
{
int
i
;
for
(
i
=
0
;
i
<
nrofproxies
;
i
++
)
if
(
MARSHAL_Compare_Mids
(
mid
,
&
(
proxies
[
i
].
mid
)))
{
*
punk
=
proxies
[
i
].
pUnk
;
IUnknown_AddRef
((
*
punk
));
return
S_OK
;
}
return
E_FAIL
;
}
HRESULT
MARSHAL_Disconnect_Proxies
()
{
int
i
;
...
...
@@ -199,20 +170,7 @@ MARSHAL_Disconnect_Proxies() {
return
S_OK
;
}
HRESULT
MARSHAL_Find_Proxy_Object
(
wine_marshal_id
*
mid
,
LPUNKNOWN
*
punk
)
{
int
i
;
for
(
i
=
0
;
i
<
nrofproxies
;
i
++
)
if
(
MARSHAL_Compare_Mids_NoInterface
(
mid
,
&
(
proxies
[
i
].
mid
)))
{
*
punk
=
proxies
[
i
].
pUnk
;
IUnknown_AddRef
((
*
punk
));
return
S_OK
;
}
return
E_FAIL
;
}
HRESULT
static
HRESULT
MARSHAL_Register_Proxy
(
wine_marshal_id
*
mid
,
LPUNKNOWN
punk
)
{
int
i
;
...
...
@@ -244,7 +202,7 @@ typedef struct _StdMarshalImpl {
DWORD
mshlflags
;
}
StdMarshalImpl
;
HRESULT
WINAPI
static
HRESULT
WINAPI
StdMarshalImpl_QueryInterface
(
LPMARSHAL
iface
,
REFIID
riid
,
LPVOID
*
ppv
)
{
*
ppv
=
NULL
;
if
(
IsEqualIID
(
&
IID_IUnknown
,
riid
)
||
IsEqualIID
(
&
IID_IMarshal
,
riid
))
{
...
...
@@ -256,14 +214,14 @@ StdMarshalImpl_QueryInterface(LPMARSHAL iface,REFIID riid,LPVOID *ppv) {
return
E_NOINTERFACE
;
}
ULONG
WINAPI
static
ULONG
WINAPI
StdMarshalImpl_AddRef
(
LPMARSHAL
iface
)
{
ICOM_THIS
(
StdMarshalImpl
,
iface
);
This
->
ref
++
;
return
This
->
ref
;
}
ULONG
WINAPI
static
ULONG
WINAPI
StdMarshalImpl_Release
(
LPMARSHAL
iface
)
{
ICOM_THIS
(
StdMarshalImpl
,
iface
);
This
->
ref
--
;
...
...
@@ -274,7 +232,7 @@ StdMarshalImpl_Release(LPMARSHAL iface) {
return
0
;
}
HRESULT
WINAPI
static
HRESULT
WINAPI
StdMarshalImpl_GetUnmarshalClass
(
LPMARSHAL
iface
,
REFIID
riid
,
void
*
pv
,
DWORD
dwDestContext
,
void
*
pvDestContext
,
DWORD
mshlflags
,
CLSID
*
pCid
...
...
@@ -283,7 +241,7 @@ StdMarshalImpl_GetUnmarshalClass(
return
S_OK
;
}
HRESULT
WINAPI
static
HRESULT
WINAPI
StdMarshalImpl_GetMarshalSizeMax
(
LPMARSHAL
iface
,
REFIID
riid
,
void
*
pv
,
DWORD
dwDestContext
,
void
*
pvDestContext
,
DWORD
mshlflags
,
DWORD
*
pSize
...
...
@@ -292,7 +250,7 @@ StdMarshalImpl_GetMarshalSizeMax(
return
S_OK
;
}
HRESULT
WINAPI
static
HRESULT
WINAPI
StdMarshalImpl_MarshalInterface
(
LPMARSHAL
iface
,
IStream
*
pStm
,
REFIID
riid
,
void
*
pv
,
DWORD
dwDestContext
,
void
*
pvDestContext
,
DWORD
mshlflags
...
...
@@ -339,7 +297,7 @@ StdMarshalImpl_MarshalInterface(
return
S_OK
;
}
HRESULT
WINAPI
static
HRESULT
WINAPI
StdMarshalImpl_UnmarshalInterface
(
LPMARSHAL
iface
,
IStream
*
pStm
,
REFIID
riid
,
void
**
ppv
)
{
...
...
@@ -392,7 +350,7 @@ StdMarshalImpl_UnmarshalInterface(
return
hres
;
}
HRESULT
WINAPI
static
HRESULT
WINAPI
StdMarshalImpl_ReleaseMarshalData
(
LPMARSHAL
iface
,
IStream
*
pStm
)
{
wine_marshal_id
mid
;
ULONG
res
;
...
...
@@ -427,7 +385,7 @@ StdMarshalImpl_ReleaseMarshalData(LPMARSHAL iface, IStream *pStm) {
return
S_OK
;
}
HRESULT
WINAPI
static
HRESULT
WINAPI
StdMarshalImpl_DisconnectObject
(
LPMARSHAL
iface
,
DWORD
dwReserved
)
{
FIXME
(
"(), stub!
\n
"
);
return
S_OK
;
...
...
dlls/ole32/rpc.c
View file @
5c7c5faf
...
...
@@ -117,7 +117,7 @@ typedef struct _PipeBuf {
}
PipeBuf
;
static
HRESULT
WINAPI
_xread
(
HANDLE
hf
,
LPVOID
ptr
,
DWORD
size
)
{
read_pipe
(
HANDLE
hf
,
LPVOID
ptr
,
DWORD
size
)
{
DWORD
res
;
if
(
!
ReadFile
(
hf
,
ptr
,
size
,
&
res
,
NULL
))
{
FIXME
(
"Failed to read from %p, le is %lx
\n
"
,
hf
,
GetLastError
());
...
...
@@ -157,7 +157,7 @@ drs(LPCSTR where) {
}
static
HRESULT
WINAPI
_xwrit
e
(
HANDLE
hf
,
LPVOID
ptr
,
DWORD
size
)
{
write_pip
e
(
HANDLE
hf
,
LPVOID
ptr
,
DWORD
size
)
{
DWORD
res
;
if
(
!
WriteFile
(
hf
,
ptr
,
size
,
&
res
,
NULL
))
{
FIXME
(
"Failed to write to %p, le is %lx
\n
"
,
hf
,
GetLastError
());
...
...
@@ -307,8 +307,8 @@ PipeBuf_Release(LPRPCCHANNELBUFFER iface) {
pipe
=
PIPE_FindByMID
(
&
This
->
mid
);
_xwrit
e
(
pipe
,
&
reqtype
,
sizeof
(
reqtype
));
_xwrit
e
(
pipe
,
&
header
,
sizeof
(
wine_rpc_disconnect_header
));
write_pip
e
(
pipe
,
&
reqtype
,
sizeof
(
reqtype
));
write_pip
e
(
pipe
,
&
header
,
sizeof
(
wine_rpc_disconnect_header
));
TRACE
(
"written disconnect packet
\n
"
);
...
...
@@ -330,7 +330,7 @@ PipeBuf_GetBuffer(
}
static
HRESULT
_invoke_onereq
(
wine_rpc_request
*
req
)
{
COM_InvokeAndRpcSend
(
wine_rpc_request
*
req
)
{
IRpcStubBuffer
*
stub
;
RPCOLEMESSAGE
msg
;
HRESULT
hres
;
...
...
@@ -351,18 +351,18 @@ _invoke_onereq(wine_rpc_request *req) {
req
->
Buffer
=
msg
.
Buffer
;
req
->
resph
.
cbBuffer
=
msg
.
cbBuffer
;
reqtype
=
REQTYPE_RESPONSE
;
hres
=
_xwrit
e
(
req
->
hPipe
,
&
reqtype
,
sizeof
(
reqtype
));
hres
=
write_pip
e
(
req
->
hPipe
,
&
reqtype
,
sizeof
(
reqtype
));
if
(
hres
)
return
hres
;
hres
=
_xwrit
e
(
req
->
hPipe
,
&
(
req
->
resph
),
sizeof
(
req
->
resph
));
hres
=
write_pip
e
(
req
->
hPipe
,
&
(
req
->
resph
),
sizeof
(
req
->
resph
));
if
(
hres
)
return
hres
;
hres
=
_xwrit
e
(
req
->
hPipe
,
req
->
Buffer
,
req
->
resph
.
cbBuffer
);
hres
=
write_pip
e
(
req
->
hPipe
,
req
->
Buffer
,
req
->
resph
.
cbBuffer
);
if
(
hres
)
return
hres
;
req
->
state
=
REQSTATE_DONE
;
drs
(
"invoke"
);
return
S_OK
;
}
static
HRESULT
_read_on
e
(
wine_pipe
*
xpipe
);
static
HRESULT
COM_RpcReceiv
e
(
wine_pipe
*
xpipe
);
static
HRESULT
RPC_QueueRequestAndWait
(
wine_rpc_request
*
req
)
{
...
...
@@ -383,23 +383,23 @@ RPC_QueueRequestAndWait(wine_rpc_request *req) {
req
->
hPipe
=
xpipe
->
hPipe
;
req
->
state
=
REQSTATE_REQ_WAITING_FOR_REPLY
;
reqtype
=
REQTYPE_REQUEST
;
hres
=
_xwrit
e
(
req
->
hPipe
,
&
reqtype
,
sizeof
(
reqtype
));
hres
=
write_pip
e
(
req
->
hPipe
,
&
reqtype
,
sizeof
(
reqtype
));
if
(
hres
)
return
hres
;
hres
=
_xwrit
e
(
req
->
hPipe
,
&
(
req
->
reqh
),
sizeof
(
req
->
reqh
));
hres
=
write_pip
e
(
req
->
hPipe
,
&
(
req
->
reqh
),
sizeof
(
req
->
reqh
));
if
(
hres
)
return
hres
;
hres
=
_xwrit
e
(
req
->
hPipe
,
req
->
Buffer
,
req
->
reqh
.
cbBuffer
);
hres
=
write_pip
e
(
req
->
hPipe
,
req
->
Buffer
,
req
->
reqh
.
cbBuffer
);
if
(
hres
)
return
hres
;
/* This loop is about allowing re-entrancy. While waiting for the
* response to one RPC we may receive a request starting another. */
while
(
!
hres
)
{
hres
=
_read_on
e
(
xpipe
);
hres
=
COM_RpcReceiv
e
(
xpipe
);
if
(
hres
)
break
;
for
(
i
=
0
;
i
<
nrofreqs
;
i
++
)
{
xreq
=
reqs
[
i
];
if
((
xreq
->
state
==
REQSTATE_REQ_GOT
)
&&
(
xreq
->
hPipe
==
req
->
hPipe
))
{
hres
=
_invoke_onereq
(
xreq
);
hres
=
COM_InvokeAndRpcSend
(
xreq
);
if
(
hres
)
break
;
}
}
...
...
@@ -637,7 +637,7 @@ PIPE_StartRequestThread(HANDLE xhPipe) {
wine_marshal_id
remoteid
;
HRESULT
hres
;
hres
=
_xread
(
xhPipe
,
&
remoteid
,
sizeof
(
remoteid
));
hres
=
read_pipe
(
xhPipe
,
&
remoteid
,
sizeof
(
remoteid
));
if
(
hres
)
{
ERR
(
"Failed to read remote mid!
\n
"
);
return
;
...
...
@@ -646,13 +646,13 @@ PIPE_StartRequestThread(HANDLE xhPipe) {
}
static
HRESULT
_read_on
e
(
wine_pipe
*
xpipe
)
{
COM_RpcReceiv
e
(
wine_pipe
*
xpipe
)
{
DWORD
reqtype
;
HRESULT
hres
=
S_OK
;
HANDLE
xhPipe
=
xpipe
->
hPipe
;
/*FIXME("%lx %d reading reqtype\n",GetCurrentProcessId(),xhPipe);*/
hres
=
_xread
(
xhPipe
,
&
reqtype
,
sizeof
(
reqtype
));
hres
=
read_pipe
(
xhPipe
,
&
reqtype
,
sizeof
(
reqtype
));
if
(
hres
)
goto
end
;
EnterCriticalSection
(
&
(
xpipe
->
crit
));
/*FIXME("%lx got reqtype %ld\n",GetCurrentProcessId(),reqtype);*/
...
...
@@ -662,7 +662,7 @@ _read_one(wine_pipe *xpipe) {
IRpcStubBuffer
*
stub
;
ULONG
ret
;
hres
=
_xread
(
xhPipe
,
&
header
,
sizeof
(
header
));
hres
=
read_pipe
(
xhPipe
,
&
header
,
sizeof
(
header
));
if
(
hres
)
{
ERR
(
"could not read disconnect header
\n
"
);
goto
end
;
...
...
@@ -689,11 +689,11 @@ _read_one(wine_pipe *xpipe) {
wine_rpc_request
*
xreq
;
RPC_GetRequest
(
&
xreq
);
xreq
->
hPipe
=
xhPipe
;
hres
=
_xread
(
xhPipe
,
&
(
xreq
->
reqh
),
sizeof
(
xreq
->
reqh
));
hres
=
read_pipe
(
xhPipe
,
&
(
xreq
->
reqh
),
sizeof
(
xreq
->
reqh
));
if
(
hres
)
goto
end
;
xreq
->
resph
.
reqid
=
xreq
->
reqh
.
reqid
;
xreq
->
Buffer
=
HeapAlloc
(
GetProcessHeap
(),
0
,
xreq
->
reqh
.
cbBuffer
);
hres
=
_xread
(
xhPipe
,
xreq
->
Buffer
,
xreq
->
reqh
.
cbBuffer
);
hres
=
read_pipe
(
xhPipe
,
xreq
->
Buffer
,
xreq
->
reqh
.
cbBuffer
);
if
(
hres
)
goto
end
;
xreq
->
state
=
REQSTATE_REQ_GOT
;
goto
end
;
...
...
@@ -701,7 +701,7 @@ _read_one(wine_pipe *xpipe) {
wine_rpc_response_header
resph
;
int
i
;
hres
=
_xread
(
xhPipe
,
&
resph
,
sizeof
(
resph
));
hres
=
read_pipe
(
xhPipe
,
&
resph
,
sizeof
(
resph
));
if
(
hres
)
goto
end
;
for
(
i
=
nrofreqs
;
i
--
;)
{
wine_rpc_request
*
xreq
=
reqs
[
i
];
...
...
@@ -715,7 +715,7 @@ _read_one(wine_pipe *xpipe) {
else
xreq
->
Buffer
=
HeapAlloc
(
GetProcessHeap
(),
HEAP_ZERO_MEMORY
,
xreq
->
resph
.
cbBuffer
);
hres
=
_xread
(
xhPipe
,
xreq
->
Buffer
,
xreq
->
resph
.
cbBuffer
);
hres
=
read_pipe
(
xhPipe
,
xreq
->
Buffer
,
xreq
->
resph
.
cbBuffer
);
if
(
hres
)
goto
end
;
xreq
->
state
=
REQSTATE_RESP_GOT
;
/*PulseEvent(hRpcChanged);*/
...
...
@@ -742,13 +742,13 @@ _StubReaderThread(LPVOID param) {
TRACE
(
"STUB reader thread %lx
\n
"
,
GetCurrentProcessId
());
while
(
!
hres
)
{
int
i
;
hres
=
_read_on
e
(
xpipe
);
hres
=
COM_RpcReceiv
e
(
xpipe
);
if
(
hres
)
break
;
for
(
i
=
nrofreqs
;
i
--
;)
{
wine_rpc_request
*
xreq
=
reqs
[
i
];
if
((
xreq
->
state
==
REQSTATE_REQ_GOT
)
&&
(
xreq
->
hPipe
==
xhPipe
))
{
hres
=
_invoke_onereq
(
xreq
);
hres
=
COM_InvokeAndRpcSend
(
xreq
);
if
(
!
hres
)
break
;
}
}
...
...
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