/* * Descent 3 * Copyright (C) 2024 Parallax Software * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . --- HISTORICAL COMMENTS FOLLOW --- * $Logfile: /DescentIII/Main/lib/directplay.h $ * $Revision: 5 $ * $Date: 9/02/98 6:54p $ * $Author: Kevin $ * * Directplay API header * * $Log: /DescentIII/Main/lib/directplay.h $ * * 5 9/02/98 6:54p Kevin * Fixed general directplay support up, and got modem-modem working * * 4 8/24/98 10:55a Kevin * new directplay stuff * * 3 8/14/98 4:54p Kevin * More directplay stuff * * 2 8/13/98 6:32p Kevin * Initial implementation of directplay API * * 1 8/13/98 6:25p Kevin * */ #ifndef _OUTRAGE_DIRECTPLAY_HEADER #define _OUTRAGE_DIRECTPLAY_HEADER #include #include "dplay.h" #include "dplobby.h" #include "networking.h" struct modem_list { char name[200]; }; #define MAX_MODEMS 15 #define MAX_DP_GAMES 32 #define MAX_DIRECTPLAY_CONNECTIONS 10 #define MAX_PENDING_NEW_CONNECTIONS 10 extern bool Use_DirectPlay; extern bool Directplay_lobby_launched_game; extern DPSESSIONDESC2 Directplay_sessions[MAX_DP_GAMES]; extern int Num_directplay_games; extern uint32_t Pending_dp_conn[MAX_PENDING_NEW_CONNECTIONS]; // This is called when a game is started, so Directplay will be happy int dp_StartGame(char *gamename); // This is called when the game ends, to tell directplay the game is over void dp_EndGame(); // This is called to request a list of ongoig direct play games int dp_ListDirectPlayGames(); // Send a packet to a direct play user int dp_DirectPlaySend(network_address *who_to, uint8_t *data, int len, bool reliable); // This function will look for incoming messages, and dispatch them accordingly void dp_DirectPlayDispatch(); // Initialize stuff int dp_InitDirectPlay(char *conn_name, void *parms = nullptr, int num_elements = 0); // Shutdown things void dp_ShutdownDirectPlay(); // Destroy a player object void dp_DirectPlayDestroyPlayer(DPID who); // Join a network game int dp_DirectPlayJoinGame(LPDPSESSIONDESC2 session); // Call this function with size set to 0, and it will fill in size with // the amount of buffer space you need // Otherwise, it will fill in the buffer with a bunch of null delimited // strings, with a double null at the end. int dp_GetModemChoices(char *buffer, LPDWORD size); // Register a DirectPlay lobby aware application // Use this so a directplay lobby provider such as zone.com can launch the game // // Parameters: // appname The non-localized name of the application (ie. "Descent 3") DON'T LOCALIZE THIS! IT IS AN ID // exefile Executable file name (without path) // exepath Path to executable file // arguments Any command line arguments the app needs // workingdir The Working directory for the application // description Localized description of the application void dp_RegisterLobbyApplication(char *appname, char *exefile, char *exepath, char *arguments, char *workingdir, char *description); // Returns TRUE if the game was launched from a lobby bool dp_DidLobbyLaunchGame(); // Autoconnects to a game or starts one, based on the directplay lobby stuff bool dp_AutoConnect(); #endif