PROFESSIONAL ACADEMIC STUDY RESOURCES WEBSITE +1 813 434 1028 proexpertwritings@hotmail.com
Java Programming
Open the zuul-bad project in BlueJ and save it as LastName-zuul1, using your last name, e.g., Smith-zuul1.
Start by completing Exercises 6e: 8.1, 8.2, and 8.3 There is nothing to turn in for these exercises. As you design your game scenario, keep in mind the following:
Your game should have at least 6 rooms and no more than 10 rooms.
Each room should have a descriptive name.
Your rooms should be different from the rooms in the program already. Do not simply extend the existing scenario; create your own.
Be creative. This game scenario will be the basis for future assignments so make it something that will keep your interest.
Complete Exercise 6e: 8.4
Create a map of your game scenario in any common electronic format (such as .pdf, .doc, .pptx, .jpg, etc.).
Update the source code of your zuul project to create the rooms and connections as you designed them.
Update the welcome and help messages to match your scenario.
The rooms created in your zuul project and the connections from one room to another should match your map.
Make sure the connections between rooms are clear in your map. I will assume that connections between rooms are bidirectional unless you indicate otherwise (e.g., with arrowheads).
Test your program.
Document your changes.
Adjust the comment block at the top of the file to include a 1-2 sentence description of your specific game scenario.
Add your name to the @author list and update the version.
When you have completed the assignment, create a jar file of your project:
From BlueJ, choose Project->Create Jar File…
Check the “Include source” checkbox ← Very important!
Name the file LastName-zuul1
Part 3: Git
In this part, you will install Git, a version control system, and use it to track source code for a simple project. Version control systems have two big advantages: (1) tracking versions of source code, and (2) facilitating collaboration among multiple developers working on the same code. In this lab, you will learn to use Git to track versions of source code.
Note: This part is a repeat of an assignment from CIS 133J. If you already have Git installed you don’t need to do that step, but you should complete all the other steps anew. Practicing the Git flow again will help you learn it. Do not resubmit a project from 133J. Each time you commit, a timestamp is associated with the commit.
Walk through all the documents in the module Version Control with Git, learning about version control and following along with the steps. You may want to keep the Git Cheat Sheet for CIS 133J handy.
Git and Version Control – informational.
Install and Set Up Git – steps you need to follow to install Git on your local system.
Set Up a Repository for a Project – steps you need to follow to create a local repository for a Java project.
Add Features to a Project – steps you need to follow to add features to your Java project while tracking the changes in the repository.
In the process of walking through the documents above you should have created a Hello World project and repository, which is what you will submit for this part of the lab.
For full credit, your project repository must meet the criteria below. (If you followed along with the videos, you should have everything you need.)
The Java code must compile and run without error, printing a hello message to the terminal.
The repository must have a feature branch on which the work was done, which has been merged into the master. (Check with ‘git branch’ – your feature branch should be listed.)
There must be at least 2 commits with feature work, beyond initializing the project. (Check with ‘git log’)
Your commits must have descriptive messages.
Your commits must have timestamps from this quarter.
Your name and email address must be set up in your Git installation. (Look at the Author line in ‘git log’)
The repository must be clean with no uncommitted changes. (When you do ‘git status’ it should say “On branch master, nothing to commit, working tree clean”)
Your submission for this part should be a zip file containing your project folder (e.g., hello-world). Creating a jar file from the BlueJ project is not sufficient because the jar does not include the repository files. Git uses a hidden folder named .git to store its internal files, and this folder needs to be in the zip file along with your project files.
game
/**
* This class is the main class of the “World of Zuul” application.
* “World of Zuul” is a very simple, text based adventure game. Users
* can walk around some scenery. That’s all. It should really be extended
* to make it more interesting!
*
* To play this game, create an instance of this class and call the “play”
* method.
*
* This main class creates and initialises all the others: it creates all
* rooms, creates the parser and starts the game. It also evaluates and
* executes the commands that the parser returns.
*
* @author Michael Kölling and David J. Barnes
* @version 2016.02.29
*/
public class Game
{
private Parser parser;
private Room currentRoom;
/**
* Create the game and initialise its internal map.
*/
public Game()
{
createRooms();
parser = new Parser();
}
/**
* Create all the rooms and link their exits together.
*/
private void createRooms()
{
Room outside, theater, pub, lab, office;
// create the rooms
outside = new Room(“outside the main entrance of the university”);
theater = new Room(“in a lecture theater”);
pub = new Room(“in the campus pub”);
lab = new Room(“in a computing lab”);
office = new Room(“in the computing admin office”);
// initialise room exits
outside.setExits(null, theater, lab, pub);
theater.setExits(null, null, null, outside);
pub.setExits(null, outside, null, null);
lab.setExits(outside, office, null, null);
office.setExits(null, null, null, lab);
currentRoom = outside; // start game outside
}
/**
* Main play routine. Loops until end of play.
*/
public void play()
{
printWelcome();
// Enter the main command loop. Here we repeatedly read commands and
// execute them until the game is over.
boolean finished = false;
while (! finished) {
Command command = parser.getCommand();
finished = processCommand(command);
}
System.out.println(“Thank you for playing. Good bye.”);
}
/**
* Print out the opening message for the player.
*/
private void printWelcome()
{
System.out.println();
System.out.println(“Welcome to the World of Zuul!”);
System.out.println(“World of Zuul is a new, incredibly boring adventure game.”);
System.out.println(“Type ‘help’ if you need help.”);
System.out.println();
System.out.println(“You are ” + currentRoom.getDescription());
System.out.print(“Exits: “);
if(currentRoom.northExit != null) {
System.out.print(“north “);
}
if(currentRoom.eastExit != null) {
System.out.print(“east “);
}
if(currentRoom.southExit != null) {
System.out.print(“south “);
}
if(currentRoom.westExit != null) {
System.out.print(“west “);
}
System.out.println();
}
/**
* Given a command, process (that is: execute) the command.
* @param command The command to be processed.
* @return true If the command ends the game, false otherwise.
*/
private boolean processCommand(Command command)
{
boolean wantToQuit = false;
if(command.isUnknown()) {
System.out.println(“I don’t know what you mean…”);
return false;
}
String commandWord = command.getCommandWord();
if (commandWord.equals(“help”)) {
printHelp();
}
else if (commandWord.equals(“go”)) {
goRoom(command);
}
else if (commandWord.equals(“quit”)) {
wantToQuit = quit(command);
}
return wantToQuit;
}
// implementations of user commands:
/**
* Print out some help information.
* Here we print some stupid, cryptic message and a list of the
* command words.
*/
private void printHelp()
{
System.out.println(“You are lost. You are alone. You wander”);
System.out.println(“around at the university.”);
System.out.println();
System.out.println(“Your command words are:”);
System.out.println(” go quit help”);
}
/**
* Try to go in one direction. If there is an exit, enter
* the new room, otherwise print an error message.
*/
private void goRoom(Command command)
{
if(!command.hasSecondWord()) {
// if there is no second word, we don’t know where to go…
System.out.println(“Go where?”);
return;
}
String direction = command.getSecondWord();
// Try to leave current room.
Room nextRoom = null;
if(direction.equals(“north”)) {
nextRoom = currentRoom.northExit;
}
if(direction.equals(“east”)) {
nextRoom = currentRoom.eastExit;
}
if(direction.equals(“south”)) {
nextRoom = currentRoom.southExit;
}
if(direction.equals(“west”)) {
nextRoom = currentRoom.westExit;
}
if (nextRoom == null) {
System.out.println(“There is no door!”);
}
else {
currentRoom = nextRoom;
System.out.println(“You are ” + currentRoom.getDescription());
System.out.print(“Exits: “);
if(currentRoom.northExit != null) {
System.out.print(“north “);
}
if(currentRoom.eastExit != null) {
System.out.print(“east “);
}
if(currentRoom.southExit != null) {
System.out.print(“south “);
}
if(currentRoom.westExit != null) {
System.out.print(“west “);
}
System.out.println();
}
}
/**
* “Quit” was entered. Check the rest of the command to see
* whether we really quit the game.
* @return true, if this command quits the game, false otherwise.
*/
private boolean quit(Command command)
{
if(command.hasSecondWord()) {
System.out.println(“Quit what?”);
return false;
}
else {
return true; // signal that we want to quit
}
}
}
” command
*/
public class Command
{
private String commandWord;
private String secondWord;
/**
* Create a command object. First and second word must be supplied, but
* either one (or both) can be null.
* @param firstWord The first word of the command. Null if the command
* was not recognised.
* @param secondWord The second word of the command.
*/
public Command(String firstWord, String secondWord)
{
commandWord = firstWord;
this.secondWord = secondWord;
}
/**
* Return the command word (the first word) of this command. If the
* command was not understood, the result is null.
* @return The command word.
*/
public String getCommandWord()
{
return commandWord;
}
/**
* @return The second word of this command. Returns null if there was no
* second word.
*/
public String getSecondWord()
{
return secondWord;
}
/**
* @return true if this command was not understood.
*/
public boolean isUnknown()
{
return (commandWord == null);
}
/**
* @return true if the command has a second word.
*/
public boolean hasSecondWord()
{
return (secondWord != null);
}
}
room ”
*/
public class Room
{
public String description;
public Room northExit;
public Room southExit;
public Room eastExit;
public Room westExit;
/**
* Create a room described “description”. Initially, it has
* no exits. “description” is something like “a kitchen” or
* “an open court yard”.
* @param description The room’s description.
*/
public Room(String description)
{
this.description = description;
}
/**
* Define the exits of this room. Every direction either leads
* to another room or is null (no exit there).
* @param north The north exit.
* @param east The east east.
* @param south The south exit.
* @param west The west exit.
*/
public void setExits(Room north, Room east, Room south, Room west)
{
if(north != null) {
northExit = north;
}
if(east != null) {
eastExit = east;
}
if(south != null) {
southExit = south;
}
if(west != null) {
westExit = west;
}
}
/**
* @return The description of the room.
*/
public String getDescription()
{
return description;
}
}
“Parser
*/
public class Parser
{
private CommandWords commands; // holds all valid command words
private Scanner reader; // source of command input
/**
* Create a parser to read from the terminal window.
*/
public Parser()
{
commands = new CommandWords();
reader = new Scanner(System.in);
}
/**
* @return The next command from the user.
*/
public Command getCommand()
{
String inputLine; // will hold the full input line
String word1 = null;
String word2 = null;
System.out.print(“> “); // print prompt
inputLine = reader.nextLine();
// Find up to two words on the line.
Scanner tokenizer = new Scanner(inputLine);
if(tokenizer.hasNext()) {
word1 = tokenizer.next(); // get first word
if(tokenizer.hasNext()) {
word2 = tokenizer.next(); // get second word
// note: we just ignore the rest of the input line.
}
}
// Now check whether this word is known. If so, create a command
// with it. If not, create a “null” command (for unknown command).
if(commands.isCommand(word1)) {
return new Command(word1, word2);
}
else {
return new Command(null, word2);
}
}
}
“command Words ”
*/
public class CommandWords
{
// a constant array that holds all valid command words
private static final String[] validCommands = {
“go”, “quit”, “help”
};
/**
* Constructor – initialise the command words.
*/
public CommandWords()
{
// nothing to do at the moment…
}
/**
* Check whether a given String is a valid command word.
* @return true if a given string is a valid command,
* false if it isn’t.
*/
public boolean isCommand(String aString)
{
for(int i = 0; i < validCommands.length; i++) { if(validCommands[i].equals(aString)) return true; } // if we get here, the string was not found in the commands return false; } }