LambdaHack-0.8.3.0: A game engine library for tactical squad ASCII roguelike dungeon crawlers

Safe HaskellNone
LanguageHaskell2010

Game.LambdaHack.Common.Faction

Contents

Description

Factions taking part in the game, e.g., a hero faction, a monster faction and an animal faction.

Synopsis

Documentation

data FactionId Source #

A unique identifier of a faction in a game.

type FactionDict = EnumMap FactionId Faction Source #

All factions in the game, indexed by faction identifier.

data Faction Source #

The faction datatype.

Constructors

Faction 

Fields

Instances
Eq Faction Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Methods

(==) :: Faction -> Faction -> Bool #

(/=) :: Faction -> Faction -> Bool #

Show Faction Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Generic Faction Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Associated Types

type Rep Faction :: * -> * #

Methods

from :: Faction -> Rep Faction x #

to :: Rep Faction x -> Faction #

Binary Faction Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Methods

put :: Faction -> Put #

get :: Get Faction #

putList :: [Faction] -> Put #

type Rep Faction Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

data Diplomacy Source #

Diplomacy states. Higher overwrite lower in case of asymmetric content.

Constructors

Unknown 
Neutral 
Alliance 
War 
Instances
Enum Diplomacy Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Eq Diplomacy Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Ord Diplomacy Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Show Diplomacy Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Generic Diplomacy Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Associated Types

type Rep Diplomacy :: * -> * #

Binary Diplomacy Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

type Rep Diplomacy Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

type Rep Diplomacy = D1 (MetaData "Diplomacy" "Game.LambdaHack.Common.Faction" "LambdaHack-0.8.3.0-5WMRdylEY9jFLqYScFUab7" False) ((C1 (MetaCons "Unknown" PrefixI False) (U1 :: * -> *) :+: C1 (MetaCons "Neutral" PrefixI False) (U1 :: * -> *)) :+: (C1 (MetaCons "Alliance" PrefixI False) (U1 :: * -> *) :+: C1 (MetaCons "War" PrefixI False) (U1 :: * -> *)))

data Status Source #

Current game status.

Constructors

Status 

Fields

Instances
Eq Status Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Methods

(==) :: Status -> Status -> Bool #

(/=) :: Status -> Status -> Bool #

Ord Status Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Show Status Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Generic Status Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Associated Types

type Rep Status :: * -> * #

Methods

from :: Status -> Rep Status x #

to :: Rep Status x -> Status #

Binary Status Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Methods

put :: Status -> Put #

get :: Get Status #

putList :: [Status] -> Put #

type Rep Status Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

type Rep Status = D1 (MetaData "Status" "Game.LambdaHack.Common.Faction" "LambdaHack-0.8.3.0-5WMRdylEY9jFLqYScFUab7" False) (C1 (MetaCons "Status" PrefixI True) (S1 (MetaSel (Just "stOutcome") NoSourceUnpackedness NoSourceStrictness DecidedStrict) (Rec0 Outcome) :*: (S1 (MetaSel (Just "stDepth") NoSourceUnpackedness NoSourceStrictness DecidedStrict) (Rec0 Int) :*: S1 (MetaSel (Just "stNewGame") NoSourceUnpackedness NoSourceStrictness DecidedStrict) (Rec0 (Maybe (GroupName ModeKind))))))

data Target Source #

The type of na actor target.

Constructors

TEnemy ActorId Bool

target an actor; cycle only trough seen foes, unless the flag is set

TPoint TGoal LevelId Point

target a concrete spot

TVector Vector

target position relative to actor

Instances
Eq Target Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Methods

(==) :: Target -> Target -> Bool #

(/=) :: Target -> Target -> Bool #

Ord Target Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Show Target Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Generic Target Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Associated Types

type Rep Target :: * -> * #

Methods

from :: Target -> Rep Target x #

to :: Rep Target x -> Target #

Binary Target Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Methods

put :: Target -> Put #

get :: Get Target #

putList :: [Target] -> Put #

type Rep Target Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

data TGoal Source #

The goal of an actor.

Constructors

TEnemyPos ActorId Bool

last seen position of the targeted actor

TEmbed ItemBag Point

embedded item that can be triggered; in TPoint (TEmbed bag p) _ q usually bag is embbedded in p and q is an adjacent open tile

TItem ItemBag

item lying on the ground

TSmell

smell potentially left by enemies

TUnknown

an unknown tile to be explored

TKnown

a known tile to be patrolled

TAny

an unspecified goal

Instances
Eq TGoal Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Methods

(==) :: TGoal -> TGoal -> Bool #

(/=) :: TGoal -> TGoal -> Bool #

Ord TGoal Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Methods

compare :: TGoal -> TGoal -> Ordering #

(<) :: TGoal -> TGoal -> Bool #

(<=) :: TGoal -> TGoal -> Bool #

(>) :: TGoal -> TGoal -> Bool #

(>=) :: TGoal -> TGoal -> Bool #

max :: TGoal -> TGoal -> TGoal #

min :: TGoal -> TGoal -> TGoal #

Show TGoal Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Methods

showsPrec :: Int -> TGoal -> ShowS #

show :: TGoal -> String #

showList :: [TGoal] -> ShowS #

Generic TGoal Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Associated Types

type Rep TGoal :: * -> * #

Methods

from :: TGoal -> Rep TGoal x #

to :: Rep TGoal x -> TGoal #

Binary TGoal Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Methods

put :: TGoal -> Put #

get :: Get TGoal #

putList :: [TGoal] -> Put #

type Rep TGoal Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

data Challenge Source #

Constructors

Challenge 

Fields

  • cdiff :: Int

    game difficulty level (HP bonus or malus)

  • cwolf :: Bool

    lone wolf challenge (only one starting character)

  • cfish :: Bool

    cold fish challenge (no healing from enemies)

Instances
Eq Challenge Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Ord Challenge Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Show Challenge Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Generic Challenge Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

Associated Types

type Rep Challenge :: * -> * #

Binary Challenge Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

type Rep Challenge Source # 
Instance details

Defined in Game.LambdaHack.Common.Faction

type Rep Challenge = D1 (MetaData "Challenge" "Game.LambdaHack.Common.Faction" "LambdaHack-0.8.3.0-5WMRdylEY9jFLqYScFUab7" False) (C1 (MetaCons "Challenge" PrefixI True) (S1 (MetaSel (Just "cdiff") NoSourceUnpackedness NoSourceStrictness DecidedStrict) (Rec0 Int) :*: (S1 (MetaSel (Just "cwolf") NoSourceUnpackedness NoSourceStrictness DecidedStrict) (Rec0 Bool) :*: S1 (MetaSel (Just "cfish") NoSourceUnpackedness NoSourceStrictness DecidedStrict) (Rec0 Bool))))

isHorrorFact :: Faction -> Bool Source #

Tell whether the faction consists of summoned horrors only.

Horror player is special, for summoned actors that don't belong to any of the main players of a given game. E.g., animals summoned during a skirmish game between two hero factions land in the horror faction. In every game, either all factions for which summoning items exist should be present or a horror player should be added to host them.

isFoe :: FactionId -> Faction -> FactionId -> Bool Source #

Check if factions are at war. Assumes symmetry.

isFriend :: FactionId -> Faction -> FactionId -> Bool Source #

Check if factions are allied or are the same faction. Assumes symmetry.

Internal operations