2007-01-15 12:09:25 -08:00
|
|
|
/*
|
|
|
|
This file is part of Warzone 2100.
|
|
|
|
Copyright (C) 1999-2004 Eidos Interactive
|
|
|
|
Copyright (C) 2005-2007 Warzone Resurrection Project
|
|
|
|
|
|
|
|
Warzone 2100 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 2 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
Warzone 2100 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 Warzone 2100; if not, write to the Free Software
|
|
|
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*/
|
2007-06-28 10:47:08 -07:00
|
|
|
/*
|
|
|
|
* Netplay.h
|
|
|
|
*
|
|
|
|
* Alex Lee sep97.
|
2006-09-13 02:09:05 -07:00
|
|
|
*/
|
2007-06-28 10:47:08 -07:00
|
|
|
|
|
|
|
#ifndef _netplay_h
|
|
|
|
#define _netplay_h
|
|
|
|
|
2007-08-08 11:50:28 -07:00
|
|
|
#include "nettypes.h"
|
|
|
|
|
2007-06-28 10:47:08 -07:00
|
|
|
// ////////////////////////////////////////////////////////////////////////
|
|
|
|
// Include this file in your game to add multiplayer facilities.
|
|
|
|
|
|
|
|
// Constants
|
|
|
|
#define MaxMsgSize 8000 // max size of a message in bytes.
|
|
|
|
#define StringSize 64 // size of strings used.
|
|
|
|
#define MaxGames 12 // max number of concurrently playable games to allow.
|
|
|
|
|
|
|
|
#define SESSION_JOINDISABLED 1
|
|
|
|
|
|
|
|
typedef struct { //Available game storage... JUST FOR REFERENCE!
|
2007-05-20 15:55:12 -07:00
|
|
|
int32_t dwSize;
|
|
|
|
int32_t dwFlags;
|
2005-12-02 13:45:42 -08:00
|
|
|
char host[16]; // host ip address
|
2007-05-20 15:55:12 -07:00
|
|
|
int32_t dwMaxPlayers;
|
|
|
|
int32_t dwCurrentPlayers;
|
|
|
|
int32_t dwUser1;
|
|
|
|
int32_t dwUser2;
|
|
|
|
int32_t dwUser3;
|
|
|
|
int32_t dwUser4;
|
2007-06-28 10:47:08 -07:00
|
|
|
} SESSIONDESC;
|
|
|
|
|
|
|
|
// Games Storage Structures
|
|
|
|
typedef struct {
|
2006-09-13 02:09:05 -07:00
|
|
|
char name[StringSize];
|
2007-06-28 10:47:08 -07:00
|
|
|
SESSIONDESC desc;
|
|
|
|
} GAMESTRUCT;
|
|
|
|
|
|
|
|
// ////////////////////////////////////////////////////////////////////////
|
|
|
|
// Message information. ie. the packets sent between machines.
|
|
|
|
|
|
|
|
#define NET_ALL_PLAYERS 255
|
|
|
|
|
|
|
|
typedef struct {
|
2007-06-24 06:38:22 -07:00
|
|
|
uint16_t size; // used size of body
|
|
|
|
uint8_t type; // type of packet
|
|
|
|
uint8_t destination; // player to send to, or NET_ALL_PLAYERS
|
2008-01-02 09:08:29 -08:00
|
|
|
uint8_t source; // player it is sent from
|
2007-06-28 10:47:08 -07:00
|
|
|
char body[MaxMsgSize];
|
2007-08-08 11:50:28 -07:00
|
|
|
BOOL status; // If the packet compiled or not (this is _not_ sent!)
|
2007-06-24 06:38:22 -07:00
|
|
|
} NETMSG;
|
2007-06-28 10:47:08 -07:00
|
|
|
|
|
|
|
#define FILEMSG 254 // a file packet
|
|
|
|
|
|
|
|
// ////////////////////////////////////////////////////////////////////////
|
|
|
|
// Player information. Update using NETplayerinfo
|
|
|
|
typedef struct {
|
2007-05-20 15:55:12 -07:00
|
|
|
uint32_t dpid;
|
2007-06-28 10:47:08 -07:00
|
|
|
char name[StringSize];
|
2007-05-20 15:55:12 -07:00
|
|
|
|
|
|
|
// These are actually boolean values so uint8_t would suffice just as well.
|
|
|
|
// The problem is however that these where previously declared as BOOL,
|
|
|
|
// which is typedef'd as int, which on most platforms is equal to uint32_t.
|
|
|
|
uint32_t bHost;
|
2007-06-28 10:47:08 -07:00
|
|
|
} PLAYER;
|
|
|
|
|
|
|
|
// ////////////////////////////////////////////////////////////////////////
|
|
|
|
// all the luvly Netplay info....
|
|
|
|
typedef struct {
|
|
|
|
GAMESTRUCT games[MaxGames]; // the collection of games
|
2008-02-11 08:23:20 -08:00
|
|
|
PLAYER players[MAX_PLAYERS]; // the array of players.
|
2007-05-20 15:55:12 -07:00
|
|
|
uint32_t playercount; // number of players in game.
|
|
|
|
uint32_t dpidPlayer; // ID of player created
|
2007-06-28 10:47:08 -07:00
|
|
|
|
2007-05-20 15:55:12 -07:00
|
|
|
// booleans
|
|
|
|
uint32_t bComms; // actually do the comms?
|
|
|
|
uint32_t bHost; // TRUE if we are hosting the session
|
2007-07-15 06:48:22 -07:00
|
|
|
} NETPLAY;
|
2007-06-28 10:47:08 -07:00
|
|
|
|
|
|
|
// ////////////////////////////////////////////////////////////////////////
|
|
|
|
// variables
|
|
|
|
|
|
|
|
extern NETPLAY NetPlay;
|
|
|
|
|
2007-08-08 11:50:28 -07:00
|
|
|
extern NETMSG NetMsg;
|
|
|
|
|
2007-06-28 10:47:08 -07:00
|
|
|
// ////////////////////////////////////////////////////////////////////////
|
|
|
|
// functions available to you.
|
2006-09-13 02:09:05 -07:00
|
|
|
extern BOOL NETinit(BOOL bFirstCall); //init(guid can be NULL)
|
2006-11-03 17:11:26 -08:00
|
|
|
extern BOOL NETsend(NETMSG *msg, UDWORD player, BOOL guarantee);// send to player, possibly guaranteed
|
2007-06-28 10:47:08 -07:00
|
|
|
extern BOOL NETbcast(NETMSG *msg,BOOL guarantee); // broadcast to everyone, possibly guaranteed
|
|
|
|
extern BOOL NETrecv(NETMSG *msg); // recv a message if possible
|
|
|
|
|
2008-01-11 13:39:41 -08:00
|
|
|
extern UBYTE NETsendFile(BOOL newFile, char *fileName, UDWORD player); // send file chunk.
|
|
|
|
extern UBYTE NETrecvFile(void); // recv file chunk
|
2007-06-28 10:47:08 -07:00
|
|
|
|
2006-11-03 17:11:26 -08:00
|
|
|
extern BOOL NETclose (void); // close current game
|
|
|
|
extern BOOL NETshutdown(void); // leave the game in play.
|
2007-06-28 10:47:08 -07:00
|
|
|
|
2006-09-13 02:09:05 -07:00
|
|
|
extern UDWORD NETgetBytesSent(void); // return bytes sent/recv. call regularly for good results
|
|
|
|
extern UDWORD NETgetPacketsSent(void); // return packets sent/recv. call regularly for good results
|
|
|
|
extern UDWORD NETgetBytesRecvd(void); // return bytes sent/recv. call regularly for good results
|
|
|
|
extern UDWORD NETgetPacketsRecvd(void); // return packets sent/recv. call regularly for good results
|
|
|
|
extern UDWORD NETgetRecentBytesSent(void); // more immediate functions.
|
|
|
|
extern UDWORD NETgetRecentPacketsSent(void);
|
|
|
|
extern UDWORD NETgetRecentBytesRecvd(void);
|
2007-06-28 10:47:08 -07:00
|
|
|
|
|
|
|
// from netjoin.c
|
2006-11-04 15:16:51 -08:00
|
|
|
extern SDWORD NETgetGameFlags(UDWORD flag); // return one of the four flags(dword) about the game.
|
|
|
|
extern SDWORD NETgetGameFlagsUnjoined(UDWORD gameid, UDWORD flag); // return one of the four flags(dword) about the game.
|
|
|
|
extern BOOL NETsetGameFlags(UDWORD flag, SDWORD value); // set game flag(1-4) to value.
|
2006-09-13 02:09:05 -07:00
|
|
|
extern BOOL NEThaltJoining(void); // stop new players joining this game
|
2007-05-13 10:31:12 -07:00
|
|
|
extern BOOL NETfindGame(void); // find games being played(uses GAME_GUID);
|
2006-11-03 17:11:26 -08:00
|
|
|
extern BOOL NETjoinGame(UDWORD gameNumber, const char* playername); // join game given with playername
|
|
|
|
extern BOOL NEThostGame(const char* SessionName, const char* PlayerName,// host a game
|
2006-11-04 15:16:51 -08:00
|
|
|
SDWORD one, SDWORD two, SDWORD three, SDWORD four, UDWORD plyrs);
|
2007-06-28 10:47:08 -07:00
|
|
|
|
|
|
|
//from netusers.c
|
2006-09-13 02:09:05 -07:00
|
|
|
extern UDWORD NETplayerInfo(void); // count players in this game.
|
2007-06-28 10:47:08 -07:00
|
|
|
extern BOOL NETchangePlayerName(UDWORD dpid, char *newName);// change a players name.
|
|
|
|
|
2007-08-08 11:50:28 -07:00
|
|
|
extern void NETsetPacketDir(PACKETDIR dir);
|
|
|
|
extern PACKETDIR NETgetPacketDir(void);
|
|
|
|
|
2006-04-08 12:14:30 -07:00
|
|
|
#include "netlog.h"
|
|
|
|
|
2007-04-21 06:46:28 -07:00
|
|
|
extern void NETsetMasterserverName(const char* hostname);
|
|
|
|
extern void NETsetMasterserverPort(unsigned int port);
|
|
|
|
extern void NETsetGameserverPort(unsigned int port);
|
2007-06-28 10:47:08 -07:00
|
|
|
|
|
|
|
#endif
|