/* -*-mode: C; fill-column: 78; c-basic-offset: 4; -*- */ /* * Copyright 2005 by Eric House (fixin@peak.org). All rights reserved. * * 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 2 * 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, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #ifndef _XWRELAY_H_ #define _XWRELAY_H_ /* This file is meant to be included by both linux code that doesn't include xptypes and from Crosswords client code.*/ /* Set if device is acting a server; cleared if as client */ #define FLAGS_SERVER_BIT 0x01 typedef enum { XWRELAY_NONE /* 0 is an illegal value */ , XWRELAY_GAME_CONNECT /* Sent from device to relay to establish connection to relay. Format: flags: 1; cookieLen: 1; cookie: ; hostID: 2. connectionID: 2. */ , XWRELAY_GAME_RECONNECT /* Connect using ID rather than cookie. Used by a device that's lost its connection to a game in progress. Once a game is locked this is the only way a host can get (back) in. */ , XWRELAY_GAME_DISCONNECT /* Tell the relay that we're gone for this game. After this message is sent, the host can reconnect on the same socket for a new game. Format: cookieID: 4; srcID: 2 */ , XWRELAY_CONNECTRESP /* Sent from relay to device in response to XWRELAY_CONNECT or XWRELAY_RECONNECT. Format: heartbeat_seconds: 2; connectionID: 2; */ , XWRELAY_OTHERCONNECT /* Another device has [re]joined your game. Format: ??? */ , XWRELAY_DISCONNECT_YOU /* Sent from relay when existing connection is terminated. Format: errorCode: 1 */ , XWRELAY_DISCONNECT_OTHER /* Another device has left the game. Format: errorCode: 1; lostHostId: 2 */ , XWRELAY_CONNECTDENIED /* The relay says go away. Format: reason code: 1 */ , XWRELAY_HEARTBEAT /* Sent in either direction. Format: cookieID: 4; srcID: 2 */ , XWRELAY_MSG_FROMRELAY /* Sent from relay to device. Format: cookieID: 4; src_hostID: 2; dest_hostID: 2; data */ , XWRELAY_MSG_TORELAY /* Sent from device to relay. Format: connectionID: 2; src_hostID: 2; dest_hostID: 2 */ } XWRelayMsg; #ifndef CANT_DO_TYPEDEF typedef unsigned char XWRELAY_Cmd; #endif #define HOST_ID_NONE 0 #define HOST_ID_SERVER 1 #define MAX_COOKIE_LEN 15 #define MAX_MSG_LEN 256 /* 100 is more like it */ #define XWRELAY_PROTO_VERSION 0x01 /* Errors passed with denied */ typedef enum { XWRELAY_ERROR_NONE ,XWRELAY_ERROR_BADPROTO ,XWRELAY_ERROR_RELAYBUSY ,XWRELAY_ERROR_SHUTDOWN /* relay's going down */ ,XWRELAY_ERROR_TIMEOUT /* Other players didn't show */ ,XWRELAY_ERROR_HEART_YOU /* Haven't heard from somebody in too long */ ,XWRELAY_ERROR_HEART_OTHER /* Haven't heard from other in too long */ ,XWRELAY_ERROR_LOST_OTHER /* Generic other-left-we-dunno-why error */ ,XWRELAY_ERROR_LASTERR } XWREASON; typedef unsigned int CookieID; #define COOKIE_ID_NONE 0L #endif