IGame.java :  » Game » megamek-0.35.15 » megamek » common » Java Open Source

Java Open Source » Game » megamek 0.35.15 
megamek 0.35.15 » megamek » common » IGame.java
/*
 * MegaMek - Copyright (C) 2005 Ben Mazur (bmazur@sev.org)
 *
 *  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.
 */

package megamek.common;

import java.util.ArrayList;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.List;
import java.util.Vector;

import megamek.common.actions.ArtilleryAttackAction;
import megamek.common.actions.AttackAction;
import megamek.common.actions.EntityAction;
import megamek.common.event.GameEvent;
import megamek.common.event.GameListener;
import megamek.common.options.GameOptions;
import megamek.common.weapons.AttackHandler;
import megamek.server.SmokeCloud;
import megamek.server.victory.Victory;

/**
 * This interface is the root of all data about the game in progress. Both the
 * Client and the Server should have one of these objects and it is their job to
 * keep it synched. note from itmo: this needs WAY MORE javadoc. also preferably
 * remove the abstract-modifiers and divide this interface into two
 * subinterfaces for reading and modifying. -stuff should be documented as
 * contracts. bad example of javadoccing found in getVictory* ... also phases
 * should be documented. wtf is an exchange-phase?
 */
public interface IGame {

    public enum Phase {
        PHASE_UNKNOWN,
        PHASE_LOUNGE,
        PHASE_SELECTION,
        PHASE_EXCHANGE,
        PHASE_DEPLOYMENT,
        PHASE_INITIATIVE,
        PHASE_INITIATIVE_REPORT,
        PHASE_TARGETING,
        PHASE_TARGETING_REPORT,
        PHASE_MOVEMENT,
        PHASE_MOVEMENT_REPORT,
        PHASE_OFFBOARD,
        PHASE_OFFBOARD_REPORT,
        PHASE_FIRING,
        PHASE_FIRING_REPORT,
        PHASE_PHYSICAL,
        PHASE_PHYSICAL_REPORT,
        PHASE_END,
        PHASE_END_REPORT,
        PHASE_VICTORY,
        PHASE_DEPLOY_MINEFIELDS,
        PHASE_STARTING_SCENARIO,
        PHASE_SET_ARTYAUTOHITHEXES;

        /**
         * @param phase_deployment2
         * @return
         */
        public boolean isDuringOrAfter(Phase otherPhase) {
            return compareTo(otherPhase) >= 0;
        }

        /**
         * @param phase_offboard2
         * @return
         */
        public boolean isBefore(Phase otherPhase) {
            return compareTo(otherPhase) < 0;
        }
    }

    // New accessors for external game id
    public abstract int getExternalGameId();

    public abstract void setExternalGameId(int value);

    /**
     * @return the currently active context-object for victorycondition
     *         checking. This should be a mutable object and it will be modified
     *         by the victory condition checkers. whoever saves the game state
     *         when doing saves, is also responsible of saving this state. at
     *         the start of the game this should be initialized to an empty
     *         hashmap
     */
    public abstract HashMap<String, Object> getVictoryContext();

    /**
     * set the game victory state.
     */
    public abstract void setVictoryContext(HashMap<String, Object> ctx);

    /**
     * Adds the specified game listener to receive board events from this Game.
     *
     * @param listener the game listener.
     */
    public abstract void addGameListener(GameListener listener);

    /**
     * Removes the specified game listener.
     *
     * @param listener the game listener.
     */
    public abstract void removeGameListener(GameListener listener);

    /**
     * Returns all the GameListeners.
     *
     * @return
     */
    public abstract Vector<GameListener> getGameListeners();

    /**
     * purges all Game Listener objects.
     */
    public abstract void purgeGameListeners();

    /**
     * Processes game events by dispatching them to any registered GameListener
     * objects.
     *
     * @param event the game event.
     */
    public abstract void processGameEvent(GameEvent event);

    /**
     * Check if there is a minefield at given coords
     *
     * @param coords coords to check
     * @return <code>true</code> if there is a minefield at given coords or
     *         <code>false</code> otherwise
     */
    public abstract boolean containsMinefield(Coords coords);

    /**
     * Get the minefields at specified coords
     *
     * @param coords
     * @return the <code>Vector</code> of minefields at specified coord
     */
    public abstract Vector<Minefield> getMinefields(Coords coords);

    /**
     * Get the number of the minefields at specified coords
     *
     * @param coords
     * @return the number of the minefields at specified coord
     */
    public abstract int getNbrMinefields(Coords coords);

    /**
     * Get the coordinates of all mined hexes in the game.
     *
     * @return an <code>Enumeration</code> of the <code>Coords</code>
     *         containing minefilds. This will not be <code>null</code>.
     */
    public abstract Enumeration<Coords> getMinedCoords();

    /**
     * Addds the specified minefield
     *
     * @param mf minefield to add
     */
    public abstract void addMinefield(Minefield mf);

    /**
     * Adds a number of minefields
     *
     * @param minefields the <code>Vector</code> of the minefields to add
     */
    public abstract void addMinefields(Vector<Minefield> minefields);

    /**
     * Sets the minefields to the given <code>Vector</code> of the minefields
     *
     * @param minefields
     */
    public abstract void setMinefields(Vector<Minefield> minefields);

    /**
     * Resets the minefield density for a given <code>Vector</code> of minefields
     * @param newMinefields
     */
    public abstract void resetMinefieldDensity(Vector<Minefield> newMinefields);

    /**
     * Removes the specified minefield
     *
     * @param mf minefield to remove
     */
    public abstract void removeMinefield(Minefield mf);

    /**
     * Removes all minefields
     */
    public abstract void clearMinefields();

    /**
     * @return the <code>Vector</code> of the vibrabombs
     */
    public abstract Vector<Minefield> getVibrabombs();

    /**
     * Addds the specified vibrabomb
     *
     * @param mf Vibrabomb to add
     */
    public abstract void addVibrabomb(Minefield mf);

    /**
     * Removes the specified Vibrabomb
     *
     * @param mf Vibrabomb to remove
     */
    public abstract void removeVibrabomb(Minefield mf);

    /**
     * Checks if the game contains the specified Vibrabomb
     *
     * @param mf the Vibrabomb to ceck
     * @return true iff the minefield contains a vibrabomb.
     */
    public abstract boolean containsVibrabomb(Minefield mf);

    /**
     * @return game options
     */
    public abstract GameOptions getOptions();

    /**
     * sets the game options
     *
     * @param options
     */
    public abstract void setOptions(GameOptions options);

    /**
     * @return the game board
     */
    public abstract IBoard getBoard();

    /**
     * Sets the new game board
     *
     * @param board
     */
    public abstract void setBoard(IBoard board);

    /**
     * Return an enumeration of teams in the game
     */
    public abstract Enumeration<Team> getTeams();

    /**
     * Return the current number of teams in the game.
     */
    public abstract int getNoOfTeams();

    /**
     * Return the immutable vector of teams
     */
    public abstract Vector<Team> getTeamsVector();

    /**
     * Return a players team Note: may return null if player has no team
     */
    public abstract Team getTeamForPlayer(Player p);

    /**
     * Set up the teams vector. Each player on a team (Team 1 .. Team X) is
     * placed in the appropriate vector. Any player on 'No Team', is placed in
     * their own object
     */
    public abstract void setupTeams();

    /**
     * Return an enumeration of player in the game
     */
    public abstract Enumeration<Player> getPlayers();

    /**
     * Return the players vector
     */
    public abstract Vector<Player> getPlayersVector();

    /**
     * Return the current number of active players in the game.
     */
    public abstract int getNoOfPlayers();

    /**
     * Returns the individual player assigned the id parameter.
     */
    public abstract Player getPlayer(int id);

    public abstract void addPlayer(int id, Player player);

    public abstract void setPlayer(int id, Player player);

    public abstract void removePlayer(int id);

    /**
     * Returns the number of entities owned by the player, regardless of their
     * status, as long as they are in the game.
     */
    public abstract int getEntitiesOwnedBy(Player player);

    /**
     * Returns the number of entities owned by the player, regardless of their
     * status.
     */
    public abstract int getAllEntitiesOwnedBy(Player player);

    /**
     * Returns the number of non-destroyed entityes owned by the player
     */
    public abstract int getLiveEntitiesOwnedBy(Player player);

    /**
     * Returns the number of non-destroyed deployed entities owned by the
     * player. Ignore offboard units and captured Mek pilots.
     */
    public abstract int getLiveDeployedEntitiesOwnedBy(Player player);

    /**
     * Returns the number of non-destroyed deployed entities owned by the
     * player. Ignore offboard units and captured Mek pilots.
     */
    public abstract int getLiveCommandersOwnedBy(Player player);

    /**
     * Returns true if the player has a valid unit with the Tactical Genius
     * pilot special ability.
     */
    public abstract boolean hasTacticalGenius(Player player);

    /**
     * Get a vector of entity objects that are "acceptable" to attack with this
     * entity
     */
    public abstract Vector<Entity> getValidTargets(Entity entity);

    /**
     * Returns true if this phase has turns. If false, the phase is simply
     * waiting for everybody to declare "done".
     */
    public abstract boolean phaseHasTurns(IGame.Phase phase);

    /**
     * @return true if the current phase can be played simultaneously
     */
    public abstract boolean isPhaseSimultaneous();

    /**
     * Returns the current GameTurn object
     */
    public abstract GameTurn getTurn();

    /**
     * @return the first GameTurn object for the specified player, or null
     * if the player has no turns to play
     */
    public abstract GameTurn getTurnForPlayer(int pn);

    /**
     * Changes to the next turn, returning it.
     */
    public abstract GameTurn changeToNextTurn();

    /**
     * Resets the turn index to -1 (awaiting first turn)
     */
    public abstract void resetTurnIndex();

    /**
     * Returns true if there is a turn after the current one
     */
    public abstract boolean hasMoreTurns();

    /**
     * Inserts a turn that will come directly after the current one
     */
    public abstract void insertNextTurn(GameTurn turn);

    /**
     * Returns an Enumeration of the current turn list
     */
    public abstract Enumeration<GameTurn> getTurns();

    /**
     * Returns the current turn index
     */
    public abstract int getTurnIndex();

    /**
     * Sets the current turn index
     */
    public abstract void setTurnIndex(int turnIndex);

    /**
     * Returns the current turn vector
     */
    public abstract Vector<GameTurn> getTurnVector();

    /**
     * Sets the current turn vector
     */
    public abstract void setTurnVector(Vector<GameTurn> turnVector);

    public abstract IGame.Phase getPhase();

    public abstract void setPhase(IGame.Phase phase);

    public abstract IGame.Phase getLastPhase();

    public abstract void setLastPhase(IGame.Phase lastPhase);

    public abstract void setDeploymentComplete(boolean deploymentComplete);

    public abstract boolean isDeploymentComplete();

    /**
     * Sets up up the hashtable of who deploys when
     */
    public abstract void setupRoundDeployment();

    /**
     * Checks to see if we've past our deployment completion
     */
    public abstract void checkForCompleteDeployment();

    /**
     * Check to see if we should deploy this round
     */
    public abstract boolean shouldDeployThisRound();

    public abstract boolean shouldDeployForRound(int round);

    /**
     * Clear this round from this list of entities to deploy
     */
    public abstract void clearDeploymentThisRound();

    /**
     * Returns a vector of entities that have not yet deployed
     */
    public abstract Vector<Entity> getUndeployedEntities();

    /**
     * Returns an enumeration of all the entites in the game.
     */
    public abstract Enumeration<Entity> getEntities();

    /**
     * Returns the actual vector for the entities
     */
    public abstract Vector<Entity> getEntitiesVector();

    public abstract void setEntitiesVector(Vector<Entity> entities);

    /**
     * Returns the actual vector for the out-of-game entities
     */
    public abstract Vector<Entity> getOutOfGameEntitiesVector();

    /**
     * Returns an out-of-game entity.
     *
     * @param id the <code>int</code> ID of the out-of-game entity.
     * @return the out-of-game <code>Entity</code> with that ID. If no
     *         out-of-game entity has that ID, returns a <code>null</code>.
     */
    public abstract Entity getOutOfGameEntity(int id);

    /**
     * Swap out the current list of dead (or fled) units for a new one.
     *
     * @param vOutOfGame - the new <code>Vector</code> of dead or fled units.
     *            This value should <em>not</em> be <code>null</code>.
     * @throw <code>IllegalArgumentException</code> if the new list is
     *        <code>null</code>.
     */
    public abstract void setOutOfGameEntitiesVector(Vector<Entity> vOutOfGame);

    /**
     * Returns a <code>Vector</code> containing the <code>Entity</code>s
     * that are in the same C3 network as the passed-in unit. The output will
     * contain the passed-in unit, if the unit has a C3 computer. If the unit
     * has no C3 computer, the output will be empty (but it will never be
     * <code>null</code>).
     *
     * @param entity - the <code>Entity</code> whose C3 network co- members is
     *            required. This value may be <code>null</code>.
     * @return a <code>Vector</code> that will contain all other
     *         <code>Entity</code>s that are in the same C3 network as the
     *         passed-in unit. This <code>Vector</code> may be empty, but it
     *         will not be <code>null</code>.
     * @see #getC3SubNetworkMembers(Entity)
     */
    public abstract Vector<Entity> getC3NetworkMembers(Entity entity);

    /**
     * Returns a <code>Vector</code> containing the <code>Entity</code>s
     * that are in the C3 sub-network under the passed-in unit. The output will
     * contain the passed-in unit, if the unit has a C3 computer. If the unit
     * has no C3 computer, the output will be empty (but it will never be
     * <code>null</code>). If the passed-in unit is a company commander or a
     * member of a C3i network, this call is the same as
     * <code>getC3NetworkMembers</code>.
     *
     * @param entity - the <code>Entity</code> whose C3 network sub- members
     *            is required. This value may be <code>null</code>.
     * @return a <code>Vector</code> that will contain all other
     *         <code>Entity</code>s that are in the same C3 network under the
     *         passed-in unit. This <code>Vector</code> may be empty, but it
     *         will not be <code>null</code>.
     * @see #getC3NetworkMembers(Entity)
     */
    public abstract Vector<Entity> getC3SubNetworkMembers(Entity entity);

    /**
     * Returns a <code>Hashtable</code> that maps the <code>Coords</code> of
     * each unit in this <code>Game</code> to a <code>Vector</code> of
     * <code>Entity</code>s at that positions. Units that have no position
     * (e.g. loaded units) will not be in the map.
     *
     * @return a <code>Hashtable</code> that maps the <code>Coords</code>
     *         positions or each unit in the game to a <code>Vector</code> of
     *         <code>Entity</code>s at that position.
     */
    public abstract Hashtable<Coords, Vector<Entity>> getPositionMap();

    /**
     * Returns an enumeration of salvagable entities.
     */
    public abstract Enumeration<Entity> getGraveyardEntities();

    /**
     * Returns an enumeration of wrecked entities.
     */
    public abstract Enumeration<Entity> getWreckedEntities();

    /**
     * Returns an enumeration of entities that have retreated
     */
    public abstract Enumeration<Entity> getRetreatedEntities();

    /**
     * Returns an enumeration of entities that were utterly destroyed
     */
    public abstract Enumeration<Entity> getDevastatedEntities();

    /**
     * Return the current number of entities in the game.
     */
    public abstract int getNoOfEntities();

    /**
     * Returns the appropriate target for this game given a type and id
     */
    public abstract Targetable getTarget(int nType, int nID);

    /**
     * Returns the entity with the given id number, if any.
     */
    public abstract Entity getEntity(int id);

    public abstract void addEntity(int id, Entity entity);

    public abstract void setEntity(int id, Entity entity);

    public void setEntity(int id, Entity entity, Vector<UnitLocation> movePath);

    /**
     * @return int containing an unused entity id
     */
    public abstract int getNextEntityId();

    /**
     * @return <code>true</code> if an entity with the specified id number
     *         exists in this game.
     */
    public abstract boolean hasEntity(int entityId);

    /**
     * Remove an entity from the master list. If we can't find that entity,
     * (probably due to double-blind) ignore it.
     */
    public abstract void removeEntity(int id, int condition);

    /**
     * Resets this game by removing all entities.
     */
    public abstract void reset();

    /**
     * add a smoke cloud to the list of smoke clouds
     */
    public abstract void addSmokeCloud(SmokeCloud cloud);

    /**
     * get the list of smokeclouds
     */
    public abstract List<SmokeCloud> getSmokeCloudList();

    /**
     * Returns the first entity at the given coordinate, if any. Only returns
     * targetable (non-dead) entities.
     *
     * @param c the coordinates to search at
     */
    public abstract Entity getFirstEntity(Coords c);

    /**
     * Returns the first enemy entity at the given coordinate, if any. Only
     * returns targetable (non-dead) entities.
     *
     * @param c the coordinates to search at
     * @param currentEntity the entity that is firing
     */
    public abstract Entity getFirstEnemyEntity(Coords c, Entity currentEntity);

    /**
     * Returns an Enumeration of the active entities at the given coordinates.
     */
    public abstract Enumeration<Entity> getEntities(Coords c);

    /**
     * Returns a Vector of the active entities at the given coordinates.
     */
    public abstract Vector<Entity> getEntitiesVector(Coords c);

    /**
     * Returns a Vector of the gun emplacements at the given coordinates.
     */
    public abstract Vector<GunEmplacement> getGunEmplacements(Coords c);
    
    /**
     * Returns a Target for an Accidental Fall From above, or null if no
     * possible target is there
     *
     * @param c The <code>Coords</code> of the hex in which the accidental
     *            fall from above happens
     * @param ignore The entity who is falling, so shouldn't be returned
     * @return The <code>Entity</code> that should be an AFFA target.
     */
    public abstract Entity getAffaTarget(Coords c, Entity ignore);

    /**
     * Returns an <code>Enumeration</code> of the enemy's active entities at
     * the given coordinates.
     *
     * @param c the <code>Coords</code> of the hex being examined.
     * @param currentEntity the <code>Entity</code> whose enemies are needed.
     * @return an <code>Enumeration</code> of <code>Entity</code>s at the
     *         given coordinates who are enemies of the given unit.
     */
    public abstract Enumeration<Entity> getEnemyEntities(final Coords c,
            final Entity currentEntity);

    /**
     * Returns an <code>Enumeration</code> of friendly active entities at the
     * given coordinates.
     *
     * @param c the <code>Coords</code> of the hex being examined.
     * @param currentEntity the <code>Entity</code> whose friends are needed.
     * @return an <code>Enumeration</code> of <code>Entity</code>s at the
     *         given coordinates who are friends of the given unit.
     */
    public abstract Enumeration<Entity> getFriendlyEntities(final Coords c,
            final Entity currentEntity);

    /**
     * Moves an entity into the graveyard so it stops getting sent out every
     * phase.
     */
    public abstract void moveToGraveyard(int id);

    /**
     * See if the <code>Entity</code> with the given ID is out of the game.
     *
     * @param id - the ID of the <code>Entity</code> to be checked.
     * @return <code>true</code> if the <code>Entity</code> is in the
     *         graveyard, <code>false</code> otherwise.
     */
    public abstract boolean isOutOfGame(int id);

    /**
     * See if the <code>Entity</code> is out of the game.
     *
     * @param entity - the <code>Entity</code> to be checked.
     * @return <code>true</code> if the <code>Entity</code> is in the
     *         graveyard, <code>false</code> otherwise.
     */
    public abstract boolean isOutOfGame(Entity entity);

    /**
     * Returns the first entity that can act in the present turn, or null if
     * none can.
     */
    public abstract Entity getFirstEntity();

    /**
     * Returns the first entity that can act in the specified turn, or null if
     * none can.33
     */
    public abstract Entity getFirstEntity(GameTurn turn);

    /**
     * Returns the id of the first entity that can act in the current turn, or
     * -1 if none can.
     */
    public abstract int getFirstEntityNum();

    /**
     * Returns the id of the first entity that can act in the specified turn, or
     * -1 if none can.
     */
    public abstract int getFirstEntityNum(GameTurn turn);

    /**
     * Returns the next selectable entity that can act this turn, or null if
     * none can.
     *
     * @param start the index number to start at
     */
    public abstract Entity getNextEntity(int start);

    /**
     * Returns the next selectable entity ID that can act this turn, or null if
     * none can.
     *
     * @param start the index number to start at
     */
    public abstract int getNextEntityNum(int start);

    /**
     * Returns the entity id of the next entity that can move during the
     * specified
     *
     * @param turn the turn to use
     * @param start the entity id to start at
     */
    public abstract int getNextEntityNum(GameTurn turn, int start);

    /**
     * Returns the number of the first deployable entity
     */
    public abstract int getFirstDeployableEntityNum();

    public abstract int getFirstDeployableEntityNum(GameTurn turn);

    /**
     * Returns the number of the next deployable entity
     */
    public abstract int getNextDeployableEntityNum(int entityId);

    public abstract int getNextDeployableEntityNum(GameTurn turn, int start);

    /**
     * Get the entities for the player.
     *
     * @param player - the <code>Player</code> whose entities are required.
     * @param hide - should fighters loaded into squadrons be excluded from this list?
     * @return a <code>Vector</code> of <code>Entity</code>s.
     */
    public abstract ArrayList<Entity> getPlayerEntities(Player player, boolean hide);

    /**
     * Determines if the indicated entity is stranded on a transport that can't
     * move. <p/> According to <a
     * href="http://www.classicbattletech.com/w3t/showflat.php?Cat=&Board=ask&Number=555466&page=2&view=collapsed&sb=5&o=0&fpart=">
     * Randall Bills</a>, the "minimum move" rule allow stranded units to
     * dismount at the start of the turn.
     *
     * @param entity the <code>Entity</code> that may be stranded
     * @return <code>true</code> if the entity is stranded <code>false</code>
     *         otherwise.
     */
    public abstract boolean isEntityStranded(Entity entity);

    /**
     * Returns the number of remaining selectable infantry owned by a player.
     */
    public abstract int getInfantryLeft(int playerId);

    /**
     * Returns the number of remaining selectable Protomechs owned by a player.
     */
    public abstract int getProtomechsLeft(int playerId);

    /**
     * Returns the number of remaining selectable Vehicles owned by a player.
     */
    public abstract int getVehiclesLeft(int playerId);

    /**
     * Removes the last, next turn found that the specified entity can move in.
     * Used when, say, an entity dies mid-phase.
     */
    public abstract void removeTurnFor(Entity entity);

    /**
     * Removes the first turn found that the specified entity can move in.
     * Used when a turn is played out of order
     */
    public abstract GameTurn removeFirstTurnFor(Entity entity);

    /**
     * Check each player for the presence of a Battle Armor squad equipped with
     * a Magnetic Clamp. If one unit is found, update that player's units to
     * allow the squad to be transported. <p/> This method should be called
     * </b>*ONCE*</b> per game, after all units for all players have been
     * loaded.
     *
     * @return <code>true</code> if a unit was updated, <code>false</code>
     *         if no player has a Battle Armor squad equipped with a Magnetic
     *         Clamp.
     */
    public abstract boolean checkForMagneticClamp();

    /** Adds the specified action to the actions list for this phase. */
    public abstract void addAction(EntityAction ea);

    public abstract void addAttack(AttackHandler ah);

    public abstract void removeAttack(AttackHandler ah);

    public abstract Enumeration<AttackHandler> getAttacks();

    public abstract Vector<AttackHandler> getAttacksVector();

    public abstract void resetAttacks();

    public int getArtillerySize();

    public void setArtilleryVector(Vector<ArtilleryAttackAction> v);

    public Enumeration<ArtilleryAttackAction> getArtilleryAttacks();

    // HACK.
    public abstract void setAttacksVector(Vector<AttackHandler> v);

    /**
     * Returns an Enumeration of actions scheduled for this phase.
     */
    public abstract Enumeration<EntityAction> getActions();

    /**
     * Resets the actions list.
     */
    public abstract void resetActions();

    /**
     * Removes all actions by the specified entity
     */
    public abstract void removeActionsFor(int entityId);

    /**
     * Remove a specified action
     *
     * @param o The action to remove.
     */
    public abstract void removeAction(Object o);

    public abstract int actionsSize();

    /**
     * Returns the actions vector. Do not use to modify the actions; I will be
     * angry. >:[ Used for sending all actions to the client.
     */
    public abstract Vector<EntityAction> getActionsVector();

    public abstract void addInitiativeRerollRequest(Team t);

    public abstract void rollInitAndResolveTies();

    public abstract int getNoOfInitiativeRerollRequests();

    /**
     * Adds a pending displacement attack to the list for this phase.
     */
    public abstract void addCharge(AttackAction ea);

    /**
     * Returns an Enumeration of displacement attacks scheduled for the end of
     * the physical phase.
     */
    public abstract Enumeration<AttackAction> getCharges();

    /**
     * Resets the pending charges list.
     */
    public abstract void resetCharges();

    /**
     * Returns the charges vector. Do not modify. >:[ Used for sending all
     * charges to the client.
     */
    public abstract Vector<AttackAction> getChargesVector();

    /**
     * Adds a pending ram attack to the list for this phase.
     */
    public abstract void addRam(AttackAction ea);

    /**
     * Returns an Enumeration of ram attacks scheduled for the end of
     * the physical phase.
     */
    public abstract Enumeration<AttackAction> getRams();

    /**
     * Resets the pending ram list.
     */
    public abstract void resetRams();

    /**
     * Returns the ram vector. Do not modify. >:[ Used for sending all
     * charges to the client.
     */
    public abstract Vector<AttackAction> getRamsVector();

    /**
     * Adds a pending tele-missile attack to the list for this phase.
     */
    public abstract void addTeleMissileAttack(AttackAction ea);

    /**
     * Returns an Enumeration of telemissile attacks scheduled for the end of
     * the physical phase.
     */
    public abstract Enumeration<AttackAction> getTeleMissileAttacks();

    /**
     * Resets the pending telemissile attack list.
     */
    public abstract void resetTeleMissileAttacks();

    /**
     * Returns the telemissile attack vector. Do not modify. >:[ Used for sending all
     * charges to the client.
     */
    public abstract Vector<AttackAction> getTeleMissileAttacksVector();

    /**
     * Adds a pending PSR to the list for this phase.
     */
    public abstract void addPSR(PilotingRollData psr);

    /**
     * Returns an Enumeration of pending PSRs.
     */
    public abstract Enumeration<PilotingRollData> getPSRs();

    /**
     * Adds a pending extreme Gravity PSR to the list for this phase.
     */
    public abstract void addExtremeGravityPSR(PilotingRollData psr);

    /**
     * Returns an Enumeration of pending extreme GravityPSRs.
     */
    public abstract Enumeration<PilotingRollData> getExtremeGravityPSRs();

    /**
     * Resets the PSR list for a given entity.
     */
    public abstract void resetPSRs(Entity entity);

    /**
     * Resets the extreme Gravity PSR list.
     */
    public abstract void resetExtremeGravityPSRs();

    /**
     * Resets the extreme Gravity PSR list for a given entity.
     */
    public abstract void resetExtremeGravityPSRs(Entity entity);

    /**
     * Resets the PSR list.
     */
    public abstract void resetPSRs();

    /**
     * Getter for property roundCount.
     *
     * @return Value of property roundCount.
     */
    public abstract int getRoundCount();

    public abstract void setRoundCount(int roundCount);

    /**
     * Increments the round counter
     */
    public abstract void incrementRoundCount();

    /**
     * Getter for property forceVictory. this tells us that a claim for victory
     * is active.
     *
     * @return Value of property forceVictory.
     */
    public abstract boolean isForceVictory();

    /**
     * Setter for property forceVictory.
     *
     * @param forceVictory New value of property forceVictory.
     */
    public abstract void setForceVictory(boolean forceVictory);

    /**
     * Adds the given reports vector to the GameReport collection.
     *
     * @param v Vector of reports
     */
    public abstract void addReports(Vector<Report> v);

    /**
     * Returns a vector of reports for the given round.
     *
     * @param r Round number
     */
    public abstract Vector<Report> getReports(int r);

    /**
     * Returns a vector of all the reports.
     */
    public abstract Vector<Vector<Report>> getAllReports();

    /**
     * Used to populate previous game reports, e.g. after a client connects to
     * an existing game.
     */
    public void setAllReports(Vector<Vector<Report>> v);

    /**
     * Clears out all the current reports, paving the way for a new game.
     */
    public void clearAllReports();

    public abstract void end(int winner, int winnerTeam);

    /**
     * Getter for property victoryPlayerId. itmo: apparently this is the guy who
     * claims to have won the game also used to tell who won when the game is
     * won
     *
     * @return Value of property victoryPlayerId.
     */
    public abstract int getVictoryPlayerId();

    /**
     * Setter for property victoryPlayerId.
     *
     * @param victoryPlayerId New value of property victoryPlayerId.
     */
    public abstract void setVictoryPlayerId(int victoryPlayerId);

    /**
     * Getter for property victoryTeam. corresponding claiming/winning team if
     * the player is in a team
     *
     * @return Value of property victoryTeam.
     */
    public abstract int getVictoryTeam();

    /**
     * Setter for property victoryTeam.
     *
     * @param victoryTeam New value of property victoryTeam.
     */
    public abstract void setVictoryTeam(int victoryTeam);

    /**
     * Returns true if the specified player is either the victor, or is on the
     * winning team. Best to call during PHASE_VICTORY.
     */
    public abstract boolean isPlayerVictor(Player player);

    /**
     * Shortcut to isPlayerVictor(Player player)
     */
    public abstract boolean isPlayerVictor(int playerId);

    /**
     * Get all <code>Entity</code>s that pass the given selection criteria.
     *
     * @param selector the <code>EntitySelector</code> that implements test
     *            that an entity must pass to be included. This value may be
     *            <code>null</code> (in which case all entities in the game
     *            will be returned).
     * @return an <code>Enumeration</code> of all entities that the selector
     *         accepts. This value will not be <code>null</code> but it may be
     *         empty.
     */
    public abstract Enumeration<Entity> getSelectedEntities(
            EntitySelector selector);

    /**
     * Count all <code>Entity</code>s that pass the given selection criteria.
     *
     * @param selector the <code>EntitySelector</code> that implements test
     *            that an entity must pass to be included. This value may be
     *            <code>null</code> (in which case the count of all entities
     *            in the game will be returned).
     * @return the <code>int</code> count of all entities that the selector
     *         accepts. This value will not be <code>null</code> but it may be
     *         empty.
     */
    public abstract int getSelectedEntityCount(EntitySelector selector);

    /**
     * Get all out-of-game <code>Entity</code>s that pass the given selection
     * criteria.
     *
     * @param selector the <code>EntitySelector</code> that implements test
     *            that an entity must pass to be included. This value may be
     *            <code>null</code> (in which case all entities in the game
     *            will be returned).
     * @return an <code>Enumeration</code> of all entities that the selector
     *         accepts. This value will not be <code>null</code> but it may be
     *         empty.
     */
    public abstract Enumeration<Entity> getSelectedOutOfGameEntities(
            EntitySelector selector);

    /**
     * Count all out-of-game<code>Entity</code>s that pass the given
     * selection criteria.
     *
     * @param selector the <code>EntitySelector</code> that implements test
     *            that an entity must pass to be included. This value may be
     *            <code>null</code> (in which case the count of all
     *            out-of-game entities will be returned).
     * @return the <code>int</code> count of all entities that the selector
     *         accepts. This value will not be <code>null</code> but it may be
     *         empty.
     */
    public abstract int getSelectedOutOfGameEntityCount(EntitySelector selector);

    /**
     * Returns true if the player has any valid units this turn that are not
     * infantry, not protomechs, or not either of those. This method is
     * utitilized by the "A players Infantry moves after that players other
     * units", and "A players Protomechs move after that players other units"
     * options.
     */
    public abstract boolean checkForValidNonInfantryAndOrProtomechs(int playerId);

    /**
     * Get Entities that have have a iNarc Nemesis pod attached and are situated
     * between two Coords
     *
     * @param attacker The attacking <code>Entity</code>.
     * @param target The <code>Coords</code> of the original target.
     * @return a <code>Enumeration</code> of entities that have nemesis pods
     *         attached and are located between attacker and target and are
     *         friendly with the attacker.
     */
    public abstract Enumeration<Entity> getNemesisTargets(Entity attacker,
            Coords target);

    /**
     * Returns the previous entity from the master list of entities. Will wrap
     * around to the end of the list if necessary.
     *
     * @param current The <code>Entity</code> whose list position you wish to
     *            start from.
     * @return The previous <code>Entity</code> in the list.
     */
    public abstract Entity getPreviousEntityFromList(Entity current);

    /**
     * Returns the next entity from the master list of entities. Will wrap
     * around to the begining of the list if necessary.
     *
     * @param current The <code>Entity</code> whose list position you wish to
     *            start from.
     * @return The next <code>Entity</code> in the list.
     */
    public abstract Entity getNextEntityFromList(Entity current);

    /**
     * Returns this turn's tag information
     */
    public abstract Vector<TagInfo> getTagInfo();

    /**
     * add the results of one tag attack
     */
    public abstract void addTagInfo(TagInfo info);

    /**
     * clears the "shots" attribute of all TagInfos where attacker is on same
     * team as ae and target is on same mapsheet as tc
     */
    public abstract void clearTagInfoShots(Entity ae, Coords tc);

    /**
     * Reset tag information
     */
    public abstract void resetTagInfo();

    /**
     * Get a list of flares
     */
    public abstract Vector<Flare> getFlares();

    /**
     * Set the list of flares
     */
    public abstract void setFlares(Vector<Flare> flares);

    /**
     * Add a new flare
     */
    public abstract void addFlare(Flare flare);

    /**
     * returns true if the hex is illuminated by a flare
     */
    public abstract boolean isPositionIlluminated(Coords c);

    /**
     * Age the flare list and remove any which have burnt out Artillery flares
     * drift with wind. (called at end of turn)
     */
    public abstract Vector<Report> ageFlares();

    public abstract boolean gameTimerIsExpired();

    /**
     * use victoryfactory to generate a new victorycondition checker provided
     * that the victorycontext is saved properly, calling this method at any
     * time is ok and should not affect anything unless the
     * victorycondition-configoptions have changed.
     */
    public abstract void createVictoryConditions();

    public abstract Victory getVictory();

    public abstract boolean useVectorMove();

    /**
     * Adds a pending control roll to the list for this phase.
     */
    public abstract void addControlRoll(PilotingRollData control);

    /**
     * Returns an Enumeration of pending Control roll.
     */
    public abstract Enumeration<PilotingRollData> getControlRolls();

    /**
     * Resets the Control Roll list for a given entity.
     */
    public abstract void resetControlRolls(Entity entity);

    /**
     * Resets the Control Roll list.
     */
    public abstract void resetControlRolls();

    public abstract boolean checkForValidSpaceStations(int playerId);

    public abstract boolean checkForValidJumpships(int playerId);

    public abstract boolean checkForValidWarships(int playerId);

    public abstract boolean checkForValidDropships(int playerId);

    public abstract boolean checkForValidSmallCraft(int playerId);

    public abstract PlanetaryConditions getPlanetaryConditions();

    public abstract void setPlanetaryConditions(PlanetaryConditions conditions);

}
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.