Mercurial > games > semicongine
comparison fuhtark_test/include/winapi/dplobby.h @ 1500:91c8c3b7cbf0
add: futhark tests for generating vulkan api
| author | sam <sam@basx.dev> |
|---|---|
| date | Wed, 26 Nov 2025 21:36:48 +0700 |
| parents | |
| children |
comparison
equal
deleted
inserted
replaced
| 1499:1f58458b7ef7 | 1500:91c8c3b7cbf0 |
|---|---|
| 1 /* | |
| 2 * Copyright (C) 1999 Francois Gouget | |
| 3 * Copyright (C) 1999 Peter Hunnisett | |
| 4 * | |
| 5 * This library is free software; you can redistribute it and/or | |
| 6 * modify it under the terms of the GNU Lesser General Public | |
| 7 * License as published by the Free Software Foundation; either | |
| 8 * version 2.1 of the License, or (at your option) any later version. | |
| 9 * | |
| 10 * This library is distributed in the hope that it will be useful, | |
| 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
| 13 * Lesser General Public License for more details. | |
| 14 * | |
| 15 * You should have received a copy of the GNU Lesser General Public | |
| 16 * License along with this library; if not, write to the Free Software | |
| 17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA | |
| 18 */ | |
| 19 | |
| 20 #ifndef __WINE_DPLOBBY_H | |
| 21 #define __WINE_DPLOBBY_H | |
| 22 | |
| 23 #include <_mingw_dxhelper.h> | |
| 24 #include <dplay.h> | |
| 25 | |
| 26 #ifdef __cplusplus | |
| 27 extern "C" { | |
| 28 #endif /* defined(__cplusplus) */ | |
| 29 | |
| 30 /***************************************************************************** | |
| 31 * Predeclare the interfaces | |
| 32 */ | |
| 33 DEFINE_GUID(CLSID_DirectPlayLobby, 0x2fe8f810, 0xb2a5, 0x11d0, 0xa7, 0x87, 0x0, 0x0, 0xf8, 0x3, 0xab, 0xfc); | |
| 34 | |
| 35 DEFINE_GUID(IID_IDirectPlayLobby, 0xaf465c71, 0x9588, 0x11cf, 0xa0, 0x20, 0x0, 0xaa, 0x0, 0x61, 0x57, 0xac); | |
| 36 typedef struct IDirectPlayLobby *LPDIRECTPLAYLOBBY; | |
| 37 | |
| 38 DEFINE_GUID(IID_IDirectPlayLobbyA, 0x26c66a70, 0xb367, 0x11cf, 0xa0, 0x24, 0x0, 0xaa, 0x0, 0x61, 0x57, 0xac); | |
| 39 typedef struct IDirectPlayLobby IDirectPlayLobbyA,*LPDIRECTPLAYLOBBYA; | |
| 40 | |
| 41 DEFINE_GUID(IID_IDirectPlayLobby2, 0x194c220, 0xa303, 0x11d0, 0x9c, 0x4f, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e); | |
| 42 typedef struct IDirectPlayLobby2 *LPDIRECTPLAYLOBBY2; | |
| 43 | |
| 44 DEFINE_GUID(IID_IDirectPlayLobby2A, 0x1bb4af80, 0xa303, 0x11d0, 0x9c, 0x4f, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e); | |
| 45 typedef struct IDirectPlayLobby2 IDirectPlayLobby2A, *LPDIRECTPLAYLOBBY2A; | |
| 46 | |
| 47 DEFINE_GUID(IID_IDirectPlayLobby3, 0x2db72490, 0x652c, 0x11d1, 0xa7, 0xa8, 0x0, 0x0, 0xf8, 0x3, 0xab, 0xfc); | |
| 48 typedef struct IDirectPlayLobby3 *LPDIRECTPLAYLOBBY3; | |
| 49 | |
| 50 DEFINE_GUID(IID_IDirectPlayLobby3A, 0x2db72491, 0x652c, 0x11d1, 0xa7, 0xa8, 0x0, 0x0, 0xf8, 0x3, 0xab, 0xfc); | |
| 51 typedef struct IDirectPlayLobby3 IDirectPlayLobby3A, *LPDIRECTPLAYLOBBY3A; | |
| 52 | |
| 53 | |
| 54 /***************************************************************************** | |
| 55 * DirectPlayLobby Property GUIDs used in lobby messages | |
| 56 */ | |
| 57 | |
| 58 /* DPLPROPERTY_MessagesSupported {762CCDA1-D916-11d0-BA39-00C04FD7ED67}. | |
| 59 * Purpose: Request if the lobby supports standard (?). | |
| 60 * Response: Answer is a BOOL. TRUE if supports the standard (?) and FALSE otherwise. Of course, it might not respond at all. | |
| 61 */ | |
| 62 DEFINE_GUID(DPLPROPERTY_MessagesSupported, 0x762ccda1, 0xd916, 0x11d0, 0xba, 0x39, 0x0, 0xc0, 0x4f, 0xd7, 0xed, 0x67); | |
| 63 | |
| 64 /* DPLPROPERTY_LobbyGuid {F56920A0-D218-11d0-BA39-00C04FD7ED67}. | |
| 65 * Purpose: Request the GUID that identifies the lobby version that the application is communicating with. | |
| 66 * Response: The GUID which identifies the lobby version | |
| 67 */ | |
| 68 DEFINE_GUID(DPLPROPERTY_LobbyGuid, 0xf56920a0, 0xd218, 0x11d0, 0xba, 0x39, 0x0, 0xc0, 0x4f, 0xd7, 0xed, 0x67); | |
| 69 | |
| 70 /* DPLPROPERTY_PlayerGuid {B4319322-D20D-11d0-BA39-00C04FD7ED67} | |
| 71 * Purpose: Request the GUID that identifies the player for this particular machine. | |
| 72 * Response: DPLDATA_PLAYERDATA structure. | |
| 73 */ | |
| 74 DEFINE_GUID(DPLPROPERTY_PlayerGuid, 0xb4319322, 0xd20d, 0x11d0, 0xba, 0x39, 0x0, 0xc0, 0x4f, 0xd7, 0xed, 0x67); | |
| 75 | |
| 76 /* DPLPROPERTY_PlayerScore {48784000-D219-11d0-BA39-00C04FD7ED67} | |
| 77 * Purpose: Used to send a score of a player to the lobby. The format is an array of long integers. | |
| 78 * Response: I don't think there is one. | |
| 79 */ | |
| 80 DEFINE_GUID(DPLPROPERTY_PlayerScore, 0x48784000, 0xd219, 0x11d0, 0xba, 0x39, 0x0, 0xc0, 0x4f, 0xd7, 0xed, 0x67); | |
| 81 | |
| 82 | |
| 83 | |
| 84 /***************************************************************************** | |
| 85 * LOBBY structures associated with GUID messages | |
| 86 */ | |
| 87 | |
| 88 typedef struct tagDPLDATA_PLAYERGUID | |
| 89 { | |
| 90 GUID guidPlayer; | |
| 91 DWORD dwPlayerFlags; | |
| 92 } DPLDATA_PLAYERGUID, *LPDPLDATA_PLAYERGUID; | |
| 93 | |
| 94 typedef struct tagDPLDATA_PLAYERSCORE | |
| 95 { | |
| 96 DWORD dwScoreCount; | |
| 97 LONG Score[1]; | |
| 98 } DPLDATA_PLAYERSCORE, *LPDPLDATA_PLAYERSCORE; | |
| 99 | |
| 100 | |
| 101 /***************************************************************************** | |
| 102 * LOBBY messages and message data structures. | |
| 103 * | |
| 104 * System messages can be identified by dwMessageFlags having a value of DPLMSG_SYSTEM | |
| 105 * after a call to ReceiveLobbyMessage. | |
| 106 * | |
| 107 * Standard messages can be indentified by dwMessageFlags having a value of DPLMSG_STANDARD | |
| 108 * after a call to ReceiveLobbyMessage. | |
| 109 */ | |
| 110 | |
| 111 /* DPLobby1 definition required for backwards compatibility */ | |
| 112 #define DPLMSG_SYSTEM 0x00000001 | |
| 113 #define DPLMSG_STANDARD 0x00000002 | |
| 114 #define DPLAD_SYSTEM DPLMSG_SYSTEM | |
| 115 | |
| 116 | |
| 117 /* System messages - dwType field for messages */ | |
| 118 #define DPLSYS_CONNECTIONSETTINGSREAD 0x00000001 | |
| 119 #define DPLSYS_DPLAYCONNECTFAILED 0x00000002 | |
| 120 #define DPLSYS_DPLAYCONNECTSUCCEEDED 0x00000003 | |
| 121 #define DPLSYS_APPTERMINATED 0x00000004 | |
| 122 #define DPLSYS_SETPROPERTY 0x00000005 | |
| 123 #define DPLSYS_SETPROPERTYRESPONSE 0x00000006 | |
| 124 #define DPLSYS_GETPROPERTY 0x00000007 | |
| 125 #define DPLSYS_GETPROPERTYRESPONSE 0x00000008 | |
| 126 #define DPLSYS_NEWSESSIONHOST 0x00000009 | |
| 127 #define DPLSYS_NEWCONNECTIONSETTINGS 0x0000000A | |
| 128 | |
| 129 | |
| 130 | |
| 131 /* Used to indentify the message type */ | |
| 132 typedef struct tagDPLMSG_GENERIC | |
| 133 { | |
| 134 DWORD dwType; /* Message type */ | |
| 135 } DPLMSG_GENERIC, *LPDPLMSG_GENERIC; | |
| 136 | |
| 137 /* Generic format for system messages - see above */ | |
| 138 typedef struct tagDPLMSG_SYSTEMMESSAGE | |
| 139 { | |
| 140 DWORD dwType; /* Message type */ | |
| 141 GUID guidInstance; /* Instance GUID of the dplay session the message corresponds to */ | |
| 142 } DPLMSG_SYSTEMMESSAGE, *LPDPLMSG_SYSTEMMESSAGE; | |
| 143 | |
| 144 /* Generic message to set a property - see property GUIDs above */ | |
| 145 typedef struct tagDPLMSG_SETPROPERTY | |
| 146 { | |
| 147 DWORD dwType; /* Message type */ | |
| 148 DWORD dwRequestID; /* Request ID (DPL_NOCONFIRMATION if no confirmation desired) */ | |
| 149 GUID guidPlayer; /* Player GUID */ | |
| 150 GUID guidPropertyTag; /* Property GUID */ | |
| 151 DWORD dwDataSize; /* Size of data */ | |
| 152 DWORD dwPropertyData[1]; /* Buffer containing data */ | |
| 153 } DPLMSG_SETPROPERTY, *LPDPLMSG_SETPROPERTY; | |
| 154 | |
| 155 #define DPL_NOCONFIRMATION 0L | |
| 156 | |
| 157 /* Reply to DPLMSG_SETPROPERTY */ | |
| 158 typedef struct tagDPLMSG_SETPROPERTYRESPONSE | |
| 159 { | |
| 160 DWORD dwType; /* Message type */ | |
| 161 DWORD dwRequestID; /* Request ID */ | |
| 162 GUID guidPlayer; /* Player GUID */ | |
| 163 GUID guidPropertyTag; /* Property GUID */ | |
| 164 HRESULT hr; /* Return Code */ | |
| 165 } DPLMSG_SETPROPERTYRESPONSE, *LPDPLMSG_SETPROPERTYRESPONSE; | |
| 166 | |
| 167 /* Request to get the present value of a property */ | |
| 168 typedef struct tagDPLMSG_GETPROPERTY | |
| 169 { | |
| 170 DWORD dwType; /* Message type */ | |
| 171 DWORD dwRequestID; /* Request ID */ | |
| 172 GUID guidPlayer; /* Player GUID */ | |
| 173 GUID guidPropertyTag; /* Property GUID */ | |
| 174 } DPLMSG_GETPROPERTY, *LPDPLMSG_GETPROPERTY; | |
| 175 | |
| 176 /* Response to a request to get the present value of a property */ | |
| 177 typedef struct tagDPLMSG_GETPROPERTYRESPONSE | |
| 178 { | |
| 179 DWORD dwType; /* Message type */ | |
| 180 DWORD dwRequestID; /* Request ID */ | |
| 181 GUID guidPlayer; /* Player GUID */ | |
| 182 GUID guidPropertyTag; /* Property GUID */ | |
| 183 HRESULT hr; /* Return Code */ | |
| 184 DWORD dwDataSize; /* Size of data */ | |
| 185 DWORD dwPropertyData[1]; /* Buffer containing data */ | |
| 186 } DPLMSG_GETPROPERTYRESPONSE, *LPDPLMSG_GETPROPERTYRESPONSE; | |
| 187 | |
| 188 /* Standard message in response to a session host migration to a new client */ | |
| 189 typedef struct tagDPLMSG_NEWSESSIONHOST | |
| 190 { | |
| 191 DWORD dwType; /* Message type */ | |
| 192 GUID guidInstance; /* GUID Instance of the session */ | |
| 193 } DPLMSG_NEWSESSIONHOST, *LPDPLMSG_NEWSESSIONHOST; | |
| 194 | |
| 195 /***************************************************************************** | |
| 196 * DirectPlay Address ID's | |
| 197 * A DirectPlay address is composed of multiple data chunks, each associated with | |
| 198 * a GUID to give significance to the type of data. All chunks have an associated | |
| 199 * size so that unknown chunks can be ignored for backwards compatibility! | |
| 200 * EnumAddresses function is used to parse the address data chunks. | |
| 201 */ | |
| 202 | |
| 203 /* DPAID_TotalSize {1318F560-912C-11d0-9DAA-00A0C90A43CB} | |
| 204 * Chunk purpose: Chunk is a DWORD containing the size of the entire DPADDRESS struct | |
| 205 */ | |
| 206 DEFINE_GUID(DPAID_TotalSize, 0x1318f560, 0x912c, 0x11d0, 0x9d, 0xaa, 0x0, 0xa0, 0xc9, 0xa, 0x43, 0xcb); | |
| 207 | |
| 208 /* DPAID_ServiceProvider {07D916C0-E0AF-11cf-9C4E-00A0C905425E} | |
| 209 * Chunk purpose: Chunk is a GUID indicated what service provider created the chunk. | |
| 210 */ | |
| 211 DEFINE_GUID(DPAID_ServiceProvider, 0x7d916c0, 0xe0af, 0x11cf, 0x9c, 0x4e, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e); | |
| 212 | |
| 213 /* DPAID_LobbyProvider {59B95640-9667-11d0-A77D-0000F803ABFC} | |
| 214 * Chunk purpose: Chunk is a GUID indicating what lobby provider created the chunk. | |
| 215 */ | |
| 216 DEFINE_GUID(DPAID_LobbyProvider, 0x59b95640, 0x9667, 0x11d0, 0xa7, 0x7d, 0x0, 0x0, 0xf8, 0x3, 0xab, 0xfc); | |
| 217 | |
| 218 /* DPAID_Phone {78EC89A0-E0AF-11cf-9C4E-00A0C905425E} -- ANSI | |
| 219 * DPAID_PhoneW {BA5A7A70-9DBF-11d0-9CC1-00A0C905425E} -- UNICODE | |
| 220 * Chunk purpose: Chunk is a phone number in ANSI or UNICODE format | |
| 221 */ | |
| 222 DEFINE_GUID(DPAID_Phone, 0x78ec89a0, 0xe0af, 0x11cf, 0x9c, 0x4e, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e); | |
| 223 DEFINE_GUID(DPAID_PhoneW, 0xba5a7a70, 0x9dbf, 0x11d0, 0x9c, 0xc1, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e); | |
| 224 | |
| 225 /* DPAID_Modem {F6DCC200-A2FE-11d0-9C4F-00A0C905425E} -- ANSI | |
| 226 * DPAID_ModemW {01FD92E0-A2FF-11d0-9C4F-00A0C905425E} -- UNICODE | |
| 227 * Chunk purpose: Chunk is a modem name registered with TAPI | |
| 228 */ | |
| 229 DEFINE_GUID(DPAID_Modem, 0xf6dcc200, 0xa2fe, 0x11d0, 0x9c, 0x4f, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e); | |
| 230 DEFINE_GUID(DPAID_ModemW, 0x1fd92e0, 0xa2ff, 0x11d0, 0x9c, 0x4f, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e); | |
| 231 | |
| 232 /* DPAID_INet {C4A54DA0-E0AF-11cf-9C4E-00A0C905425E} -- ANSI | |
| 233 * DPAID_INetW {E63232A0-9DBF-11d0-9CC1-00A0C905425E} -- UNICODE | |
| 234 * Chunk purpose: Chunk is a string containing a TCP/IP host name or IP address | |
| 235 */ | |
| 236 DEFINE_GUID(DPAID_INet, 0xc4a54da0, 0xe0af, 0x11cf, 0x9c, 0x4e, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e); | |
| 237 DEFINE_GUID(DPAID_INetW, 0xe63232a0, 0x9dbf, 0x11d0, 0x9c, 0xc1, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e); | |
| 238 | |
| 239 /* DPAID_INetPort {E4524541-8EA5-11d1-8A96-006097B01411} | |
| 240 * Chunk purpose: Chunk is a port number used for creating TCP and UDP sockets. (WORD) | |
| 241 */ | |
| 242 DEFINE_GUID(DPAID_INetPort, 0xe4524541, 0x8ea5, 0x11d1, 0x8a, 0x96, 0x0, 0x60, 0x97, 0xb0, 0x14, 0x11); | |
| 243 | |
| 244 /* DPAID_ComPort {F2F0CE00-E0AF-11cf-9C4E-00A0C905425E} | |
| 245 * Chunk purpose: Chunk contains the description of a serial port. | |
| 246 */ | |
| 247 DEFINE_GUID(DPAID_ComPort, 0xf2f0ce00, 0xe0af, 0x11cf, 0x9c, 0x4e, 0x0, 0xa0, 0xc9, 0x5, 0x42, 0x5e); | |
| 248 | |
| 249 | |
| 250 /* Header block for address data elements */ | |
| 251 typedef struct tagDPADDRESS | |
| 252 { | |
| 253 GUID guidDataType; | |
| 254 DWORD dwDataSize; | |
| 255 } DPADDRESS, *LPDPADDRESS; | |
| 256 | |
| 257 | |
| 258 /* Used for specification of a communication port. Baud rate, stop bits and | |
| 259 * parity bits can be found in winbase.h. These are flow control constants only. | |
| 260 */ | |
| 261 #define DPCPA_NOFLOW 0 /* no flow control */ | |
| 262 #define DPCPA_XONXOFFFLOW 1 /* software flow control */ | |
| 263 #define DPCPA_RTSFLOW 2 /* hardware flow control with RTS */ | |
| 264 #define DPCPA_DTRFLOW 3 /* hardware flow control with DTR */ | |
| 265 #define DPCPA_RTSDTRFLOW 4 /* hardware flow control with RTS and DTR */ | |
| 266 | |
| 267 typedef struct tagDPCOMPORTADDRESS | |
| 268 { | |
| 269 DWORD dwComPort; /* COM port to use (1-4) */ | |
| 270 DWORD dwBaudRate; /* baud rate (100-256k) */ | |
| 271 DWORD dwStopBits; /* no. stop bits (1-2) */ | |
| 272 DWORD dwParity; /* parity (none, odd, even, mark) */ | |
| 273 DWORD dwFlowControl; /* flow control (none, xon/xoff, rts, dtr) */ | |
| 274 } DPCOMPORTADDRESS, *LPDPCOMPORTADDRESS; | |
| 275 | |
| 276 | |
| 277 | |
| 278 /**************************************************************************** | |
| 279 * Miscellaneous | |
| 280 */ | |
| 281 | |
| 282 typedef struct tagDPLAPPINFO | |
| 283 { | |
| 284 DWORD dwSize; | |
| 285 GUID guidApplication; | |
| 286 | |
| 287 union | |
| 288 { | |
| 289 LPSTR lpszAppNameA; | |
| 290 LPWSTR lpszAppName; | |
| 291 } DUMMYUNIONNAME; | |
| 292 | |
| 293 } DPLAPPINFO, *LPDPLAPPINFO; | |
| 294 typedef const DPLAPPINFO *LPCDPLAPPINFO; | |
| 295 | |
| 296 typedef struct DPCOMPOUNDADDRESSELEMENT | |
| 297 { | |
| 298 GUID guidDataType; | |
| 299 DWORD dwDataSize; | |
| 300 LPVOID lpData; | |
| 301 } DPCOMPOUNDADDRESSELEMENT, *LPDPCOMPOUNDADDRESSELEMENT; | |
| 302 typedef const DPCOMPOUNDADDRESSELEMENT *LPCDPCOMPOUNDADDRESSELEMENT; | |
| 303 | |
| 304 typedef struct tagDPAPPLICATIONDESC | |
| 305 { | |
| 306 DWORD dwSize; | |
| 307 DWORD dwFlags; | |
| 308 | |
| 309 union | |
| 310 { | |
| 311 LPSTR lpszApplicationNameA; | |
| 312 LPWSTR lpszApplicationName; | |
| 313 } DUMMYUNIONNAME1; | |
| 314 | |
| 315 GUID guidApplication; | |
| 316 | |
| 317 union | |
| 318 { | |
| 319 LPSTR lpszFilenameA; | |
| 320 LPWSTR lpszFilename; | |
| 321 } DUMMYUNIONNAME2; | |
| 322 | |
| 323 union | |
| 324 { | |
| 325 LPSTR lpszCommandLineA; | |
| 326 LPWSTR lpszCommandLine; | |
| 327 } DUMMYUNIONNAME3; | |
| 328 | |
| 329 union | |
| 330 { | |
| 331 LPSTR lpszPathA; | |
| 332 LPWSTR lpszPath; | |
| 333 } DUMMYUNIONNAME4; | |
| 334 | |
| 335 union | |
| 336 { | |
| 337 LPSTR lpszCurrentDirectoryA; | |
| 338 LPWSTR lpszCurrentDirectory; | |
| 339 } DUMMYUNIONNAME5; | |
| 340 | |
| 341 LPSTR lpszDescriptionA; | |
| 342 LPWSTR lpszDescriptionW; | |
| 343 | |
| 344 } DPAPPLICATIONDESC, *LPDPAPPLICATIONDESC; | |
| 345 | |
| 346 | |
| 347 | |
| 348 extern HRESULT WINAPI DirectPlayLobbyCreateW(LPGUID, LPDIRECTPLAYLOBBY*, IUnknown*, LPVOID, DWORD ); | |
| 349 extern HRESULT WINAPI DirectPlayLobbyCreateA(LPGUID, LPDIRECTPLAYLOBBYA*, IUnknown*, LPVOID, DWORD ); | |
| 350 #define DirectPlayLobbyCreate WINELIB_NAME_AW(DirectPlayLobbyCreate) | |
| 351 | |
| 352 | |
| 353 typedef BOOL (CALLBACK *LPDPENUMADDRESSCALLBACK)( | |
| 354 REFGUID guidDataType, | |
| 355 DWORD dwDataSize, | |
| 356 LPCVOID lpData, | |
| 357 LPVOID lpContext ); | |
| 358 | |
| 359 typedef BOOL (CALLBACK *LPDPLENUMADDRESSTYPESCALLBACK)( | |
| 360 REFGUID guidDataType, | |
| 361 LPVOID lpContext, | |
| 362 DWORD dwFlags ); | |
| 363 | |
| 364 typedef BOOL (CALLBACK *LPDPLENUMLOCALAPPLICATIONSCALLBACK)( | |
| 365 LPCDPLAPPINFO lpAppInfo, | |
| 366 LPVOID lpContext, | |
| 367 DWORD dwFlags ); | |
| 368 | |
| 369 /***************************************************************************** | |
| 370 * IDirectPlayLobby and IDirectPlayLobbyA interface | |
| 371 */ | |
| 372 #define INTERFACE IDirectPlayLobby | |
| 373 DECLARE_INTERFACE_(IDirectPlayLobby,IUnknown) | |
| 374 { | |
| 375 /*** IUnknown methods ***/ | |
| 376 STDMETHOD_(HRESULT,QueryInterface)(THIS_ REFIID riid, void** ppvObject) PURE; | |
| 377 STDMETHOD_(ULONG,AddRef)(THIS) PURE; | |
| 378 STDMETHOD_(ULONG,Release)(THIS) PURE; | |
| 379 /*** IDirectPlayLobby methods ***/ | |
| 380 STDMETHOD(Connect)(THIS_ DWORD, LPDIRECTPLAY2*, IUnknown*) PURE; | |
| 381 STDMETHOD(CreateAddress)(THIS_ REFGUID, REFGUID, LPCVOID, DWORD, LPVOID, LPDWORD) PURE; | |
| 382 STDMETHOD(EnumAddress)(THIS_ LPDPENUMADDRESSCALLBACK, LPCVOID, DWORD, LPVOID) PURE; | |
| 383 STDMETHOD(EnumAddressTypes)(THIS_ LPDPLENUMADDRESSTYPESCALLBACK, REFGUID, LPVOID, DWORD) PURE; | |
| 384 STDMETHOD(EnumLocalApplications)(THIS_ LPDPLENUMLOCALAPPLICATIONSCALLBACK, LPVOID, DWORD) PURE; | |
| 385 STDMETHOD(GetConnectionSettings)(THIS_ DWORD, LPVOID, LPDWORD) PURE; | |
| 386 STDMETHOD(ReceiveLobbyMessage)(THIS_ DWORD, DWORD, LPDWORD, LPVOID, LPDWORD) PURE; | |
| 387 STDMETHOD(RunApplication)(THIS_ DWORD, LPDWORD, LPDPLCONNECTION, HANDLE) PURE; | |
| 388 STDMETHOD(SendLobbyMessage)(THIS_ DWORD, DWORD, LPVOID, DWORD) PURE; | |
| 389 STDMETHOD(SetConnectionSettings)(THIS_ DWORD, DWORD, LPDPLCONNECTION) PURE; | |
| 390 STDMETHOD(SetLobbyMessageEvent)(THIS_ DWORD, DWORD, HANDLE) PURE; | |
| 391 }; | |
| 392 #undef INTERFACE | |
| 393 | |
| 394 /***************************************************************************** | |
| 395 * IDirectPlayLobby2 and IDirectPlayLobby2A interface | |
| 396 */ | |
| 397 #define INTERFACE IDirectPlayLobby2 | |
| 398 DECLARE_INTERFACE_(IDirectPlayLobby2,IDirectPlayLobby) | |
| 399 { | |
| 400 /*** IUnknown methods ***/ | |
| 401 STDMETHOD_(HRESULT,QueryInterface)(THIS_ REFIID riid, void** ppvObject) PURE; | |
| 402 STDMETHOD_(ULONG,AddRef)(THIS) PURE; | |
| 403 STDMETHOD_(ULONG,Release)(THIS) PURE; | |
| 404 /*** IDirectPlayLobby methods ***/ | |
| 405 STDMETHOD(Connect)(THIS_ DWORD, LPDIRECTPLAY2*, IUnknown*) PURE; | |
| 406 STDMETHOD(CreateAddress)(THIS_ REFGUID, REFGUID, LPCVOID, DWORD, LPVOID, LPDWORD) PURE; | |
| 407 STDMETHOD(EnumAddress)(THIS_ LPDPENUMADDRESSCALLBACK, LPCVOID, DWORD, LPVOID) PURE; | |
| 408 STDMETHOD(EnumAddressTypes)(THIS_ LPDPLENUMADDRESSTYPESCALLBACK, REFGUID, LPVOID, DWORD) PURE; | |
| 409 STDMETHOD(EnumLocalApplications)(THIS_ LPDPLENUMLOCALAPPLICATIONSCALLBACK, LPVOID, DWORD) PURE; | |
| 410 STDMETHOD(GetConnectionSettings)(THIS_ DWORD, LPVOID, LPDWORD) PURE; | |
| 411 STDMETHOD(ReceiveLobbyMessage)(THIS_ DWORD, DWORD, LPDWORD, LPVOID, LPDWORD) PURE; | |
| 412 STDMETHOD(RunApplication)(THIS_ DWORD, LPDWORD, LPDPLCONNECTION, HANDLE) PURE; | |
| 413 STDMETHOD(SendLobbyMessage)(THIS_ DWORD, DWORD, LPVOID, DWORD) PURE; | |
| 414 STDMETHOD(SetConnectionSettings)(THIS_ DWORD, DWORD, LPDPLCONNECTION) PURE; | |
| 415 STDMETHOD(SetLobbyMessageEvent)(THIS_ DWORD, DWORD, HANDLE) PURE; | |
| 416 /*** IDirectPlayLobby2 methods ***/ | |
| 417 STDMETHOD(CreateCompoundAddress)(THIS_ LPCDPCOMPOUNDADDRESSELEMENT, DWORD, LPVOID, LPDWORD) PURE; | |
| 418 }; | |
| 419 #undef INTERFACE | |
| 420 | |
| 421 /***************************************************************************** | |
| 422 * IDirectPlayLobby3 and IDirectPlayLobby3A interface | |
| 423 */ | |
| 424 #define INTERFACE IDirectPlayLobby3 | |
| 425 DECLARE_INTERFACE_(IDirectPlayLobby3,IDirectPlayLobby2) | |
| 426 { | |
| 427 /*** IUnknown methods ***/ | |
| 428 STDMETHOD_(HRESULT,QueryInterface)(THIS_ REFIID riid, void** ppvObject) PURE; | |
| 429 STDMETHOD_(ULONG,AddRef)(THIS) PURE; | |
| 430 STDMETHOD_(ULONG,Release)(THIS) PURE; | |
| 431 /*** IDirectPlayLobby methods ***/ | |
| 432 STDMETHOD(Connect)(THIS_ DWORD, LPDIRECTPLAY2*, IUnknown*) PURE; | |
| 433 STDMETHOD(CreateAddress)(THIS_ REFGUID, REFGUID, LPCVOID, DWORD, LPVOID, LPDWORD) PURE; | |
| 434 STDMETHOD(EnumAddress)(THIS_ LPDPENUMADDRESSCALLBACK, LPCVOID, DWORD, LPVOID) PURE; | |
| 435 STDMETHOD(EnumAddressTypes)(THIS_ LPDPLENUMADDRESSTYPESCALLBACK, REFGUID, LPVOID, DWORD) PURE; | |
| 436 STDMETHOD(EnumLocalApplications)(THIS_ LPDPLENUMLOCALAPPLICATIONSCALLBACK, LPVOID, DWORD) PURE; | |
| 437 STDMETHOD(GetConnectionSettings)(THIS_ DWORD, LPVOID, LPDWORD) PURE; | |
| 438 STDMETHOD(ReceiveLobbyMessage)(THIS_ DWORD, DWORD, LPDWORD, LPVOID, LPDWORD) PURE; | |
| 439 STDMETHOD(RunApplication)(THIS_ DWORD, LPDWORD, LPDPLCONNECTION, HANDLE) PURE; | |
| 440 STDMETHOD(SendLobbyMessage)(THIS_ DWORD, DWORD, LPVOID, DWORD) PURE; | |
| 441 STDMETHOD(SetConnectionSettings)(THIS_ DWORD, DWORD, LPDPLCONNECTION) PURE; | |
| 442 STDMETHOD(SetLobbyMessageEvent)(THIS_ DWORD, DWORD, HANDLE) PURE; | |
| 443 /*** IDirectPlayLobby2 methods ***/ | |
| 444 STDMETHOD(CreateCompoundAddress)(THIS_ LPCDPCOMPOUNDADDRESSELEMENT, DWORD, LPVOID, LPDWORD) PURE; | |
| 445 /*** IDirectPlayLobby3 methods ***/ | |
| 446 STDMETHOD(ConnectEx)(THIS_ DWORD, REFIID, LPVOID *, IUnknown *) PURE; | |
| 447 STDMETHOD(RegisterApplication)(THIS_ DWORD, LPDPAPPLICATIONDESC) PURE; | |
| 448 STDMETHOD(UnregisterApplication)(THIS_ DWORD, REFGUID) PURE; | |
| 449 STDMETHOD(WaitForConnectionSettings)(THIS_ DWORD) PURE; | |
| 450 }; | |
| 451 #undef INTERFACE | |
| 452 | |
| 453 #if !defined(__cplusplus) || defined(CINTERFACE) | |
| 454 /*** IUnknown methods ***/ | |
| 455 #define IDirectPlayLobby_QueryInterface(p,a,b) (p)->lpVtbl->QueryInterface(p,a,b) | |
| 456 #define IDirectPlayLobby_AddRef(p) (p)->lpVtbl->AddRef(p) | |
| 457 #define IDirectPlayLobby_Release(p) (p)->lpVtbl->Release(p) | |
| 458 /*** IDirectPlayLobby methods ***/ | |
| 459 #define IDirectPlayLobby_Connect(p,a,b,c) (p)->lpVtbl->Connect(p,a,b,c) | |
| 460 #define IDirectPlayLobby_CreateAddress(p,a,b,c,d,e,f) (p)->lpVtbl->CreateAddress(p,a,b,c,d,e,f) | |
| 461 #define IDirectPlayLobby_EnumAddress(p,a,b,c,d) (p)->lpVtbl->EnumAddress(p,a,b,c,d) | |
| 462 #define IDirectPlayLobby_EnumAddressTypes(p,a,b,c,d) (p)->lpVtbl->EnumAddressTypes(p,a,b,c,d) | |
| 463 #define IDirectPlayLobby_EnumLocalApplications(p,a,b,c) (p)->lpVtbl->EnumLocalApplications(p,a,b,c) | |
| 464 #define IDirectPlayLobby_GetConnectionSettings(p,a,b,c) (p)->lpVtbl->GetConnectionSettings(p,a,b,c) | |
| 465 #define IDirectPlayLobby_ReceiveLobbyMessage(p,a,b,c,d,e) (p)->lpVtbl->ReceiveLobbyMessage(p,a,b,c,d,e) | |
| 466 #define IDirectPlayLobby_RunApplication(p,a,b,c,d) (p)->lpVtbl->RunApplication(p,a,b,c,d) | |
| 467 #define IDirectPlayLobby_SendLobbyMessage(p,a,b,c,d) (p)->lpVtbl->SendLobbyMessage(p,a,b,c,d) | |
| 468 #define IDirectPlayLobby_SetConnectionSettings(p,a,b,c) (p)->lpVtbl->SetConnectionSettings(p,a,b,c) | |
| 469 #define IDirectPlayLobby_SetLobbyMessageEvent(p,a,b,c) (p)->lpVtbl->SetLobbyMessageEvent(p,a,b,c) | |
| 470 /*** IDirectPlayLobby2 methods ***/ | |
| 471 #define IDirectPlayLobby_CreateCompoundAddress(p,a,b,c,d) (p)->lpVtbl->CreateCompoundAddress(p,a,b,c,d) | |
| 472 /*** IDirectPlayLobby3 methods ***/ | |
| 473 #define IDirectPlayLobby_ConnectEx(p,a,b,c,d) (p)->lpVtbl->ConnectEx(p,a,b,c,d) | |
| 474 #define IDirectPlayLobby_RegisterApplication(p,a,b) (p)->lpVtbl->RegisterApplication(p,a,b) | |
| 475 #define IDirectPlayLobby_UnregisterApplication(p,a,b) (p)->lpVtbl->UnregisterApplication(p,a,b) | |
| 476 #define IDirectPlayLobby_WaitForConnectionSettings(p,a) (p)->lpVtbl->WaitForConnectionSettings(p,a) | |
| 477 #else | |
| 478 /*** IUnknown methods ***/ | |
| 479 #define IDirectPlayLobby_QueryInterface(p,a,b) (p)->QueryInterface(a,b) | |
| 480 #define IDirectPlayLobby_AddRef(p) (p)->AddRef() | |
| 481 #define IDirectPlayLobby_Release(p) (p)->Release() | |
| 482 /*** IDirectPlayLobby methods ***/ | |
| 483 #define IDirectPlayLobby_Connect(p,a,b,c) (p)->Connect(a,b,c) | |
| 484 #define IDirectPlayLobby_CreateAddress(p,a,b,c,d,e,f) (p)->CreateAddress(a,b,c,d,e,f) | |
| 485 #define IDirectPlayLobby_EnumAddress(p,a,b,c,d) (p)->EnumAddress(a,b,c,d) | |
| 486 #define IDirectPlayLobby_EnumAddressTypes(p,a,b,c,d) (p)->EnumAddressTypes(a,b,c,d) | |
| 487 #define IDirectPlayLobby_EnumLocalApplications(p,a,b,c) (p)->EnumLocalApplications(a,b,c) | |
| 488 #define IDirectPlayLobby_GetConnectionSettings(p,a,b,c) (p)->GetConnectionSettings(a,b,c) | |
| 489 #define IDirectPlayLobby_ReceiveLobbyMessage(p,a,b,c,d,e) (p)->ReceiveLobbyMessage(a,b,c,d,e) | |
| 490 #define IDirectPlayLobby_RunApplication(p,a,b,c,d) (p)->RunApplication(a,b,c,d) | |
| 491 #define IDirectPlayLobby_SendLobbyMessage(p,a,b,c,d) (p)->SendLobbyMessage(a,b,c,d) | |
| 492 #define IDirectPlayLobby_SetConnectionSettings(p,a,b,c) (p)->SetConnectionSettings(a,b,c) | |
| 493 #define IDirectPlayLobby_SetLobbyMessageEvent(p,a,b,c) (p)->SetLobbyMessageEvent(a,b,c) | |
| 494 /*** IDirectPlayLobby2 methods ***/ | |
| 495 #define IDirectPlayLobby_CreateCompoundAddress(p,a,b,c,d) (p)->CreateCompoundAddress(a,b,c,d) | |
| 496 /*** IDirectPlayLobby3 methods ***/ | |
| 497 #define IDirectPlayLobby_ConnectEx(p,a,b,c,d) (p)->ConnectEx(a,b,c,d) | |
| 498 #define IDirectPlayLobby_RegisterApplication(p,a,b) (p)->RegisterApplication(a,b) | |
| 499 #define IDirectPlayLobby_UnregisterApplication(p,a,b) (p)->UnregisterApplication(a,b) | |
| 500 #define IDirectPlayLobby_WaitForConnectionSettings(p,a) (p)->WaitForConnectionSettings(a) | |
| 501 #endif | |
| 502 | |
| 503 /* Used for WaitForConnectionSettings */ | |
| 504 #define DPLWAIT_CANCEL 0x00000001 | |
| 505 | |
| 506 #ifdef __cplusplus | |
| 507 } /* extern "C" */ | |
| 508 #endif /* defined(__cplusplus) */ | |
| 509 | |
| 510 #endif /* __WINE_DPLOBBY_H */ |
