eliot/game/bag.h
2004-04-08 09:43:06 +00:00

85 lines
2.8 KiB
C

/* Eliot */
/* Copyright (C) 1999 Antoine Fraboulet */
/* antoine.fraboulet@free.fr */
/* */
/* 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 */
/* $Id: bag.h,v 1.1 2004/04/08 09:43:06 afrab Exp $ */
#ifndef _BAG_H_
#define _BAG_H_
#if defined(__cplusplus)
extern "C" {
#endif
/*************************
* A bag stores the set of free
* tiles for the game
*************************/
typedef struct tbag *Bag;
/*************************
* Bag general routines
*************************/
Bag Bag_create (void);
void Bag_init (Bag b);
void Bag_destroy (Bag b);
void Bag_copy (Bag dst, Bag src);
/*************************
* take or replace a tile in the bag
* return value :
* 0 : Ok
* 1 : an error occured (not enough or too many tiles
* of that type are in the bag)
*************************/
int Bag_taketile (Bag b, tile_t t);
int Bag_replacetile (Bag b, tile_t t);
/*************************
* Returns how many 'tile_t' tiles are available
*************************/
int Bag_in (Bag b, tile_t t);
/*************************
* Returns how many tiles/vowels/consonants are available
* Warning: Bag_nvowels(b) + Bag_nconsonants(b) != Bag_ntiles(b),
* because of the jokers and the 'Y'.
*************************/
int Bag_ntiles (Bag b);
int Bag_nvowels (Bag b);
int Bag_nconsonants (Bag b);
/*************************
* return a random available tile
* the tile is not taken out of the
* bag.
* returns 0 on failure
*************************/
tile_t Bag_select_random (Bag b);
#if defined(__cplusplus)
}
#endif
#endif