pub struct Game {
pub id: GameId,
pub name: String,
pub phase: GamePhase,
pub players: Players,
pub round: Round,
pub score: Score,
pub table: Table,
pub version: GameVersion,
pub style: GameStyle,
}
Fields§
§id: GameId
§name: String
§phase: GamePhase
§players: Players
§round: Round
§score: Score
§table: Table
§version: GameVersion
§style: GameStyle
Implementations§
source§impl Game
impl Game
pub fn get_possible_melds_for_player( &self, player: &PlayerId, check_for_mahjong: bool, ) -> Vec<PossibleMeld>
pub fn get_can_claim_tile( &self, player: &PlayerId, ) -> (bool, Option<TileId>, Option<&Hand>)
pub fn get_possible_melds(&self, early_return: bool) -> Vec<PossibleMeld>
pub fn get_possible_melds_by_discard(&self) -> Vec<PossibleMeld>
pub fn get_current_player(&self) -> Option<PlayerId>
pub fn get_board_tile_player_diff( &self, round: Option<&Round>, hand: Option<&Hand>, player_id: &PlayerId, ) -> PlayerDiff
pub fn get_dealer(&self) -> Option<&PlayerId>
pub fn get_player_wind(&self) -> Wind
source§impl Game
impl Game
pub fn set_players(&mut self, players: &Players)
pub fn say_mahjong( &mut self, player_id: &PlayerId, ) -> Result<(), CanSayMahjongError>
pub fn pass_null_round(&mut self) -> Result<(), PassNullRoundError>
pub fn start(&mut self, shuffle_players: bool)
pub fn decide_dealer(&mut self) -> Result<(), DecideDealerError>
pub fn prepare_table(&mut self, with_dead_wall: bool)
pub fn initial_draw(&mut self) -> Result<(), DrawError>
pub fn draw_tile_from_wall(&mut self) -> DrawTileResult
pub fn discard_tile_to_board( &mut self, tile_id: &TileId, ) -> Result<(), DiscardTileError>
pub fn create_meld( &mut self, player_id: &PlayerId, tiles: &[TileId], is_upgrade: bool, is_concealed: bool, ) -> Result<(), CreateMeldError>
pub fn break_meld( &mut self, player_id: &PlayerId, set_id: &String, ) -> Result<(), BreakMeldError>
pub fn claim_tile(&mut self, player_id: &PlayerId) -> bool
pub fn update_version(&mut self)
pub fn update_id(&mut self, id: Option<&str>)
pub fn complete_players( &mut self, shuffle_players: bool, ) -> Result<(), &'static str>
pub fn set_wind_for_player(&mut self, player_id: &PlayerId, wind: &Wind)
source§impl Game
impl Game
pub fn calculate_hand_score( &mut self, winner_player: &PlayerId, ) -> (Vec<ScoringRule>, u32)
source§impl Game
impl Game
pub fn get_summary(&self) -> String
pub fn get_summary_sorted(&self) -> String
pub fn from_summary(summary: &str) -> Self
pub fn get_meld_id_from_summary(&self, player_id: &str, summary: &str) -> String
Trait Implementations§
source§impl<'de> Deserialize<'de> for Game
impl<'de> Deserialize<'de> for Game
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
source§impl TS for Game
impl TS for Game
source§type WithoutGenerics = Game
type WithoutGenerics = Game
If this type does not have generic parameters, then
WithoutGenerics
should just be Self
.
If the type does have generic parameters, then all generic parameters must be replaced with
a dummy type, e.g ts_rs::Dummy
or ()
.
The only requirement for these dummy types is that EXPORT_TO
must be None
. Read moresource§fn decl_concrete() -> String
fn decl_concrete() -> String
Declaration of this type using the supplied generic arguments.
The resulting TypeScript definition will not be generic. For that, see
TS::decl()
.
If this type is not generic, then this function is equivalent to TS::decl()
.source§fn decl() -> String
fn decl() -> String
Declaration of this type, e.g.
type User = { user_id: number, ... }
.
This function will panic if the type has no declaration. Read moresource§fn inline() -> String
fn inline() -> String
Formats this types definition in TypeScript, e.g
{ user_id: number }
.
This function will panic if the type cannot be inlined.source§fn inline_flattened() -> String
fn inline_flattened() -> String
Flatten a type declaration.
This function will panic if the type cannot be flattened.
This function will panic if the type cannot be flattened.
source§fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
Iterates over all type parameters of this type.
source§fn output_path() -> Option<&'static Path>
fn output_path() -> Option<&'static Path>
Returns the output path to where
The returned path does not include the base directory from
T
should be exported.The returned path does not include the base directory from
TS_RS_EXPORT_DIR
. Read moresource§fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
Iterates over all dependency of this type.
§const DOCS: Option<&'static str> = None
const DOCS: Option<&'static str> = None
JSDoc comment to describe this type in TypeScript - when
TS
is derived, docs are
automatically read from your doc comments or #[doc = ".."]
attributes§fn dependencies() -> Vec<Dependency>where
Self: 'static,
fn dependencies() -> Vec<Dependency>where
Self: 'static,
Resolves all dependencies of this type recursively.
§fn export() -> Result<(), ExportError>where
Self: 'static,
fn export() -> Result<(), ExportError>where
Self: 'static,
Manually export this type to the filesystem.
To export this type together with all of its dependencies, use [
TS::export_all
]. Read more§fn export_all() -> Result<(), ExportError>where
Self: 'static,
fn export_all() -> Result<(), ExportError>where
Self: 'static,
Manually export this type to the filesystem, together with all of its dependencies.
To export only this type, without its dependencies, use [
To export only this type, without its dependencies, use [
TS::export
]. Read more§fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
Manually export this type into the given directory, together with all of its dependencies.
To export only this type, without its dependencies, use [
To export only this type, without its dependencies, use [
TS::export
]. Read more§fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
§fn default_output_path() -> Option<PathBuf>
fn default_output_path() -> Option<PathBuf>
Returns the output path to where
T
should be exported. Read moreAuto Trait Implementations§
impl Freeze for Game
impl RefUnwindSafe for Game
impl Send for Game
impl Sync for Game
impl Unpin for Game
impl UnwindSafe for Game
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)