Minor API files update.
[wine/testsucceed.git] / include / dplobby.h
blob85615b7efaaf604e4f45b42e769b1efe2804145f
1 #ifndef __WINE_DPLOBBY_H
2 #define __WINE_DPLOBBY_H
4 /* FIXME: GCC doesn't yet support annon structures so some of the structures
5 * defined here don't match the sdk exactly. I've tried to come up with
6 * suitably terse names, but this file won't cut it for inclusion into a
7 * Winelib app.
8 */
10 #include "dplay.h"
12 #ifdef __cplusplus
13 extern "C" {
14 #endif /* defined(__cplusplus) */
16 #include "pshpack1.h"
18 /*****************************************************************************
19 * Predeclare the interfaces
21 DEFINE_GUID(CLSID_DirectPlayLobby, 0x2fe8f810, 0xb2a5, 0x11d0, 0xa7, 0x87, 0x0, 0x0, 0xf8, 0x3, 0xab, 0xfc);
23 DEFINE_GUID(IID_IDirectPlayLobby, 0xaf465c71, 0x9588, 0x11cf, 0xa0, 0x20, 0x0, 0xaa, 0x0, 0x61, 0x57, 0xac);
24 typedef struct IDirectPlayLobby IDirectPlayLobby,*LPDIRECTPLAYLOBBY;
26 DEFINE_GUID(IID_IDirectPlayLobbyA, 0x26c66a70, 0xb367, 0x11cf, 0xa0, 0x24, 0x0, 0xaa, 0x0, 0x61, 0x57, 0xac);
27 typedef struct IDirectPlayLobby IDirectPlayLobbyA,*LPDIRECTPLAYLOBBYA;
29 DEFINE_GUID(IID_IDirectPlayLobby2, 0x194c220, 0xa303, 0x11d0, 0x9c, 0x4f, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e);
30 typedef struct IDirectPlayLobby2 IDirectPlayLobby2, *LPDIRECTPLAYLOBBY2;
32 DEFINE_GUID(IID_IDirectPlayLobby2A, 0x1bb4af80, 0xa303, 0x11d0, 0x9c, 0x4f, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e);
33 typedef struct IDirectPlayLobby2 IDirectPlayLobby2A, *LPDIRECTPLAYLOBBY2A;
35 DEFINE_GUID(IID_IDirectPlayLobby3, 0x2db72490, 0x652c, 0x11d1, 0xa7, 0xa8, 0x0, 0x0, 0xf8, 0x3, 0xab, 0xfc);
36 typedef struct IDirectPlayLobby3 IDirectPlayLobby3, *LPDIRECTPLAYLOBBY3;
38 DEFINE_GUID(IID_IDirectPlayLobby3A, 0x2db72491, 0x652c, 0x11d1, 0xa7, 0xa8, 0x0, 0x0, 0xf8, 0x3, 0xab, 0xfc);
39 typedef struct IDirectPlayLobby3 IDirectPlayLobby3A, *LPDIRECTPLAYLOBBY3A;
42 /*****************************************************************************
43 * DirectPlayLobby Property GUIDs used in lobby messages
46 /* DPLPROPERTY_MessagesSupported {762CCDA1-D916-11d0-BA39-00C04FD7ED67}.
47 * Purpose: Request if the lobby supports standard (?).
48 * Response: Answer is a BOOL. TRUE if supports the standard (?) and FALSE otherwise. Of course, it might not respond at all.
50 DEFINE_GUID(DPLPROPERTY_MessagesSupported, 0x762ccda1, 0xd916, 0x11d0, 0xba, 0x39, 0x0, 0xc0, 0x4f, 0xd7, 0xed, 0x67);
52 /* DPLPROPERTY_LobbyGuid {F56920A0-D218-11d0-BA39-00C04FD7ED67}.
53 * Purpose: Request the GUID that identifies the lobby version that the application is communicating with.
54 * Response: The GUID which identifies the lobby version
56 DEFINE_GUID(DPLPROPERTY_LobbyGuid, 0xf56920a0, 0xd218, 0x11d0, 0xba, 0x39, 0x0, 0xc0, 0x4f, 0xd7, 0xed, 0x67);
58 /* DPLPROPERTY_PlayerGuid {B4319322-D20D-11d0-BA39-00C04FD7ED67}
59 * Purpose: Request the GUID that identifies the player for this particular machine.
60 * Response: DPLDATA_PLAYERDATA structure.
62 DEFINE_GUID(DPLPROPERTY_PlayerGuid, 0xb4319322, 0xd20d, 0x11d0, 0xba, 0x39, 0x0, 0xc0, 0x4f, 0xd7, 0xed, 0x67);
64 /* DPLPROPERTY_PlayerScore {48784000-D219-11d0-BA39-00C04FD7ED67}
65 * Purpose: Used to send a score of a player to the lobby. The format is an array of long integers.
66 * Response: I don't think there is one.
68 DEFINE_GUID(DPLPROPERTY_PlayerScore, 0x48784000, 0xd219, 0x11d0, 0xba, 0x39, 0x0, 0xc0, 0x4f, 0xd7, 0xed, 0x67);
72 /*****************************************************************************
73 * LOBBY structures associated with GUID messages
76 typedef struct tagDPLDATA_PLAYERGUID
78 GUID guidPlayer;
79 DWORD dwPlayerFlags;
80 } DPLDATA_PLAYERGUID, *LPDPLDATA_PLAYERGUID;
82 typedef struct tagDPLDATA_PLAYERSCORE
84 DWORD dwScoreCount;
85 LONG Score[1];
86 } DPLDATA_PLAYERSCORE, *LPDPLDATA_PLAYERSCORE;
89 /*****************************************************************************
90 * LOBBY messages and message data structures.
92 * System messages can be identified by dwMessageFlags having a value of DPLMSG_SYSTEM
93 * after a call to ReceiveLobbyMessage.
95 * Standard messages can be indentified by dwMessageFlags having a value of DPLMSG_STANDARD
96 * after a call to ReceiveLobbyMessage.
99 /* DPLobby1 definition required for backwards compatibility */
100 #define DPLMSG_SYSTEM 0x00000001
101 #define DPLMSG_STANDARD 0x00000002
102 #define DPLAD_SYSTEM DPLMSG_SYSTEM
105 /* System messages - dwType field for messages */
106 #define DPLSYS_CONNECTIONSETTINGSREAD 0x00000001
107 #define DPLSYS_DPLAYCONNECTFAILED 0x00000002
108 #define DPLSYS_DPLAYCONNECTSUCCEEDED 0x00000003
109 #define DPLSYS_APPTERMINATED 0x00000004
110 #define DPLSYS_SETPROPERTY 0x00000005
111 #define DPLSYS_SETPROPERTYRESPONSE 0x00000006
112 #define DPLSYS_GETPROPERTY 0x00000007
113 #define DPLSYS_GETPROPERTYRESPONSE 0x00000008
114 #define DPLSYS_NEWSESSIONHOST 0x00000009
115 #define DPLSYS_NEWCONNECTIONSETTINGS 0x0000000A
119 /* Used to indentify the message type */
120 typedef struct tagDPLMSG_GENERIC
122 DWORD dwType; /* Message type */
123 } DPLMSG_GENERIC, *LPDPLMSG_GENERIC;
125 /* Generic format for system messages - see above */
126 typedef struct tagDPLMSG_SYSTEMMESSAGE
128 DWORD dwType; /* Message type */
129 GUID guidInstance; /* Instance GUID of the dplay session the message corresponds to */
130 } DPLMSG_SYSTEMMESSAGE, *LPDPLMSG_SYSTEMMESSAGE;
132 /* Generic message to set a property - see property GUIDs above */
133 typedef struct tagDPLMSG_SETPROPERTY
135 DWORD dwType; /* Message type */
136 DWORD dwRequestID; /* Request ID (DPL_NOCONFIRMATION if no confirmation desired) */
137 GUID guidPlayer; /* Player GUID */
138 GUID guidPropertyTag; /* Property GUID */
139 DWORD dwDataSize; /* Size of data */
140 DWORD dwPropertyData[1]; /* Buffer containing data */
141 } DPLMSG_SETPROPERTY, *LPDPLMSG_SETPROPERTY;
143 #define DPL_NOCONFIRMATION 0L
145 /* Reply to DPLMSG_SETPROPERTY */
146 typedef struct tagDPLMSG_SETPROPERTYRESPONSE
148 DWORD dwType; /* Message type */
149 DWORD dwRequestID; /* Request ID */
150 GUID guidPlayer; /* Player GUID */
151 GUID guidPropertyTag; /* Property GUID */
152 HRESULT hr; /* Return Code */
153 } DPLMSG_SETPROPERTYRESPONSE, *LPDPLMSG_SETPROPERTYRESPONSE;
155 /* Request to get the present value of a property */
156 typedef struct tagDPLMSG_GETPROPERTY
158 DWORD dwType; /* Message type */
159 DWORD dwRequestID; /* Request ID */
160 GUID guidPlayer; /* Player GUID */
161 GUID guidPropertyTag; /* Property GUID */
162 } DPLMSG_GETPROPERTY, *LPDPLMSG_GETPROPERTY;
164 /* Response to a request to get the present value of a property */
165 typedef struct tagDPLMSG_GETPROPERTYRESPONSE
167 DWORD dwType; /* Message type */
168 DWORD dwRequestID; /* Request ID */
169 GUID guidPlayer; /* Player GUID */
170 GUID guidPropertyTag; /* Property GUID */
171 HRESULT hr; /* Return Code */
172 DWORD dwDataSize; /* Size of data */
173 DWORD dwPropertyData[1]; /* Buffer containing data */
174 } DPLMSG_GETPROPERTYRESPONSE, *LPDPLMSG_GETPROPERTYRESPONSE;
176 /* Standard message in response to a session host migration to a new client */
177 typedef struct tagDPLMSG_NEWSESSIONHOST
179 DWORD dwType; /* Message type */
180 GUID guidInstance; /* GUID Instance of the session */
181 } DPLMSG_NEWSESSIONHOST, *LPDPLMSG_NEWSESSIONHOST;
183 /*****************************************************************************
184 * DirectPlay Address ID's
185 * A DirectPlay address is composed of multiple data chunks, each assocated with
186 * a GUID to give significance to the type of data. All chunks have an associated
187 * size so that unknown chunks can be ignored for backwards compatibility!
188 * EnumAddresses function is used to parse the address data chunks.
191 /* DPAID_TotalSize {1318F560-912C-11d0-9DAA-00A0C90A43CB}
192 * Chunk purpose: Chunk is a DWORD containing the size of the entire DPADDRESS struct
194 DEFINE_GUID(DPAID_TotalSize, 0x1318f560, 0x912c, 0x11d0, 0x9d, 0xaa, 0x0, 0xa0, 0xc9, 0xa, 0x43, 0xcb);
196 /* DPAID_ServiceProvider {07D916C0-E0AF-11cf-9C4E-00A0C905425E}
197 * Chunk purpose: Chunk is a GUID indicated what service provider created the chunk.
199 DEFINE_GUID(DPAID_ServiceProvider, 0x7d916c0, 0xe0af, 0x11cf, 0x9c, 0x4e, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e);
201 /* DPAID_LobbyProvider {59B95640-9667-11d0-A77D-0000F803ABFC}
202 * Chunk purpose: Chunk is a GUID indicating what lobby provider created the chunk.
204 DEFINE_GUID(DPAID_LobbyProvider, 0x59b95640, 0x9667, 0x11d0, 0xa7, 0x7d, 0x0, 0x0, 0xf8, 0x3, 0xab, 0xfc);
206 /* DPAID_Phone {78EC89A0-E0AF-11cf-9C4E-00A0C905425E} -- ANSI
207 * DPAID_PhoneW {BA5A7A70-9DBF-11d0-9CC1-00A0C905425E} -- UNICODE
208 * Chunk purpose: Chunk is a phone number in ANSI or UNICODE format
210 DEFINE_GUID(DPAID_Phone, 0x78ec89a0, 0xe0af, 0x11cf, 0x9c, 0x4e, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e);
211 DEFINE_GUID(DPAID_PhoneW, 0xba5a7a70, 0x9dbf, 0x11d0, 0x9c, 0xc1, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e);
213 /* DPAID_Modem {F6DCC200-A2FE-11d0-9C4F-00A0C905425E} -- ANSI
214 * DPAID_ModemW {01FD92E0-A2FF-11d0-9C4F-00A0C905425E} -- UNICODE
215 * Chunk purpose: Chunk is a modem name registered with TAPI
217 DEFINE_GUID(DPAID_Modem, 0xf6dcc200, 0xa2fe, 0x11d0, 0x9c, 0x4f, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e);
218 DEFINE_GUID(DPAID_ModemW, 0x1fd92e0, 0xa2ff, 0x11d0, 0x9c, 0x4f, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e);
220 /* DPAID_INet {C4A54DA0-E0AF-11cf-9C4E-00A0C905425E} -- ANSI
221 * DPAID_INetW {E63232A0-9DBF-11d0-9CC1-00A0C905425E} -- UNICODE
222 * Chunk purpose: Chunk is a string containing a TCP/IP host name or IP address
224 DEFINE_GUID(DPAID_INet, 0xc4a54da0, 0xe0af, 0x11cf, 0x9c, 0x4e, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e);
225 DEFINE_GUID(DPAID_INetW, 0xe63232a0, 0x9dbf, 0x11d0, 0x9c, 0xc1, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e);
227 /* DPAID_INetPort {E4524541-8EA5-11d1-8A96-006097B01411}
228 * Chunk purpose: Chunk is a port number used for creating TCP and UDP sockets. (WORD)
230 DEFINE_GUID(DPAID_INetPort, 0xe4524541, 0x8ea5, 0x11d1, 0x8a, 0x96, 0x0, 0x60, 0x97, 0xb0, 0x14, 0x11);
232 /* DPAID_ComPort {F2F0CE00-E0AF-11cf-9C4E-00A0C905425E}
233 * Chunk purpose: Chunk contains the description of a serial port.
235 DEFINE_GUID(DPAID_ComPort, 0xf2f0ce00, 0xe0af, 0x11cf, 0x9c, 0x4e, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e);
238 /* Header block for address data elements */
239 typedef struct tagDPADDRESS
241 GUID guidDataType;
242 DWORD dwDataSize;
243 } DPADDRESS, *LPDPADDRESS;
246 /* Used for specification of a communication port. Baud rate, stop bits and
247 * parity bits can be found in winbase.h. These are flow control constants only.
249 #define DPCPA_NOFLOW 0 /* no flow control */
250 #define DPCPA_XONXOFFFLOW 1 /* software flow control */
251 #define DPCPA_RTSFLOW 2 /* hardware flow control with RTS */
252 #define DPCPA_DTRFLOW 3 /* hardware flow control with DTR */
253 #define DPCPA_RTSDTRFLOW 4 /* hardware flow control with RTS and DTR */
255 typedef struct tagDPCOMPORTADDRESS
257 DWORD dwComPort; /* COM port to use (1-4) */
258 DWORD dwBaudRate; /* baud rate (100-256k) */
259 DWORD dwStopBits; /* no. stop bits (1-2) */
260 DWORD dwParity; /* parity (none, odd, even, mark) */
261 DWORD dwFlowControl; /* flow control (none, xon/xoff, rts, dtr) */
262 } DPCOMPORTADDRESS, *LPDPCOMPORTADDRESS;
266 /****************************************************************************
267 * Miscellaneous
270 typedef struct tagDPLAPPINFO
272 DWORD dwSize;
273 GUID guidApplication;
275 union
277 LPSTR lpszAppNameA;
278 LPWSTR lpszAppName;
279 } appName;
281 } DPLAPPINFO, *LPDPLAPPINFO;
282 typedef const DPLAPPINFO *LPCDPLAPPINFO;
284 typedef struct DPCOMPOUNDADDRESSELEMENT
286 GUID guidDataType;
287 DWORD dwDataSize;
288 LPVOID lpData;
289 } DPCOMPOUNDADDRESSELEMENT, *LPDPCOMPOUNDADDRESSELEMENT;
290 typedef const DPCOMPOUNDADDRESSELEMENT *LPCDPCOMPOUNDADDRESSELEMENT;
292 typedef struct tagDPAPPLICATIONDESC
294 DWORD dwSize;
295 DWORD dwFlags;
297 union
299 LPSTR lpszApplicationNameA;
300 LPWSTR lpszApplicationName;
301 } appName;
303 GUID guidApplication;
305 union
307 LPSTR lpszFilenameA;
308 LPWSTR lpszFilename;
309 } fileName;
311 union
313 LPSTR lpszCommandLineA;
314 LPWSTR lpszCommandLine;
315 } cmdLine;
317 union
319 LPSTR lpszPathA;
320 LPWSTR lpszPath;
321 } path;
323 union
325 LPSTR lpszCurrentDirectoryA;
326 LPWSTR lpszCurrentDirectory;
327 } curDir;
329 LPSTR lpszDescriptionA;
330 LPWSTR lpszDescriptionW;
332 } DPAPPLICATIONDESC, *LPDPAPPLICATIONDESC;
336 extern HRESULT WINAPI DirectPlayLobbyCreateW(LPGUID, LPDIRECTPLAYLOBBY*, IUnknown*, LPVOID, DWORD );
337 extern HRESULT WINAPI DirectPlayLobbyCreateA(LPGUID, LPDIRECTPLAYLOBBYA*, IUnknown*, LPVOID, DWORD );
341 typedef BOOL CALLBACK (*LPDPENUMADDRESSCALLBACK)(
342 REFGUID guidDataType,
343 DWORD dwDataSize,
344 LPCVOID lpData,
345 LPVOID lpContext );
347 typedef BOOL CALLBACK (*LPDPLENUMADDRESSTYPESCALLBACK)(
348 REFGUID guidDataType,
349 LPVOID lpContext,
350 DWORD dwFlags );
352 typedef BOOL CALLBACK (*LPDPLENUMLOCALAPPLICATIONSCALLBACK)(
353 LPCDPLAPPINFO lpAppInfo,
354 LPVOID lpContext,
355 DWORD dwFlags );
357 #include "poppack.h"
359 /*****************************************************************************
360 * IDirectPlayLobby and IDirectPlayLobbyA interface
362 #define ICOM_INTERFACE IDirectPlayLobby
363 #define IDirectPlayLobby_METHODS \
364 ICOM_METHOD3(HRESULT,Connect, DWORD,, LPDIRECTPLAY2*,, IUnknown*,) \
365 ICOM_METHOD6(HRESULT,CreateAddress, REFGUID,, REFGUID,, LPCVOID,, DWORD,, LPVOID,, LPDWORD,) \
366 ICOM_METHOD4(HRESULT,EnumAddress, LPDPENUMADDRESSCALLBACK,, LPCVOID,, DWORD,, LPVOID,) \
367 ICOM_METHOD4(HRESULT,EnumAddressTypes, LPDPLENUMADDRESSTYPESCALLBACK,, REFGUID,, LPVOID,, DWORD,) \
368 ICOM_METHOD3(HRESULT,EnumLocalApplications, LPDPLENUMLOCALAPPLICATIONSCALLBACK,, LPVOID,, DWORD,) \
369 ICOM_METHOD3(HRESULT,GetConnectionSettings, DWORD,, LPVOID,, LPDWORD,) \
370 ICOM_METHOD5(HRESULT,ReceiveLobbyMessage, DWORD,, DWORD,, LPDWORD,, LPVOID,, LPDWORD,) \
371 ICOM_METHOD4(HRESULT,RunApplication, DWORD,, LPDWORD,, LPDPLCONNECTION,, HANDLE,) \
372 ICOM_METHOD4(HRESULT,SendLobbyMessage, DWORD,, DWORD,, LPVOID,, DWORD,) \
373 ICOM_METHOD3(HRESULT,SetConnectionSettings, DWORD,, DWORD,, LPDPLCONNECTION,) \
374 ICOM_METHOD3(HRESULT,SetLobbyMessageEvent, DWORD,, DWORD,, HANDLE,)
375 #define IDirectPlayLobby_IMETHODS \
376 IUnknown_IMETHODS \
377 IDirectPlayLobby_METHODS
378 ICOM_DEFINE(IDirectPlayLobby,IUnknown)
379 #undef ICOM_INTERFACE
381 /*****************************************************************************
382 * IDirectPlayLobby2 and IDirectPlayLobby2A interface
384 #define ICOM_INTERFACE IDirectPlayLobby2
385 #define IDirectPlayLobby2_METHODS \
386 ICOM_METHOD4(HRESULT,CreateCompoundAddress, LPCDPCOMPOUNDADDRESSELEMENT,, DWORD,, LPVOID,, LPDWORD,)
387 #define IDirectPlayLobby2_IMETHODS \
388 IDirectPlayLobby_IMETHODS \
389 IDirectPlayLobby2_METHODS
390 ICOM_DEFINE(IDirectPlayLobby2,IDirectPlayLobby)
391 #undef ICOM_INTERFACE
393 /*****************************************************************************
394 * IDirectPlayLobby3 and IDirectPlayLobby3A interface
396 #define ICOM_INTERFACE IDirectPlayLobby3
397 #define IDirectPlayLobby3_METHODS \
398 ICOM_METHOD4( HRESULT, ConnectEx, DWORD,, REFIID,, LPVOID *,, IUnknown *,) \
399 ICOM_METHOD2( HRESULT, RegisterApplication, DWORD,, LPDPAPPLICATIONDESC, ) \
400 ICOM_METHOD2( HRESULT, UnregisterApplication, DWORD,, REFGUID, ) \
401 ICOM_METHOD1( HRESULT, WaitForConnectionSettings, DWORD, )
403 #define IDirectPlayLobby3_IMETHODS \
404 IDirectPlayLobby2_IMETHODS \
405 IDirectPlayLobby3_METHODS
406 ICOM_DEFINE(IDirectPlayLobby3,IDirectPlayLobby2)
407 #undef ICOM_INTERFACE
409 #define IDirectPlayLobby_QueryInterface(p,a,b) ICOM_CALL2(QueryInterface,p,a,b)
410 #define IDirectPlayLobby_AddRef(p) ICOM_CALL (AddRef,p)
411 #define IDirectPlayLobby_Release(p) ICOM_CALL (Release,p)
412 #define IDirectPlayLobby_Connect(p,a,b,c) ICOM_CALL3(Connect,p,a,b,c)
413 #define IDirectPlayLobby_ConnectEx(p,a,b,c,d) ICOM_CALL4(ConnectEx,p,a,b,c,d)
414 #define IDirectPlayLobby_CreateAddress(p,a,b,c,d,e,f) ICOM_CALL6(CreateAddress,p,a,b,c,d,e,f)
415 #define IDirectPlayLobby_CreateCompoundAddress(p,a,b,c,d) ICOM_CALL4(CreateCompoundAddress,p,a,b,c,d)
416 #define IDirectPlayLobby_EnumAddress(p,a,b,c,d) ICOM_CALL4(EnumAddress,p,a,b,c,d)
417 #define IDirectPlayLobby_EnumAddressTypes(p,a,b,c,d) ICOM_CALL4(EnumAddressTypes,p,a,b,c,d)
418 #define IDirectPlayLobby_EnumLocalApplications(p,a,b,c) ICOM_CALL3(EnumLocalApplications,p,a,b,c)
419 #define IDirectPlayLobby_GetConnectionSettings(p,a,b,c) ICOM_CALL3(GetConnectionSettings,p,a,b,c)
420 #define IDirectPlayLobby_ReceiveLobbyMessage(p,a,b,c,d,e) ICOM_CALL5(ReceiveLobbyMessage,p,a,b,c,d,e)
421 #define IDirectPlayLobby_RegisterApplication(p,a,b) ICOM_CALL2(RegisterApplication,p,a,b)
422 #define IDirectPlayLobby_RunApplication(p,a,b,c,d) ICOM_CALL4(RunApplication,p,a,b,c,d)
423 #define IDirectPlayLobby_SendLobbyMessage(p,a,b,c,d) ICOM_CALL4(SendLobbyMessage,p,a,b,c,d)
424 #define IDirectPlayLobby_SetConnectionSettings(p,a,b,c) ICOM_CALL3(SetConnectionSettings,p,a,b,c)
425 #define IDirectPlayLobby_SetLobbyMessageEvent(p,a,b,c) ICOM_CALL3(SetLobbyMessageEvent,p,a,b,c)
426 #define IDirectPlayLobby_UnregisterApplication(p,a,b) ICOM_CALL2(UnregisterApplication,p,a,b)
427 #define IDirectPlayLobby_WaitForConnectionSettings(p,a) ICOM_CALL1(WaitForConnectionSettings,p,a)
429 /* Used for WaitForConnectionSettings */
430 #define DPLWAIT_CANCEL 0x00000001
432 #ifdef __cplusplus
433 } /* extern "C" */
434 #endif /* defined(__cplusplus) */
436 #endif /* __WINE_DPLOBBY_H */