Results 1 to 6 of 6
Thread: Loose Coupling and Cohesion
- 08-10-2012, 03:11 AM #1
Member
- Join Date
- Aug 2012
- Posts
- 10
- Rep Power
- 0
Loose Coupling and Cohesion
The IDE is BlueJ and the purpose of this exercise is to be able to reduce code duplication and make more editable code while adding a method call known as printLocation as a separate method under the heading of private void printLocation(). Now this is just the first step in a variety of exercises so the assignment does not ask to delete the extra code within printWelcome or goRoom. However, as to no waste your valuable time I did try deleting those after placing this method and I still received the same error message which were illegal start of expression for private void printLocation and after trying to balance my braces I received an error message of could not find the given method. This is what I have to go on at the moment... I will keep working at it but tips on how to remove/add a brace or improve syntax so it will compile would be helpful. Again, the code is supposed to be bad at first with duplications as per BlueJ 7.4 pp. 206-210 2009 by Barnes and Kolling.
The code is below
Java Code:/** * 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 Jacob Mack * @version 2012.08/09 */ 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(); } private void printLocationInfo() } 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.eastExit != 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 } } }Last edited by Fubarable; 08-10-2012 at 03:47 AM. Reason: quote tags changed to code tags
-
Re: Loose Coupling and Cohesion
Moderator edit: [quote] [/quote] changed to [code] [/code] tags. Original poster, please don't use quote tags when posting code as it makes the code lose all of its formatting.
As for your problem, carefully check all your curly braces near and at the offending method, and you'll find some big problems. Also, note that methods cannot be nested within methods.
- 08-10-2012, 04:20 AM #3
Member
- Join Date
- Aug 2012
- Posts
- 10
- Rep Power
- 0
Re: Loose Coupling and Cohesion
I apologize for the oversight. I was able to remove the method from being nested within other methods and now the new error message states cannot find symbol variable command, on this line of code is where the indicated error is contained: String direction = command.getSecondWord(); Below is the whole code within the code tag convention and thanks for your help.
Java Code:/** * 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 2011.07.31 */ 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; } private void printLocationInfo() { System.out.println("You are " + currentRoom.getDescription()); System.out.println("Exits: "); if(currentRoom.northExit != null ) { System.out.println("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(); } 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 } } }
- 08-10-2012, 09:47 AM #4
Moderator
- Join Date
- Apr 2009
- Posts
- 10,481
- Rep Power
- 16
Re: Loose Coupling and Cohesion
Indent your code properly, matching braces.
Because that is your problem.
How do you expect to see where there is a basic problem with braces if your indentation is all over the place?Please do not ask for code as refusal often offends.
- 08-10-2012, 11:40 AM #5
Member
- Join Date
- Aug 2012
- Posts
- 10
- Rep Power
- 0
- 08-10-2012, 12:01 PM #6
Moderator
- Join Date
- Apr 2009
- Posts
- 10,481
- Rep Power
- 16
Re: Loose Coupling and Cohesion
No, that is not the format.
The code that is untouched by you is properly indented.
The code that is causing you problems (printLocationInfo()) is not.
So fix that, then you will probably see that the braces do not match.Please do not ask for code as refusal often offends.
Similar Threads
-
what is the difference between loosly coupling and tightly coupling?
By akiravelmont in forum StrutsReplies: 3Last Post: 01-13-2012, 11:45 AM -
Events and listeners - reduce coupling
By Serpenthelm in forum AWT / SwingReplies: 6Last Post: 01-03-2012, 01:07 AM -
When do we draw the line for loose coupling.
By h8alfred in forum Advanced JavaReplies: 0Last Post: 03-27-2009, 03:05 AM -
coupling
By srinuvericharla in forum Advanced JavaReplies: 1Last Post: 05-16-2007, 04:06 PM


LinkBack URL
About LinkBacks
Reply With Quote

Bookmarks