All Downloads are FREE. Search and download functionalities are using the official Maven repository.

pacman.controllers.Controller Maven / Gradle / Ivy

package pacman.controllers;

import pacman.game.Game;

/**
 * This class is the superclass of your controller. In contains the code required to run the
 * controller as a thread. In provides numerous methods that allow the Executor to use the
 * controller in various different execution modes. Your controller only needs to provide the
 * code for the getMove() method.
 *
 * @param  The generic type of the move to be returned (either a single move for Ms Pac-Man or an EnumMap for the ghosts).
 */
public abstract class Controller implements Runnable {
    protected T lastMove;    //this is now protected. You can set this directly in your getMove() method to save an immediate response.
    private boolean alive, wasSignalled, hasComputed;
    private volatile boolean threadStillRunning;
    private long timeDue;
    private Game game;
    private String name = "Unknown Controller";

    /**
     * Instantiates a new controller. The constructor initialises the class variables.
     */
    public Controller() {
        alive = true;
        wasSignalled = false;
        hasComputed = false;
        threadStillRunning = false;
    }

    /**
     * Terminates the controller: a signal is sent and the flag 'alive' is set to false. When
     * the thread wakes up, the outer loop will terminate and the thread finishes.
     */
    public final void terminate() {
        alive = false;
        wasSignalled = true;

        synchronized (this) {
            notify();
        }
    }

    /**
     * Updates the game state: a copy of the game is passed to this method and the class variable is
     * updated accordingly.
     *
     * @param game    A copy of the current game
     * @param timeDue The time the next move is due
     */
    public final void update(Game game, long timeDue) {
        synchronized (this) {
            this.game = game;
            this.timeDue = timeDue;
            wasSignalled = true;
            hasComputed = false;
            notify();
        }
    }

    /**
     * Retrieves the move from the controller (whatever is stored in the class variable).
     *
     * @return The move stored in the class variable 'lastMove'
     */
    public final T getMove() {
        return lastMove;
    }

    /* (non-Javadoc)
     * @see java.lang.Runnable#run()
     */
    public final void run() {
        while (alive) {
            synchronized (this) {
                while (!wasSignalled) {
                    try {
                        wait();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }

                if (!threadStillRunning) {
                    new Thread() {
                        public void run() {
                            threadStillRunning = true;
                            lastMove = getMove(game, timeDue);
                            hasComputed = true;
                            threadStillRunning = false;
                        }
                    }.start();
                }

                wasSignalled = false;
            }
        }
    }

    /**
     * This method is used to check whether the controller computed a move since the last
     * update of the game.
     *
     * @return Whether or not the controller computed a move since the last update
     */
    public final boolean hasComputed() {
        return hasComputed;
    }

    /**
     * Compute the next move given a copy of the current game and a time the move has to be computed by.
     * This is the method contestants need to implement. Many examples are available in
     * pacman.controllers.examples
     * Your controllers must be in the files: pacman.entries.pacman.MyPacMan.java for Pac-Man controllers or
     * pacman.entries.ghosts.MyGhosts.java for ghosts controllers.
     *
     * @param game    A copy of the current game
     * @param timeDue The time the next move is due
     * @return The move to be played (i.e., the move calculated by your controller)
     */
    public abstract T getMove(Game game, long timeDue);

    /**
     * Gets the name of the controller
     *
     * @return The name of the controller
     */
    public String getName() {
        return name;
    }

    /**
     * Used for recognising a controller
     *
     * @param name Name of the controller
     */
    public final void setName(String name) {
        this.name = name;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy