Man Linux: Main Page and Category List

NAME

       ggzcore.h - The interface for the ggzcore library used by GGZ clients.

SYNOPSIS

       #include <stdarg.h>
       #include <sys/types.h>
       #include <ggz_common.h>

   Defines
       #define GGZCORE_VERSION_MAJOR   0
       #define GGZCORE_VERSION_MINOR   0
       #define GGZCORE_VERSION_MICRO   11
       #define GGZCORE_VERSION_IFACE   ’7:0:0’
       #define GGZCORE_DBG_CONF   ’GGZCORE:CONF’
           ggz_debug debugging type for configuration system.
       #define GGZCORE_DBG_GAME   ’GGZCORE:GAME’
           ggz_debug debugging type for game communication.
       #define GGZCORE_DBG_HOOK   ’GGZCORE:HOOK’
           ggz_debug debugging type for hook system.
       #define GGZCORE_DBG_MODULE   ’GGZCORE:MODULE’
           ggz_debug debugging type for accessing modules.
       #define GGZCORE_DBG_NET   ’GGZCORE:NET’
           ggz_debug debugging type for network interaction.
       #define GGZCORE_DBG_POLL   ’GGZCORE:POLL’
           ggz_debug debugging type for debugging while polling.
       #define GGZCORE_DBG_ROOM   ’GGZCORE:ROOM’
           ggz_debug debugging type for room events and data.
       #define GGZCORE_DBG_SERVER   ’GGZCORE:SERVER’
           ggz_debug debugging type for server events and data.
       #define GGZCORE_DBG_STATE   ’GGZCORE:STATE’
           ggz_debug debugging type for state changes.
       #define GGZCORE_DBG_TABLE   ’GGZCORE:TABLE’
           ggz_debug debugging type for table data.
       #define GGZCORE_DBG_XML   ’GGZCORE:XML’
           ggz_debug debugging type for XML processing.
       #define ggzcore_server_get_channel(server)   (-1)
           Deprecated function. Do not use.
       #define ggzcore_server_create_channel(server)   (void)0
           Deprecated function. Do not use.
       #define ggzcore_module_launch(m)   ((int)(-1))
       #define ggzcore_game_set_server_fd(game, fd)   (void)0
           Deprecated function. Do not use.

   Typedefs
       typedef _GGZOptions GGZOptions
       typedef GGZHookReturn(* GGZHookFunc )(unsigned int id, const void
           *event_data, const void *user_data)
       typedef void(* GGZDestroyFunc )(void *data)
           GGZ object destroy function type.
       typedef _GGZServer GGZServer
           A server object containing all information about a connection.
       typedef _GGZRoom GGZRoom
           Contains information about a single room on a server.
       typedef _GGZPlayer GGZPlayer
           Contains information about a single player.
       typedef _GGZTable GGZTable
           Contains information about a single table.
       typedef _GGZGameType GGZGameType
           Contains information about a _game type_.
       typedef _GGZModule GGZModule
           Contains information about a single module. A game module, on the
           client, is an executable designed to play a game. Each game type
           may have many modules that play it.
       typedef _GGZGame GGZGame
           Contains information about a single game table. This contains
           information about a table we are present at or are about to launch.
           It is thus associated with both a GGZTable and a GGZModule.

   Enumerations
       enum GGZOptionFlags { GGZ_OPT_PARSER =  0x0001, GGZ_OPT_MODULES =
           0x0002, GGZ_OPT_THREADED_IO =  0x0004, GGZ_OPT_EMBEDDED =  0x0008,
           GGZ_OPT_RECONNECT =  0x0010 }
       enum GGZHookReturn { GGZ_HOOK_OK, GGZ_HOOK_REMOVE, GGZ_HOOK_ERROR,
           GGZ_HOOK_CRISIS }
       enum GGZLoginType { GGZ_LOGIN, GGZ_LOGIN_GUEST, GGZ_LOGIN_NEW }
       enum GGZServerEvent { GGZ_CONNECTED, GGZ_CONNECT_FAIL, GGZ_NEGOTIATED,
           GGZ_NEGOTIATE_FAIL, GGZ_LOGGED_IN, GGZ_LOGIN_FAIL, GGZ_MOTD_LOADED,
           GGZ_ROOM_LIST, GGZ_TYPE_LIST, GGZ_SERVER_PLAYERS_CHANGED,
           GGZ_ENTERED, GGZ_ENTER_FAIL, GGZ_LOGOUT, GGZ_NET_ERROR,
           GGZ_PROTOCOL_ERROR, GGZ_CHAT_FAIL, GGZ_STATE_CHANGE,
           GGZ_CHANNEL_CONNECTED, GGZ_CHANNEL_READY, GGZ_CHANNEL_FAIL,
           GGZ_NUM_SERVER_EVENTS }
       enum GGZRoomEvent { GGZ_PLAYER_LIST, GGZ_TABLE_LIST, GGZ_CHAT_EVENT,
           GGZ_ROOM_ENTER, GGZ_ROOM_LEAVE, GGZ_TABLE_UPDATE,
           GGZ_TABLE_LAUNCHED, GGZ_TABLE_LAUNCH_FAIL, GGZ_TABLE_JOINED,
           GGZ_TABLE_JOIN_FAIL, GGZ_TABLE_LEFT, GGZ_TABLE_LEAVE_FAIL,
           GGZ_PLAYER_LAG, GGZ_PLAYER_STATS, GGZ_PLAYER_COUNT }
       enum GGZGameEvent { GGZ_GAME_LAUNCHED, GGZ_GAME_LAUNCH_FAIL,
           GGZ_GAME_NEGOTIATED, GGZ_GAME_NEGOTIATE_FAIL, GGZ_GAME_PLAYING }
       enum GGZStateID { GGZ_STATE_OFFLINE, GGZ_STATE_CONNECTING,
           GGZ_STATE_RECONNECTING, GGZ_STATE_ONLINE, GGZ_STATE_LOGGING_IN,
           GGZ_STATE_LOGGED_IN, GGZ_STATE_ENTERING_ROOM, GGZ_STATE_IN_ROOM,
           GGZ_STATE_BETWEEN_ROOMS, GGZ_STATE_LAUNCHING_TABLE,
           GGZ_STATE_JOINING_TABLE, GGZ_STATE_AT_TABLE,
           GGZ_STATE_LEAVING_TABLE, GGZ_STATE_LOGGING_OUT }
           The states a server connection may be in.
       enum GGZModuleEnvironment { GGZ_ENVIRONMENT_PASSIVE,
           GGZ_ENVIRONMENT_CONSOLE, GGZ_ENVIRONMENT_FRAMEBUFFER,
           GGZ_ENVIRONMENT_XWINDOW, GGZ_ENVIRONMENT_XFULLSCREEN }
           The environment a game frontend expects.

   Functions
       int ggzcore_init (GGZOptions options)
       void ggzcore_reload (void)
       void ggzcore_destroy (void)
       GGZServer * ggzcore_server_new (void)
           Create a new server object.
       int ggzcore_server_reset (GGZServer *server)
           Reset the server object.
       int ggzcore_server_add_event_hook (GGZServer *server, const
           GGZServerEvent event, const GGZHookFunc func)
           Register a callback handler for a server event.
       int ggzcore_server_add_event_hook_full (GGZServer *server, const
           GGZServerEvent event, const GGZHookFunc func, const void *data)
           Register a callback handler for a server event.
       int ggzcore_server_remove_event_hook (GGZServer *server, const
           GGZServerEvent event, const GGZHookFunc func)
           Remove a single hook function from an events hook list.
       int ggzcore_server_remove_event_hook_id (GGZServer *server, const
           GGZServerEvent event, const unsigned int hook_id)
           Remove a hook function with given ID from the events hook list.
       int ggzcore_server_set_hostinfo (GGZServer *server, const char *host,
           const unsigned int port, const unsigned int use_tls)
           Set host info for connecting to the server.
       int ggzcore_server_set_logininfo (GGZServer *server, const GGZLoginType
           type, const char *handle, const char *password, const char *email)
           Set login info for logging in to the server.
       int ggzcore_server_log_session (GGZServer *server, const char
           *filename)
           Initiate logging of ggzcore events.
       const char * ggzcore_server_get_host (const GGZServer *server)
           Get the hostname of the server.
       int ggzcore_server_get_port (const GGZServer *server)
           Get the port of the server.
       GGZLoginType ggzcore_server_get_type (const GGZServer *server)
           Get the login type being used for this server.
       const char * ggzcore_server_get_handle (const GGZServer *server)
           Get the handle being used for this server.
       const char * ggzcore_server_get_password (const GGZServer *server)
           Get the password being used for this server.
       int ggzcore_server_get_fd (const GGZServer *server)
           Get the socket used for connection with the server.
       GGZStateID ggzcore_server_get_state (const GGZServer *server)
           Get the state of the server connection.
       int ggzcore_server_get_tls (const GGZServer *server)
           Get the current TLS status of this server.
       int ggzcore_server_get_num_players (const GGZServer *server)
           Get the total number of players on the server.
       int ggzcore_server_get_num_rooms (const GGZServer *server)
           Return the number of rooms on the server, or -1 on error.
       GGZRoom * ggzcore_server_get_cur_room (const GGZServer *server)
           Return the current room, or NULL if there is none.
       GGZRoom * ggzcore_server_get_nth_room (const GGZServer *server, const
           unsigned int num)
           Return the nth room on the server, or NULL on error.
       int ggzcore_server_get_num_gametypes (const GGZServer *server)
           Return the overall number of game types on the server.
       GGZGameType * ggzcore_server_get_nth_gametype (const GGZServer *server,
           const unsigned int num)
           Get the nth gametype, or NULL on error.
       GGZGame * ggzcore_server_get_cur_game (const GGZServer *server)
           Return the players current game.
       int ggzcore_server_is_online (const GGZServer *server)
           Return TRUE iff the server is online (connected?).
       int ggzcore_server_is_logged_in (const GGZServer *server)
           Return TRUE iff we are logged into the server.
       int ggzcore_server_is_in_room (const GGZServer *server)
           Return TRUE iff we are in a room on the server.
       int ggzcore_server_is_at_table (const GGZServer *server)
           Return TRUE iff we are at a table on the server.
       int ggzcore_server_connect (GGZServer *server)
           Connect to the server.
       int ggzcore_server_login (GGZServer *server)
           Log in to the server.
       int ggzcore_server_motd (GGZServer *server)
           Request the MOTD from the server.
       int ggzcore_server_list_rooms (GGZServer *server, const int type, const
           char verbose)
           Request room list.
       int ggzcore_server_list_gametypes (GGZServer *server, const char
           verbose)
           Request game type list.
       int ggzcore_server_join_room (GGZServer *server, const unsigned int
           room)
           Join a room on the server.
       int ggzcore_server_logout (GGZServer *server)
           Log out of a server.
       int ggzcore_server_disconnect (GGZServer *server)
           Disconnect from a server after having logged out.
       int ggzcore_server_data_is_pending (GGZServer *server)
           Check for data pending from the server socket.
       int ggzcore_server_read_data (GGZServer *server, int fd)
           Read data for the server on the specified FD.
       void ggzcore_server_free (GGZServer *server)
           Free GGZServer object and accompanying data.
       GGZRoom * ggzcore_room_new (void)
           Allocate space for a new room object.
       int ggzcore_room_init (GGZRoom *room, GGZServer *server, const unsigned
           int id, const char *name, const unsigned int game, const char
           *desc)
           Initialize room object.
       void ggzcore_room_free (GGZRoom *room)
           De-allocate room object and its children.
       GGZServer * ggzcore_room_get_server (GGZRoom *room)
           Return the server for this room (or NULL on error).
       int ggzcore_room_get_id (const GGZRoom *room)
           Return the ID number of the room (or negative on error).
       char * ggzcore_room_get_name (GGZRoom *room)
           Return the name of the room (or NULL on error).
       char * ggzcore_room_get_desc (GGZRoom *room)
           Return the description of the room (or NULL on error).
       GGZGameType * ggzcore_room_get_gametype (GGZRoom *room)
           Return the type of game played in this room (or NULL on error).
       int ggzcore_room_get_num_players (GGZRoom *room)
           Return the number of players in the room (or negative on error).
       GGZPlayer * ggzcore_room_get_nth_player (GGZRoom *room, const unsigned
           int num)
           Return the nth player in the room (or NULL on error).
       int ggzcore_room_get_num_tables (GGZRoom *room)
           Return the number of tables in the room (or negative on error).
       GGZTable * ggzcore_room_get_nth_table (GGZRoom *room, const unsigned
           int num)
           Return the nth table in the room (or NULL on error).
       GGZTable * ggzcore_room_get_table_by_id (GGZRoom *room, const unsigned
           int id)
           Return the table in this room with matching ID (NULL on error).
       int ggzcore_room_add_event_hook (GGZRoom *room, const GGZRoomEvent
           event, const GGZHookFunc func)
           Register a handler (hook) for the room event.
       int ggzcore_room_add_event_hook_full (GGZRoom *room, const GGZRoomEvent
           event, const GGZHookFunc func, const void *data)
           Register a handler (hook) for thee room event, with data.
       int ggzcore_room_remove_event_hook (GGZRoom *room, const GGZRoomEvent
           event, const GGZHookFunc func)
           Remove a hook from an event.
       int ggzcore_room_remove_event_hook_id (GGZRoom *room, const
           GGZRoomEvent event, const unsigned int hook_id)
           Remove a hook from an event, by ID.
       int ggzcore_room_list_players (GGZRoom *room)
           Call to request a list of players in the room.
       int ggzcore_room_list_tables (GGZRoom *room, const int type, const char
           global)
           Call to request a list of tables in the room.
       int ggzcore_room_chat (GGZRoom *room, const GGZChatType opcode, const
           char *player, const char *msg)
           Chat!
       int ggzcore_room_launch_table (GGZRoom *room, GGZTable *table)
           Launch a table in the room.
       int ggzcore_room_join_table (GGZRoom *room, const unsigned int
           table_id, int spectator)
           Join a table in the room, so that you can then play at it.
       int ggzcore_room_leave_table (GGZRoom *room, int force)
           Leave the table you are currently playing at.
       char * ggzcore_player_get_name (const GGZPlayer *player)
           Return the name of the player.
       GGZPlayerType ggzcore_player_get_type (const GGZPlayer *player)
           Return the type of the player (admin/registered/guest).
       GGZRoom * ggzcore_player_get_room (const GGZPlayer *player)
           Return the players room, or NULL if none.
       GGZTable * ggzcore_player_get_table (const GGZPlayer *player)
           Return the players table, or NULL if none.
       int ggzcore_player_get_lag (const GGZPlayer *player)
           Return the players lag class (1..5).
       int ggzcore_player_get_record (const GGZPlayer *player, int *wins, int
           *losses, int *ties, int *forfeits)
           Get the players win-loss record.
       int ggzcore_player_get_rating (const GGZPlayer *player, int *rating)
           Get the players rating.
       int ggzcore_player_get_ranking (const GGZPlayer *player, int *ranking)
           Get the players ranking.
       int ggzcore_player_get_highscore (const GGZPlayer *player, int
           *highscore)
           Get the players highscore.
       GGZTable * ggzcore_table_new (void)
           Create a new table object.
       int ggzcore_table_init (GGZTable *table, const GGZGameType *gametype,
           const char *desc, const unsigned int num_seats)
           Set data on a table object.
       void ggzcore_table_free (GGZTable *table)
           Free the table object.
       int ggzcore_table_set_seat (GGZTable *table, const unsigned int seat,
           GGZSeatType type, const char *name)
           Set a seat type at a table, pre-launch.
       int ggzcore_table_remove_player (GGZTable *table, char *name)
           Find and remove the player from the table.
       int ggzcore_table_get_id (const GGZTable *table)
           Return the ID of the table.
       const GGZRoom * ggzcore_table_get_room (const GGZTable *table)
           Return the room this table is in.
       const GGZGameType * ggzcore_table_get_type (const GGZTable *table)
           Return the game type of the table.
       const char * ggzcore_table_get_desc (const GGZTable *table)
           Return the tables description (or NULL).
       GGZTableState ggzcore_table_get_state (const GGZTable *table)
           Return the state of the table.
       int ggzcore_table_get_num_seats (const GGZTable *table)
           Return the number of seats at the table.
       int ggzcore_table_set_desc (GGZTable *table, const char *desc)
           Set the table description.
       int ggzcore_table_get_seat_count (const GGZTable *table, GGZSeatType
           type)
           Count the seats of the given type.
       const char * ggzcore_table_get_nth_player_name (const GGZTable *table,
           const unsigned int num)
           Return the name of a player at the table, or NULL on error.
       int ggzcore_table_get_num_spectator_seats (const GGZTable *table)
           Return the number of spectator seats at the table, or -1.
       const char * ggzcore_table_get_nth_spectator_name (const GGZTable
           *table, const unsigned int num)
           Return the name of the nth spectator, or NULL if seat is empty.
       GGZSeatType ggzcore_table_get_nth_player_type (const GGZTable *table,
           const unsigned int num)
           Return the type of a player at the table, or GGZ_PLAYER_NONE on
           error.
       unsigned int ggzcore_gametype_get_id (const GGZGameType *type)
           Get the ID of this gametype.
       const char * ggzcore_gametype_get_name (const GGZGameType *type)
           Get the name of the game type.
       const char * ggzcore_gametype_get_prot_engine (const GGZGameType *type)
           Get the protocol engine used by the game type.
       const char * ggzcore_gametype_get_prot_version (const GGZGameType
           *type)
           Get the version of the protocol the game uses.
       const char * ggzcore_gametype_get_version (const GGZGameType *type)
           Get the version of the game itself.
       const char * ggzcore_gametype_get_author (const GGZGameType *type)
           Get the author of the game.
       const char * ggzcore_gametype_get_url (const GGZGameType *type)
           Get a URL for more info about the game.
       const char * ggzcore_gametype_get_desc (const GGZGameType *type)
           Get a description of the game.
       int ggzcore_gametype_get_max_players (const GGZGameType *type)
           Get the maximum number of players the game can support.
       int ggzcore_gametype_get_max_bots (const GGZGameType *type)
           Get the maximum number of bots the game can support.
       int ggzcore_gametype_get_spectators_allowed (const GGZGameType *type)
           Return TRUE iff spectators are allowed for this game type.
       int ggzcore_gametype_num_players_is_valid (const GGZGameType *type,
           unsigned int num)
           Return TRUE iff the given number of players is valid.
       int ggzcore_gametype_num_bots_is_valid (const GGZGameType *type,
           unsigned int num)
           Return TRUE iff the given number of bots is valid.
       int ggzcore_conf_initialize (const char *g_path, const char *u_path)
       int ggzcore_conf_write_string (const char *section, const char *key,
           const char *value)
       int ggzcore_conf_write_int (const char *section, const char *key, int
           value)
       int ggzcore_conf_write_list (const char *section, const char *key, int
           argc, char **argv)
       char * ggzcore_conf_read_string (const char *section, const char *key,
           const char *def)
       int ggzcore_conf_read_int (const char *section, const char *key, int
           def)
       int ggzcore_conf_read_list (const char *section, const char *key, int
           *argcp, char ***argvp)
       int ggzcore_conf_remove_section (const char *section)
       int ggzcore_conf_remove_key (const char *section, const char *key)
       int ggzcore_conf_commit (void)
       unsigned int ggzcore_module_get_num (void)
           This returns the number of registered modules.
       int ggzcore_module_add (const char *name, const char *version, const
           char *prot_engine, const char *prot_version, const char *author,
           const char *frontend, const char *url, const char *exe_path, const
           char *icon_path, const char *help_path, GGZModuleEnvironment
           environment)
       int ggzcore_module_get_num_by_type (const char *game, const char
           *engine, const char *version)
           Returns how many modules support this game and protocol.
       GGZModule * ggzcore_module_get_nth_by_type (const char *game, const
           char *engine, const char *version, const unsigned int num)
           Returns n-th module that supports this game and protocol.
       const char * ggzcore_module_get_name (GGZModule *module)
           Return the name of the module.
       const char * ggzcore_module_get_version (GGZModule *module)
           Return the (game?) version of the module.
       const char * ggzcore_module_get_prot_engine (GGZModule *module)
           Return the name of the modules protocol engine.
       const char * ggzcore_module_get_prot_version (GGZModule *module)
           Return the version of the modules protocol engine.
       const char * ggzcore_module_get_author (GGZModule *module)
           Return the author of the module.
       const char * ggzcore_module_get_frontend (GGZModule *module)
           Return the modules frontend type.
       const char * ggzcore_module_get_url (GGZModule *module)
           Return the URL associated with the module.
       const char * ggzcore_module_get_icon_path (GGZModule *module)
       const char * ggzcore_module_get_help_path (GGZModule *module)
           Return the help path of the module (?).
       char ** ggzcore_module_get_argv (GGZModule *module)
           Return the executable arguments for the module. See exec().
       GGZModuleEnvironment ggzcore_module_get_environment (GGZModule *module)
           Return the preferred environment type.
       GGZGame * ggzcore_game_new (void)
           Make a new game object.
       int ggzcore_game_init (GGZGame *game, GGZServer *server, GGZModule
           *module)
           Initialize the game object.
       void ggzcore_game_free (GGZGame *game)
           Free the game object.
       int ggzcore_game_add_event_hook (GGZGame *game, const GGZGameEvent
           event, const GGZHookFunc func)
           Register a hook for a game event.
       int ggzcore_game_add_event_hook_full (GGZGame *game, const GGZGameEvent
           event, const GGZHookFunc func, const void *data)
           Register a hook for a game event.
       int ggzcore_game_remove_event_hook (GGZGame *game, const GGZGameEvent
           event, const GGZHookFunc func)
           Remove a hook from a game event.
       int ggzcore_game_remove_event_hook_id (GGZGame *game, const
           GGZGameEvent event, const unsigned int hook_id)
           Remove a specified hook from a game event.
       int ggzcore_game_get_control_fd (GGZGame *game)
           Return the control (ggzmod) socket for the game.
       GGZModule * ggzcore_game_get_module (GGZGame *game)
           Return the module set for the game.
       int ggzcore_game_launch (GGZGame *game)
           Launch thee game!
       int ggzcore_game_read_data (GGZGame *game)
           Read data from the game. When data is pending on the control
           socket, call this function.

Detailed Description

       The interface for the ggzcore library used by GGZ clients.

Define Documentation

   #define ggzcore_module_launch(m)   ((int)(-1))
       This attempts to launch the specified module and returns 0 if
       successful or -1 on error.

Typedef Documentation

   typedef void(* GGZDestroyFunc)(void *data)
       GGZ object destroy function type.

       Todo
           This is not currently used.

   typedef struct _GGZGameType GGZGameType
       Contains information about a _game type_.

       Note:
           Each room has one game type; a game may be used in multiple rooms.

   typedef GGZHookReturn(* GGZHookFunc)(unsigned int id, const void
       *event_data, const void *user_data)
       GGZ Event hook function type, used as a vallback for events

   typedef struct _GGZOptions  GGZOptions
       Options structure for ggzcore library

Enumeration Type Documentation

   enum GGZGameEvent
       A GGZGameEvent is an event associated with the game, that is triggered
       by a communication from the server or from the game. When a game event
       occurs, the associated event handle will be called, and will be passed
       the event data (a void*) along with the (optional) user data. All game
       events apply to the current game. Game events are usually triggered by
       calling ggzcore_server_read_data or ggzcore_game_read_data.

       See also:
           ggzcore_game_add_event_hook

           ggzcore_server_read_data

       Enumeration values:

       GGZ_GAME_LAUNCHED
              A game was launched by the player (you). After this the core
              client should call ggzcore_game_get_control_fd, monitor the
              socket that function returns, and call ggzcore_game_read_data
              when there is data pending. This event is triggered inside of
              ggzcore_game_launch.

       Parameters:
           data NULL

       See also:
           ggzcore_game_launch

       GGZ_GAME_LAUNCH_FAIL
              Your game launch has failed. Triggered instead of
              GGZ_GAME_LAUNCHED when there’s a failure somewhere.

       Parameters:
           data NULL

       See also:
           GGZ_GAME_LAUNCHED

       GGZ_GAME_NEGOTIATED
              Negotiation with server was successful. This should happen some
              time after the launch succeeds. The core client need do nothing
              at this point.

       Parameters:
           data NULL

       GGZ_GAME_NEGOTIATE_FAIL
              Negotiation was not successful, game launch failed.

       Todo
           Currently this can’t actually happen...

       GGZ_GAME_PLAYING
              Game reached the ’playing’ state. When this happens the core
              client should call ggzcore_room_launch_table or
              ggzcore_room_join_table to finalize the game join.

       Parameters:
           data NULL

   enum GGZHookReturn
       GGZ Hook function return types

       Enumeration values:

       GGZ_HOOK_OK
              Success!

       GGZ_HOOK_REMOVE
              Remove this hook immediately.

       GGZ_HOOK_ERROR
              A localized error.

       GGZ_HOOK_CRISIS
              A major error; stop processing the event.

   enum GGZLoginType
       This controls the type of login a user chooses. A different value will
       require different information to be sent to the server.

       Enumeration values:

       GGZ_LOGIN
              Standard login; uname and correct passwd needed.

       GGZ_LOGIN_GUEST
              Guest login; only a uname is required.

       GGZ_LOGIN_NEW
              New user login; only a uname is required. Password will be
              assigned by the server (but can be passed along).

   enum GGZModuleEnvironment
       The environment a game frontend expects.

       Core clients should offer those game modules which fit their own
       environment.

       Enumeration values:

       GGZ_ENVIRONMENT_PASSIVE
              No GUI, no interaction with user

       GGZ_ENVIRONMENT_CONSOLE
              Text console

       GGZ_ENVIRONMENT_FRAMEBUFFER
              VESA or framebuffer

       GGZ_ENVIRONMENT_XWINDOW
              X11 windowed mode (default)

       GGZ_ENVIRONMENT_XFULLSCREEN
              X11 fullscreen mode

   enum GGZOptionFlags
       Enumeration values:

       GGZ_OPT_MODULES
              Load the default configuration file (unused).

       GGZ_OPT_THREADED_IO
              Load the game module list.

       GGZ_OPT_EMBEDDED
              Provide multi-threaded network IO (unused).

       GGZ_OPT_RECONNECT
              Reconnect automatically after connection loss.

   enum GGZRoomEvent
       A GGZRoomEvent is an event associated with the room, that is triggered
       by a communication from the server. When a room event occurs, the
       associated event handler will be called, and will be passed the event
       data (a void*), along with the (optional) user data. All room events
       apply to the current room unless a room number is given. Room events
       are almost always triggered by calling ggzcore_server_read_data.

       See also:
           ggzcore_room_add_event_hook

           ggzcore_server_read_data

       Enumeration values:

       GGZ_PLAYER_LIST
              The list of players in a room has arrived.

       Parameters:
           data The room id (int *)

       Note:
           This will only be issued for the current room.

       See also:
           ggzcore_room_list_players

       GGZ_TABLE_LIST
              Received the list of active tables.

       Parameters:
           data NULL

       See also:
           ggzcore_room_list_tables

       GGZ_CHAT_EVENT
              Received a chat message of any kind. This can happen at any time
              when you’re in a room.

       Parameters:
           data The GGZChatEventData associated with the chat.

       See also:
           GGZChatEventData

       GGZ_ROOM_ENTER
              A player has entered the room with you.

       Parameters:
           data A GGZRoomChangeEventData structure.

       GGZ_ROOM_LEAVE
              A player has left your room.

       Parameters:
           data A GGZRoomChangeEventData structure.

       GGZ_TABLE_UPDATE
              One of the tables in the current room has changed.

       Todo
           How are you supposed to know which table has changed?

           Parameters:
               data NULL

       GGZ_TABLE_LAUNCHED
              The table you tried to launch has launched!

       See also:
           ggzcore_room_launch_table

       Parameters:
           data NULL

       GGZ_TABLE_LAUNCH_FAIL
              The table you tried to launch couldn’t be launched

       See also:
           GGZ_TABLE_LAUNCHED

       Parameters:
           data A pointer to a GGZErrorEventData

       GGZ_TABLE_JOINED
              Your table join attempt has succeeded.

       See also:
           ggzcore_room_join_table

       Parameters:
           data The table index (int*) of the table we joined.

       GGZ_TABLE_JOIN_FAIL
              Joining a table did not succeed.

       See also:
           GGZ_TABLE_JOINED

       Parameters:
           data A helpful error string.

       GGZ_TABLE_LEFT
              You have successfully left the table you were at.

       See also:
           ggzcore_room_leave_table

       Parameters:
           data The GGZTableLeaveEventData associated with the leave.

       See also:
           GGZTableLeaveEventData

       GGZ_TABLE_LEAVE_FAIL
              Your attempt to leave the table has failed.

       See also:
           GGZ_TABLE_LEFT

       Parameters:
           data A helpful error string.

       GGZ_PLAYER_LAG
              A player’s lag (measure of connection speed) has been updated

       See also:
           ggzcore_player_get_lag

       Parameters:
           data The name of the player whose lag has changed.

       GGZ_PLAYER_STATS
              A player’s stats have been updated.

       See also:
           GGZ_PLAYER_LIST

           ggzcore_player_get_record

           ggzcore_player_get_rating

           ggzcore_player_get_ranking

           ggzcore_player_get_highscore

       Parameters:
           data The name of the player whose stats have changed.

       GGZ_PLAYER_COUNT
              The number of players in a room has arrived.

       Parameters:
           data The room id (int *)

   enum GGZServerEvent
       A GGZServerEvent is an event triggered by a communication from the
       server. Each time an event occurs, the associated event handler will be
       called, and will be passed the event data (a void*). Most events are
       generated as a result of ggzcore_server_read_data.

       See also:
           ggzcore_server_add_event_hook

       Enumeration values:

       GGZ_CONNECTED
              We have just made a connection to the server. After this point
              the server’s socket should be accessible and should be monitored
              for data. It happens in direct response to
              ggzcore_server_connect. Note that most events after this will
              only happen by calling ggzcore_server_read_data on the server’s
              FD!

       Parameters:
           data NULL

       See also:
           ggzcore_server_connect

       GGZ_CONNECT_FAIL
              Error: we have failed to connect to the server. This is
              generated in place of GGZ_CONNECTED if the connection could not
              be made. The server object is otherwise unaffected.

       Parameters:
           data An error string (created by strerror)

       See also:
           ggzcore_server_connect

       GGZ_NEGOTIATED
              We have negotiated a connection to the server. This will happen
              automatically once a connection has been established, if the
              server socket is monitored.

       Note:
           This just means we’ve determined ggzd is at the other end.

       Parameters:
           data NULL

       See also:
           ggzcore_server_read_data

       GGZ_NEGOTIATE_FAIL
              Error: negotiation failure. Could be the wrong version. This
              will happen in place of a GGZ_NEGOTIATED if the server could not
              be negotiated with.

       Parameters:
           data A useless error string.

       See also:
           ggzcore_server_read_data

       GGZ_LOGGED_IN
              We have successfully logged in. We can now start doing stuff.
              This will not happen until the client sends their login
              information.

       See also:
           ggzcore_server_login

       Parameters:
           data NULL

       See also:
           ggzcore_server_read_data

       GGZ_LOGIN_FAIL
              Error: login failure. This will happen in place of GGZ_LOGGED_IN
              if the login failed. The server object will be otherwise
              unaffected.

       Parameters:
           data A pointer to a GGZErrorEventData.

       See also:
           GGZErrorEventData

           ggzcore_server_read_data

       GGZ_MOTD_LOADED
              The MOTD has been read from the server and can be displayed. The
              server will send us the MOTD automatically after login; it can
              also be requested by ggzcore_server_motd. It is up to the client
              whether or not to display it. See the online documentation
              (somewhere?) about the MOTD markup format.

       Parameters:
           data Pointer to a GGZMotdEventData including the full MOTD text.

       See also:
           ggzcore_server_motd

       Todo
           The MOTD cannot be accessed outside of this event

           See also:
               ggzcore_server_read_data!

       GGZ_ROOM_LIST
              The room list arrived. This will only happen after the list is
              requested by ggzcore_server_list_rooms(). The list may be
              accessed through ggzcore_server_get_num_rooms() and
              ggzcore_server_get_nth_room(). Until this event arrives these
              functions will be useless!

       Parameters:
           data NULL

       See also:
           ggzcore_server_read_data

       GGZ_TYPE_LIST
              The list of game types is available. This will only happen after
              the list is requested by ggzcore_server_list_types(). The list
              may be accessed through ggzcore_server_get_num_gametypes() and
              ggzcore_server_get_nth_gametype(). Until this event arrives
              these functions will be useless!

       Parameters:
           data NULL

       See also:
           ggzcore_server_read_data

       GGZ_SERVER_PLAYERS_CHANGED
              The number of players on the server has changed. This event is
              issued rather frequently every time players enter or leave.

       Parameters:
           data NULL

       See also:
           ggzcore_server_get_num_players

           ggzcore_server_read_data

       GGZ_ENTERED
              We have successfully entered a room. This will be issued to tell
              us a room join has succeeded, after it has been requested.

       Parameters:
           data NULL

       See also:
           ggzcore_server_join_room

           ggzcore_server_read_data

       GGZ_ENTER_FAIL
              Error: we have tried to enter a room and failed. This will be
              issued to tell us a room join has failed.

       Parameters:
           data A pointer to a GGZErrorEventData.

       See also:
           GGZErrorEventData

           ggzcore_server_join_room

           ggzcore_server_read_data

       GGZ_LOGOUT
              Logged out of the server. This will happen when the server
              completes the communication; usually after
              ggzcore_net_send_logout is called.

       Parameters:
           data NULL

       See also:
           ggzcore_server_read_data

       GGZ_NET_ERROR
              Error: a network (transmission) error occurred. The server will
              automatically disconnect.

       Parameters:
           data A generally unhelpful error string.

       See also:
           ggzcore_server_read_data

       GGZ_PROTOCOL_ERROR
              Error: a communication protocol error occured. This can happen
              in a variety of situations when the server sends us something we
              can’t handle. The server will be automatically disconnected.

       Parameters:
           data A technical error string.

       See also:
           ggzcore_server_read_data

       GGZ_CHAT_FAIL
              Error: A chat message could not be sent. This will happen when
              we try to send a chat and the server rejects it.

       Parameters:
           data A pointer to a GGZErrorEventData.

       See also:
           GGZErrorEventData

           ggzcore_server_read_data

       GGZ_STATE_CHANGE
              The internal state of ggzcore has changed. This may happen at
              any time.

       Parameters:
           data NULL

       See also:
           GGZStateID

           ggzcore_server_get_state

       GGZ_CHANNEL_CONNECTED
              Status event: a requested direct game connection has been
              established. To start a game (table), a channel must be created.
              This event will alert that the channel has been established. The
              channel’s FD should then be monitored for input, which should
              then be passed back to the server object for handling.

       Parameters:
           data NULL

       Note:
           This event is deprecated and should not be used.

       See also:
           ggzcore_server_get_channel

           ggzcore_server_read_data

       GGZ_CHANNEL_READY
              Game channel is ready for read/write operations. After the
              channel has been connected, if we continue to monitor the socket
              eventually it will be negotiated and ready to use. At this point
              it is ready for the game client to use.

       Parameters:
           data NULL

       Note:
           This event is deprecated and should not be used.

       See also:
           ggzcore_server_read_data

       GGZ_CHANNEL_FAIL
              Error: Failure during setup of direct connection to game server.
              If the channel could not be prepared, this event will happen
              instead of GGZ_CHANNEL_READY or GGZ_CHANNEL_CONNECTED event. At
              this point the channel is no longer useful (I think).

       Parameters:
           data An unhelpful error string

       Note:
           This event is deprecated and should not be used.

       See also:
           ggzcore_server_read_data

       GGZ_NUM_SERVER_EVENTS
              Terminator. Do not use.

   enum GGZStateID
       The states a server connection may be in.

       On the client side, a simplistic state maching is used to tell what’s
       going on. A game client should usually consult the current state when
       determining what actions are possible.

       Enumeration values:

       GGZ_STATE_OFFLINE
              Not connected (at all)

       GGZ_STATE_CONNECTING
              In the process of connecting.

       GGZ_STATE_RECONNECTING
              Continuous reconnection attempts.

       GGZ_STATE_ONLINE
              Connected, but not doing anything.

       GGZ_STATE_LOGGING_IN
              In the process of logging in.

       GGZ_STATE_LOGGED_IN
              Online and logged in!

       GGZ_STATE_ENTERING_ROOM
              Moving into a room.

       GGZ_STATE_IN_ROOM
              Online, logged in, and in a room.

       GGZ_STATE_BETWEEN_ROOMS
              Moving between rooms.

       GGZ_STATE_LAUNCHING_TABLE
              Trying to launch a table.

       GGZ_STATE_JOINING_TABLE
              Trying to join a table.

       GGZ_STATE_AT_TABLE
              Online, loggied in, in a room, at a table.

       GGZ_STATE_LEAVING_TABLE
              Waiting to leave a table.

       GGZ_STATE_LOGGING_OUT
              In the process of logging out.

Function Documentation

   int ggzcore_conf_commit (void)
       ggzcore_conf_commit() - Commits the core user config file to disk

       Returns:
           : int : 0 if successful, -1 on error

   int ggzcore_conf_initialize (const char * g_path, const char * u_path)
       ggzcore_conf_initialize() Opens the global and/or user configuration
       files for the frontend. Either g_path or u_path can be NULL if the file
       is not to be used. The user config file will be created if it does not
       exist.

       Returns:
           : 0 on success, negative on failure

   int ggzcore_conf_read_int (const char * section, const char * key, int def)
       ggzcore_conf_read_int() - Read a integer from the configuration file(s)

       Parameters:
           section section to get value from
           key key value was stored under
           def default value to return if none is found

       Returns:
           an integer from the configuration file OR the default value

       Note:
           There is no guaranteed way to find if the call failed. If you must
           know, call ggzcore_conf_read_string with a NULL default value and
           check for the NULL return.

   int ggzcore_conf_read_list (const char * section, const char * key, int *
       argcp, char *** argvp)
       ggzcore_conf_read_list() - Read a list from the configuration file(s)

       Parameters:
           section section to get value from
           key key value was stored under
           argcp ptr to int which will receive the list entry count
           argvp a pointer to a dynamically allocated array that
           ggzcore_conf_read_list() will build

       Returns:
           int : 0 if successful, -1 on error

   char* ggzcore_conf_read_string (const char * section, const char * key,
       const char * def)
       ggzcore_conf_read_string() - Read a string from the configuration
       file(s)

       Parameters:
           section section to get value from
           key key value was stored under
           def default value to return if none is found

       Returns:
           a dynamically allocated string from the configuration file OR a
           dynamically allocated copy of the default string

       Note:
           The default may be set to NULL, in which case a NULL will be
           returned if the value could not be found in either configuration
           file.

   int ggzcore_conf_remove_key (const char * section, const char * key)
       ggzcore_conf_remove_key() - Removes a key entry from the user config
       file

       Parameters:
           section section to remove
           key key entry to remove

       Returns:
           int : 0 if success, -1 on error, 1 on soft error (section/key
           didn’t exist)

   int ggzcore_conf_remove_section (const char * section)
       ggzcore_conf_remove_section() - Removes a section from the user config
       file

       Parameters:
           section section to remove

       Returns:
           int : 0 if successful, -1 on error, 1 on soft error (section did
           not exist)

   int ggzcore_conf_write_int (const char * section, const char * key, int
       value)
       ggzcore_conf_write_int() - Write a integer to the user config file

       Parameters:
           section section to store value in
           key key to store value under
           value value to store

       Returns:
           int : 0 if successful, -1 on error

   int ggzcore_conf_write_list (const char * section, const char * key, int
       argc, char ** argv)
       ggzcore_conf_write_list() - Write a list to the user config file

       Parameters:
           section section to store value in
           key key to store value under
           argc count of string arguments in list
           argv array of NULL terminated strings

       Returns:
           int : 0 if successful, -1 on error

   int ggzcore_conf_write_string (const char * section, const char * key,
       const char * value)
       ggzcore_conf_write_string() - Write a string to the user config file

       Parameters:
           section section to store value in
           key key to store value under
           value value to store

       Returns:
           int : 0 if successful, -1 on error

   void ggzcore_destroy (void)
       ggzcore_destroy() - Cleanup function for ggzcore lib.

   int ggzcore_game_add_event_hook (GGZGame * game, const GGZGameEvent event,
       const GGZHookFunc func)
       Register a hook for a game event.

       See also:
           ggzcore_server_add_event_hook

           ggzcore_room_add_event_hook

   int ggzcore_game_add_event_hook_full (GGZGame * game, const GGZGameEvent
       event, const GGZHookFunc func, const void * data)
       Register a hook for a game event.

       See also:
           ggzcore_server_add_event_hook_full

           ggzcore_room_add_event_hook_full

   int ggzcore_game_read_data (GGZGame * game)
       Read data from the game. When data is pending on the control socket,
       call this function.

       Returns:
           negative on error

       See also:
           ggzcore_game_get_control_fd

   int ggzcore_game_remove_event_hook (GGZGame * game, const GGZGameEvent
       event, const GGZHookFunc func)
       Remove a hook from a game event.

       See also:
           ggzcore_server_remove_event_hook

           ggzcore_room_remove_event_hook

   int ggzcore_game_remove_event_hook_id (GGZGame * game, const GGZGameEvent
       event, const unsigned int hook_id)
       Remove a specified hook from a game event.

       See also:
           ggzcore_server_remove_event_hook_id

           ggzcore_room_remove_event_hook_id

   unsigned int ggzcore_gametype_get_id (const GGZGameType * type)
       Get the ID of this gametype.

       Note:
           This is not normally useful for a GGZ client to know.

   int ggzcore_gametype_get_max_bots (const GGZGameType * type)
       Get the maximum number of bots the game can support.

       See also:
           ggzcore_gametype_bots_is_valid

   int ggzcore_gametype_get_max_players (const GGZGameType * type)
       Get the maximum number of players the game can support.

       See also:
           ggzcore_gametype_num_players_is_valid

   int ggzcore_init (GGZOptions options)
       ggzcore_init() - Initializtion function for ggzcore lib.

       Parameters:
           options options structure

       Returns:
           int : 0 if successful, -1 on failure

   int ggzcore_module_add (const char * name, const char * version, const char
       * prot_engine, const char * prot_version, const char * author, const
       char * frontend, const char * url, const char * exe_path, const char *
       icon_path, const char * help_path, GGZModuleEnvironment environment)
       This adds a local module to the list. It returns 0 if successful or -1
       on failure.

   const char* ggzcore_module_get_icon_path (GGZModule * module)
       This is (intended to be) an optional xpm file that the module can
       provide to use for representing the game graphically.

   int ggzcore_player_get_highscore (const GGZPlayer * player, int *
       highscore)
       Get the player’s highscore.

       Returns:
           TRUE if there is a highscore; FALSE if not or on error.

   int ggzcore_player_get_ranking (const GGZPlayer * player, int * ranking)
       Get the player’s ranking.

       Returns:
           TRUE if there is a ranking; FALSE if not or on error.

   int ggzcore_player_get_rating (const GGZPlayer * player, int * rating)
       Get the player’s rating.

       Returns:
           TRUE if there is a rating; FALSE if not or on error.

   int ggzcore_player_get_record (const GGZPlayer * player, int * wins, int *
       losses, int * ties, int * forfeits)
       Get the player’s win-loss record.

       Returns:
           TRUE if there is a record; FALSE if not or on error.

   void ggzcore_reload (void)
       ggzcore_reload() - Reload game module database

   int ggzcore_room_add_event_hook (GGZRoom * room, const GGZRoomEvent event,
       const GGZHookFunc func)
       Register a handler (hook) for the room event.

       A room event will happen when data is received from the server. To make
       updates to the frontend, the client will need to register a hook
       function to handle the event. This hook function will be called each
       time the room event occurrs. More than one hook function may be
       specified, in which case they will all be called (in FIFO order).

       Parameters:
           room The room object to associate the hook with.
           event The event the handler is going to be ’hooked’ onto.
           func The event handler itself. This is called during the event.

       Returns:
           The hook ID, or negative on error.

       See also:
           ggzcore_room_add_event_hook_full

           ggzcore_room_remove_event_hook

           ggzcore_room_remove_event_hook_id

   int ggzcore_room_add_event_hook_full (GGZRoom * room, const GGZRoomEvent
       event, const GGZHookFunc func, const void * data)
       Register a handler (hook) for thee room event, with data.

       This function is similar to ggzcore_room_add_event_hook, except that
       user data will be associated with the hook. This data will be passed
       back to the function each time it is invoked on this event.

       Parameters:
           room The room object to associate the hook with.
           event The event the handler is going to be ’hooked’ onto.
           func The event handler itself. This is called during the event.
           data The user data associated with the hook.

       Returns:
           The hook ID, or negative on error.

       See also:
           ggzcore_room_add_event_hook

   int ggzcore_room_chat (GGZRoom * room, const GGZChatType opcode, const char
       * player, const char * msg)
       Chat!

       Parameters:
           room Your current room.
           opcode The chat type.
           player The name of the target player (only for certain chat types)
           msg The text of the chat message (some chat types don’t need it)

       Returns:
           0 on success, negative on (any) failure

       Note:
           The chat message should be in UTF-8.

   int ggzcore_room_join_table (GGZRoom * room, const unsigned int table_id,
       int spectator)
       Join a table in the room, so that you can then play at it.

       Parameters:
           room Your current room.
           table_id The table to join.
           spectator TRUE if you wish to spectate, FALSE if you want to play

       Returns:
           0 on success, negative on (any) failure

   int ggzcore_room_launch_table (GGZRoom * room, GGZTable * table)
       Launch a table in the room.

       When a player wants to launch a new table, this is the function to do
       it. You must first create the table and set up the number and type of
       seats. Then call this function to initiate the launch.

       Parameters:
           room Your current room.
           table The table to launch.

       Returns:
           0 on success, negative on (any) failure

   int ggzcore_room_leave_table (GGZRoom * room, int force)
       Leave the table you are currently playing at.

       This function tries to leave your current table. You should ’force’ the
       leave only if the game client is inoperable, since for some games this
       will destroy the game server as well.

       Parameters:
           room Your current room.
           force TRUE to force the leave, FALSE to leave it up to ggzd

       Returns:
           0 on success, negative on (any) failure

   int ggzcore_room_list_players (GGZRoom * room)
       Call to request a list of players in the room.

       See also:
           GGZ_PLAYER_LIST

   int ggzcore_room_list_tables (GGZRoom * room, const int type, const char
       global)
       Call to request a list of tables in the room.

       Parameters:
           room Your current room
           type currently ignored (???)
           global currently ignored (???)

       See also:
           GGZ_TABLE_LIST

   int ggzcore_room_remove_event_hook (GGZRoom * room, const GGZRoomEvent
       event, const GGZHookFunc func)
       Remove a hook from an event.

       Removes a specific hook function from the hook list for the given room
       event. If more than one copy of the function exists in the list, the
       oldest one will be removed.

       Parameters:
           room The room object to associate the hook with.
           event The event the handler is to be unhooked from.
           func The event handler function to remove.

       Returns:
           0 on success, negative on failure.

       See also:
           ggzcore_room_add_event_hook

   int ggzcore_room_remove_event_hook_id (GGZRoom * room, const GGZRoomEvent
       event, const unsigned int hook_id)
       Remove a hook from an event, by ID.

       Removes a specific hook from the hook list for the given room. The ’ID’
       should be the same as that returned when the hook was added.

       Parameters:
           room The room object to associate the hook with.
           event The event the handler is to be unhooked from.
           id The ID of the hook to remove, as returned by the add function
           return 0 on success, negative on failure

       See also:
           ggzcore_room_add_event_hook

   int ggzcore_server_add_event_hook (GGZServer * server, const GGZServerEvent
       event, const GGZHookFunc func)
       Register a callback handler for a server event.

       Call this function to register the given GGZHookFunc as a handler for
       the given event. Then any time that event happens the handler function
       will be called.

       Parameters:
           server The GGZ server object.
           event The server event to be handled.
           func The handler function to be called when the event occurs.

       Returns:
           A hook ID value to identify this handler.

       Note:
           Equivalent to ggzcore_server_add_event_hook_full with data==NULL.

           More than one handler can be registered for each event.

   int ggzcore_server_add_event_hook_full (GGZServer * server, const
       GGZServerEvent event, const GGZHookFunc func, const void * data)
       Register a callback handler for a server event.

       See also:
           ggzcore_server_add_event_hook

       Parameters:
           data An arbitrary pointer that will be passed to the hook function.

   int ggzcore_server_connect (GGZServer * server)
       Connect to the server.

       Call this function to initially connect to a GGZ server. Connection
       info is set using the ggzcore_server_set_hostinfo function.

       The function is asynchronous and will return very quickly. After the
       connection is (hopefully) established we will receive either a
       GGZ_CONNECTED or GGZ_CONNECT_FAIL server event. If the connection
       succeeds, negotiations with the GGZ server will begin automatically.
       Once this is complete, we will receive either a GGZ_NEGOTIATED or
       GGZ_NEGOTIATE_FAIL event.

       Parameters:
           server The GGZ server object.

       Returns:
           0 on success, -1 on failure.

       Note:
           On success a GGZ_CONNECTED event will be generated.

           On failure a GGZ_CONNECT_FAIL event may or may not be generated.

   int ggzcore_server_get_fd (const GGZServer * server)
       Get the socket used for connection with the server.

       This returns the file descriptor of the primary socket for the TCP
       connection to the server. All GGZ data goes across this socket.

       Parameters:
           server The GGZ server object.

       Returns:
           The file descriptor of the connection socket.

       See also:
           ggzcore_server_connect

   const char* ggzcore_server_get_handle (const GGZServer * server)
       Get the handle being used for this server.

       Parameters:
           server The GGZ server object.

       Returns:
           A string containing the handle, or NULL on error.

       See also:
           ggzcore_server_set_logininfo

   const char* ggzcore_server_get_host (const GGZServer * server)
       Get the hostname of the server.

       Parameters:
           server The GGZ server object.

       Returns:
           A string containing the host name, or NULL on error.

       See also:
           ggzcore_server_set_hostinfo

   int ggzcore_server_get_num_gametypes (const GGZServer * server)
       Return the overall number of game types on the server.

       Parameters:
           server The GGZ server object.

       Returns:
           The number of game types on this server, or -1 on error.

       Note:
           This number is 0 until

       See also:
           GGZ_TYPE_LIST.

   int ggzcore_server_get_num_players (const GGZServer * server)
       Get the total number of players on the server.

       Parameters:
           server The GGZ server object return An approximate number of
           players in all rooms of the server.

   int ggzcore_server_get_num_rooms (const GGZServer * server)
       Return the number of rooms on the server, or -1 on error.

       Note:
           Until we retrieve the list of rooms, this will return 0.

   const char* ggzcore_server_get_password (const GGZServer * server)
       Get the password being used for this server.

       Parameters:
           server The GGZ server object.

       Returns:
           A string containing the password, or NULL on error.

       See also:
           ggzcore_server_set_logininfo

   int ggzcore_server_get_port (const GGZServer * server)
       Get the port of the server.

       Parameters:
           server The GGZ server object.

       Returns:
           The port number of the server, or -1 on error.

       See also:
           ggzcore_server_set_hostinfo

   GGZStateID ggzcore_server_get_state (const GGZServer * server)
       Get the state of the server connection.

       Parameters:
           server The GGZ server object.

       Returns:
           The state of the connection, or -1 on error.

   int ggzcore_server_get_tls (const GGZServer * server)
       Get the current TLS status of this server.

       Parameters:
           server The GGZ server object

       Returns:
           Whether TLS is active or not

   GGZLoginType ggzcore_server_get_type (const GGZServer * server)
       Get the login type being used for this server.

       Parameters:
           server The GGZ server object.

       Returns:
           The login type set for the server, or -1 on error.

       See also:
           ggzcore_server_set_logininfo

   int ggzcore_server_join_room (GGZServer * server, const unsigned int room)
       Join a room on the server.

       Parameters:
           server The GGZ server object.
           room The number of the room to join.

       Returns:
           0 on success, -1 on failure (e.g. non-existing room number).

   int ggzcore_server_list_gametypes (GGZServer * server, const char verbose)
       Request game type list.

       Parameters:
           server The GGZ server object.
           verbose Receive detailed gametype information or not.

       Returns:
           0 on success, -1 on failure.

       Note:
           A GGZ_TYPE_LIST event will be the asynchronous response on success.

   int ggzcore_server_list_rooms (GGZServer * server, const int type, const
       char verbose)
       Request room list.

       Parameters:
           server The GGZ server object.
           type Not used yet.
           verbose Receive all information about a room or only the
           essentials.

       Returns:
           0 on success, -1 on failure.

       Note:
           A GGZ_ROOM_LIST might be generated thereafter.

   int ggzcore_server_log_session (GGZServer * server, const char * filename)
       Initiate logging of ggzcore events.

       Normally, ggzcore traffic is not logged anywhere. With this functions,
       such output can be directed into a file. It contains all the network
       messages received from the server.

       Parameters:
           server The GGZ server object.
           filename The file the messages are written to.

       Returns:
           0 on success, -1 on error.

   int ggzcore_server_login (GGZServer * server)
       Log in to the server.

       Call this function to log in to the server once a connection has been
       established. Typically you must first connect to the server, then wait
       to receive the GGZ_CONNECTED and GGZ_NEGOTIATED events before
       attempting to log in. Login info is set using the
       ggzcore_server_set_logininfo function.

       The function is asynchronous and will return immediately. After the
       login request is sent, we will wait to receive either a GGZ_LOGGED_IN
       or GGZ_LOGIN_FAIL server event.

       Parameters:
           server The GGZ server object.

       Returns:
           0 on success, -1 on failure.

       Note:
           On failure no events will be generated.

   GGZServer* ggzcore_server_new (void)
       Create a new server object.

       Call this function to create a server object. This object holds all
       state data for communicating with a ggz server. It is necessary for any
       kind of connection.

   int ggzcore_server_read_data (GGZServer * server, int fd)
       Read data for the server on the specified FD.

       Returns:
           negative on error

   int ggzcore_server_remove_event_hook (GGZServer * server, const
       GGZServerEvent event, const GGZHookFunc func)
       Remove a single hook function from an event’s hook list.

       Parameters:
           server The GGZ server object.
           event The server event the hook is associated with.
           func The function to be removed from the hook list.

       Returns:
           0 on success (hook removed); -1 on failure (no hook removed)

       Note:
           At most one copy of the function will be removed.

       See also:
           ggzcore_server_remove_event_hook_id

   int ggzcore_server_remove_event_hook_id (GGZServer * server, const
       GGZServerEvent event, const unsigned int hook_id)
       Remove a hook function with given ID from the event’s hook list.

       Parameters:
           server The GGZ server object.
           event The server event the hook is associated with.
           hook_id The ID of the hook event.

       Returns:
           0 on success (hook removed); -1 on failure (no hook removed)

       Note:
           The hook ID is given by ggzcore_server_add_event_hook

   int ggzcore_server_reset (GGZServer * server)
       Reset the server object.

       After you’ve disconnected, call this function to discard all state data
       and reset the state of the server object. You can then connect again.

       Note:
           You should disconnect before resetting.

   int ggzcore_server_set_hostinfo (GGZServer * server, const char * host,
       const unsigned int port, const unsigned int use_tls)
       Set host info for connecting to the server.

       Call this function to set host info for the GGZ server before trying to
       connect to it.

       Parameters:
           server The GGZ server object.
           host A string containing the hostname.
           port The port to connect to.
           use_tls If set, the connection will be encrypted.

       Returns:
           0 on success, -1 on error.

       Note:
           Should never fail when given valid input.

       See also:
           ggzcore_server_connect

   int ggzcore_server_set_logininfo (GGZServer * server, const GGZLoginType
       type, const char * handle, const char * password, const char * email)
       Set login info for logging in to the server.

       Call this function to set login info for the GGZ server before trying
       to login. This should only be called when the server is in certain
       states.

       Parameters:
           server The GGZ server object.
           type The type of login to attempt.
           handle The username to use with the server.
           password The password to use (may be NULL with some login types).
           email The email address to use (may be NULL with some login types).

       Returns:
           0 on success, -1 on error.

   int ggzcore_table_get_seat_count (const GGZTable * table, GGZSeatType type)
       Count the seats of the given type.

       Given a table and a seat type, this function returns the number of
       seats at the table that match the type.

       Parameters:
           table A GGZ table.
           type A GGZSeatType.

       Returns:
           The number of seats matching the type, or -1 on error.

   int ggzcore_table_init (GGZTable * table, const GGZGameType * gametype,
       const char * desc, const unsigned int num_seats)
       Set data on a table object.

       Note:
           Useful when launching a game.

   GGZTable* ggzcore_table_new (void)
       Create a new table object.

       Note:
           Useful when launching a game.

   int ggzcore_table_set_seat (GGZTable * table, const unsigned int seat,
       GGZSeatType type, const char * name)
       Set a seat type at a table, pre-launch.

       When launching a table, call this function to set up a particular seat
       at the table. It can also be used to fiddle with already existing
       tables, but that would be extremely unwise.

       Parameters:
           table The table object to change.
           seat The seat number at the table to change.
           type The type of seat to make it (open, reserved, or bot).
           name The name of the seat (must be valid for reserved seats).

       Returns:
           0 on success, -1 on error.

       Todo
           How do we stop the GGZ client from fiddling with random tables?

Author

       Generated automatically by Doxygen for GGZCore from the source code.