[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] r11669: added some comfort to the Groovy shell (in puppetor/trunk/src/de/uniba/wiai/lspi/puppetor: groovy impl)



Author: kloesing
Date: 2007-09-27 12:44:02 -0400 (Thu, 27 Sep 2007)
New Revision: 11669

Modified:
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/groovy/RmiPuppetzShell.java
   puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/NetworkImpl.java
Log:
added some comfort to the Groovy shell

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/groovy/RmiPuppetzShell.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/groovy/RmiPuppetzShell.java	2007-09-27 16:41:42 UTC (rev 11668)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/groovy/RmiPuppetzShell.java	2007-09-27 16:44:02 UTC (rev 11669)
@@ -43,17 +43,25 @@
 package de.uniba.wiai.lspi.puppetor.groovy;
 
 import groovy.lang.GroovyShell;
+import groovy.lang.Script;
 
 import java.awt.BorderLayout;
 import java.awt.Dimension;
 import java.awt.GridBagConstraints;
 import java.awt.GridBagLayout;
+import java.io.IOException;
+import java.io.OutputStream;
+import java.io.PrintStream;
 import java.net.MalformedURLException;
 import java.rmi.Naming;
 import java.rmi.NotBoundException;
 import java.rmi.RemoteException;
 import java.rmi.server.UnicastRemoteObject;
 import java.util.HashMap;
+import java.util.LinkedList;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
 import javax.swing.JButton;
 import javax.swing.JFrame;
 import javax.swing.JPanel;
@@ -61,6 +69,7 @@
 import javax.swing.JSplitPane;
 import javax.swing.JTabbedPane;
 import javax.swing.JTextArea;
+
 import de.uniba.wiai.lspi.puppetor.Event;
 import de.uniba.wiai.lspi.puppetor.EventListener;
 import de.uniba.wiai.lspi.puppetor.Network;
@@ -80,6 +89,8 @@
 	 */
 	private GroovyShell shell;
 
+	private Logger logger;
+
 	/**
 	 * The ContentPane to which all other graphical components are added.
 	 */
@@ -133,6 +144,53 @@
 	private HashMap<String, EventListener> eventListeners = new HashMap<String, EventListener>();
 
 	/**
+	 * A hash map to store the entiries that have been entered into the shell.
+	 */
+	private LinkedList<String> shellEntries = null; // @jve:decl-index=0:
+
+	private int listCounter = 0;
+
+	private JButton jButtonNext = null;
+
+	private JButton jButtonPrevious = null;
+
+	/**
+	 * This method initializes jButtonNext
+	 * 
+	 * @return javax.swing.JButton
+	 */
+	private JButton getJButtonNext() {
+		if (jButtonNext == null) {
+			jButtonNext = new JButton();
+			jButtonNext.setText(">");
+			jButtonNext.addMouseListener(new java.awt.event.MouseAdapter() {
+				public void mouseReleased(java.awt.event.MouseEvent e) {
+					displayNextInput();
+				}
+			});
+		}
+		return jButtonNext;
+	}
+
+	/**
+	 * This method initializes jButtonPrevious
+	 * 
+	 * @return javax.swing.JButton
+	 */
+	private JButton getJButtonPrevious() {
+		if (jButtonPrevious == null) {
+			jButtonPrevious = new JButton();
+			jButtonPrevious.setText("<");
+			jButtonPrevious.addMouseListener(new java.awt.event.MouseAdapter() {
+				public void mouseReleased(java.awt.event.MouseEvent e) {
+					displayPreviousInput();
+				}
+			});
+		}
+		return jButtonPrevious;
+	}
+
+	/**
 	 * Main method to start the Gui.
 	 * 
 	 * @param args
@@ -146,6 +204,17 @@
 	 * Initializes the Gui and registers it as a listener to the netaNetwork
 	 */
 	public RmiPuppetzShell() {
+
+		// create logger
+		this.logger = Logger.getLogger("RmiPuppetzShell" + "."
+				+ this.getClass().getName());
+
+		this.logger.setLevel(Level.ALL);
+
+		// log entering
+		this.logger.entering(this.getClass().getName(), "RmiPuppetzShell",
+				new Object[] {});
+
 		initialize();
 
 		// binds network on the shell
@@ -154,8 +223,13 @@
 			consoleJTextArea.append("Welcome, type \"shell.[method]\" to use!"
 					+ "\n");
 		} catch (Exception e) {
+			this.logger.throwing(this.getClass().getName(), "RmiPuppetzShell",
+					e);
 			e.printStackTrace();
 		}
+
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "RmiPuppetzShell");
 	}
 
 	/**
@@ -179,6 +253,10 @@
 	public void connectNetwork(String remoteHost, String bindingName)
 			throws MalformedURLException, RemoteException, NotBoundException {
 
+		// log entering
+		this.logger.entering(this.getClass().getName(), "connectNetwork",
+				new Object[] { remoteHost, bindingName });
+
 		// network lookup
 		Network network = (Network) Naming.lookup("rmi://" + remoteHost + "/"
 				+ bindingName);
@@ -189,16 +267,58 @@
 		// binds network on the shell
 		try {
 			shell.setVariable(bindingName, network);
-			consoleJTextArea.append("Network bound to: " + bindingName + "\n");
+			getConsoleJTextArea().append(
+					"Network bound to: " + bindingName + "\n");
 		} catch (Exception e) {
+			this.logger
+					.throwing(this.getClass().getName(), "connectNetwork", e);
 			e.printStackTrace();
 		}
+
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "connectNetwork");
 	}
 
 	/**
+	 * An output stream that writes its output to a javax.swing.JTextArea
+	 * control.
+	 */
+	private class TextAreaOutputStream extends OutputStream {
+		private JTextArea textControl;
+
+		/**
+		 * Creates a new instance of TextAreaOutputStream which writes to the
+		 * specified instance of javax.swing.JTextArea control.
+		 * 
+		 * @param control
+		 *            A reference to the javax.swing.JTextArea control to which
+		 *            the output must be redirected to.
+		 */
+		public TextAreaOutputStream(JTextArea control) {
+			textControl = control;
+		}
+
+		/**
+		 * Writes the specified byte as a character to the
+		 * javax.swing.JTextArea.
+		 * 
+		 * @param b
+		 *            The byte to be written as character to the JTextArea.
+		 */
+		public void write(int b) throws IOException {
+			// append the data as characters to the JTextArea control
+			textControl.append(String.valueOf((char) b));
+		}
+	}
+
+	/**
 	 * This method initializes the window.
 	 */
 	private void initialize() {
+
+		// log entering
+		this.logger.entering(this.getClass().getName(), "initialize");
+		this.shellEntries = new LinkedList<String>();
 		this.setSize(new Dimension(531, 256));
 		this.setPreferredSize(new Dimension(100, 150));
 		this.setContentPane(getJContentPane());
@@ -206,6 +326,19 @@
 		this.setVisible(true);
 		this.setDefaultCloseOperation(EXIT_ON_CLOSE);
 		shell = new GroovyShell();
+
+		// Create Printstream that writes to JTextArea
+		PrintStream out = new PrintStream(new TextAreaOutputStream(
+				getConsoleJTextArea()));
+
+		// redirect standard output stream to the TextAreaOutputStream
+		System.setOut(out);
+
+		// redirect error output stream to the TextAreaOutputStream
+		System.setErr(out);
+
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "initialize");
 	}
 
 	/**
@@ -214,12 +347,17 @@
 	 * @return javax.swing.JPanel
 	 */
 	private JPanel getJContentPane() {
+		// log entering
+		this.logger.entering(this.getClass().getName(), "getJContentPane");
 		if (jContentPane == null) {
 			jContentPane = new JPanel();
 			jContentPane.setLayout(new BorderLayout());
 			jContentPane.add(getJPanel(), BorderLayout.SOUTH);
 			jContentPane.add(getJSplitPane(), BorderLayout.CENTER);
 		}
+
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "getJContentPane");
 		return jContentPane;
 	}
 
@@ -229,10 +367,16 @@
 	 * @return javax.swing.JTextArea
 	 */
 	private JScrollPane getInputJScrollPane() {
+		// log entering
+		this.logger.entering(this.getClass().getName(), "getInputJScrollPane");
 		if (inputJScrollPane == null) {
 			inputJScrollPane = new JScrollPane();
 			inputJScrollPane.getViewport().add(getInputJTextArea());
 		}
+
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "getInputJScrollPane");
+
 		return inputJScrollPane;
 	}
 
@@ -242,10 +386,16 @@
 	 * @return javax.swing.JTextArea
 	 */
 	private JTextArea getInputJTextArea() {
+
+		// log entering
+		this.logger.entering(this.getClass().getName(), "getInputJTextArea");
 		if (inputJTextArea == null) {
 			inputJTextArea = new JTextArea();
 			inputJTextArea.setEditable(true);
 		}
+
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "getInputJTextArea");
 		return inputJTextArea;
 	}
 
@@ -255,10 +405,19 @@
 	 * @return javax.swing.JScrollPane
 	 */
 	private JScrollPane getConsoleJScrollPane() {
+
+		// log entering
+		this.logger.entering(this.getClass().getName(),
+				"getConsoleJScrollPane", new Object[] {});
+
 		if (ConsoleJScrollPane == null) {
 			ConsoleJScrollPane = new JScrollPane();
 			ConsoleJScrollPane.getViewport().add(getConsoleJTextArea());
 		}
+
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "getConsoleJScrollPane");
+
 		return ConsoleJScrollPane;
 	}
 
@@ -268,11 +427,19 @@
 	 * @return javax.swing.JTextArea
 	 */
 	private JTextArea getConsoleJTextArea() {
+
+		// log entering
+		this.logger.entering(this.getClass().getName(), "getConsoleJTextArea");
+
 		if (consoleJTextArea == null) {
 			consoleJTextArea = new JTextArea();
 			consoleJTextArea.setEditable(false);
 			consoleJTextArea.setName("Console");
 		}
+
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "getConsoleJTextArea");
+
 		return consoleJTextArea;
 	}
 
@@ -285,21 +452,59 @@
 	 * @return javax.swing.JButton
 	 */
 	private JButton getJButton() {
+
+		// log entering
+		this.logger.entering(this.getClass().getName(), "getJButton");
+
 		if (okJButton == null) {
 			okJButton = new JButton();
 			okJButton.setText("OK");
 			okJButton.addMouseListener(new java.awt.event.MouseAdapter() {
 				public void mouseReleased(java.awt.event.MouseEvent e) {
-					try {
-						shell.evaluate(inputJTextArea.getText());
-					} catch (Exception e1) {
-						consoleJTextArea.append("Unkorrekte eingabe" + "\n");
-						e1.printStackTrace();
-					}
 
+					Thread evaluationThread = new Thread() {
+						@Override
+						public void run() {
+							// log entering
+							logger.entering(this.getClass().getName(), "run");
+							Script script = null;
+							try {
+								String input = inputJTextArea.getText();
+								listCounter = 0;
+								shellEntries.addFirst(input);
+								script = shell.parse(input);
+							} catch (Exception e1) {
+								consoleJTextArea.append("In correct input"
+										+ "\n");
+								e1.printStackTrace();
+								logger.log(Level.WARNING, e1.getMessage());
+								return;
+							}
+							try {
+								script.run();
+							} catch (Exception e2) {
+								consoleJTextArea
+										.append("An error occured while performing script"
+												+ "\n");
+								e2.printStackTrace();
+								logger.log(Level.WARNING, e2.getMessage());
+								return;
+							}
+
+							// log exiting
+							logger.exiting(this.getClass().getName(), "run");
+						}
+					};
+					evaluationThread.setName("evaluationThread");
+					evaluationThread.start();
+
 				}
 			});
 		}
+
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "getJButton");
+
 		return okJButton;
 	}
 
@@ -309,15 +514,31 @@
 	 * @return javax.swing.JPanel
 	 */
 	private JPanel getJPanel() {
+
+		// log entering
+		this.logger.entering(this.getClass().getName(), "getJPanel");
+
 		if (buttonJPanel == null) {
+			GridBagConstraints gridBagConstraints2 = new GridBagConstraints();
+			gridBagConstraints2.gridx = 0;
+			gridBagConstraints2.gridy = 0;
+			GridBagConstraints gridBagConstraints1 = new GridBagConstraints();
+			gridBagConstraints1.gridx = 2;
+			gridBagConstraints1.gridy = 0;
 			GridBagConstraints gridBagConstraints = new GridBagConstraints();
-			gridBagConstraints.gridx = 0;
+			gridBagConstraints.gridx = 1;
 			gridBagConstraints.gridy = 0;
 			buttonJPanel = new JPanel();
 			buttonJPanel.setLayout(new GridBagLayout());
 			buttonJPanel.setPreferredSize(new Dimension(100, 30));
 			buttonJPanel.add(getJButton(), gridBagConstraints);
+			buttonJPanel.add(getJButtonNext(), gridBagConstraints1);
+			buttonJPanel.add(getJButtonPrevious(), gridBagConstraints2);
 		}
+
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "getJPanel");
+
 		return buttonJPanel;
 	}
 
@@ -327,11 +548,19 @@
 	 * @return javax.swing.JSplitPane
 	 */
 	private JSplitPane getJSplitPane() {
+
+		// log entering
+		this.logger.entering(this.getClass().getName(), "getJSplitPane");
+
 		if (jSplitPane == null) {
 			jSplitPane = new JSplitPane(JSplitPane.VERTICAL_SPLIT,
 					getInputJScrollPane(), getJTabbedPane());
 			jSplitPane.setContinuousLayout(true);
 		}
+
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "getJSplitPane");
+
 		return jSplitPane;
 	}
 
@@ -341,24 +570,36 @@
 	 * @return javax.swing.JTabbedPane
 	 */
 	private JTabbedPane getJTabbedPane() {
+
+		// log entering
+		this.logger.entering(this.getClass().getName(), "getJTabbedPane");
+
 		if (jTabbedPane == null) {
 			jTabbedPane = new JTabbedPane();
 			jTabbedPane.add("Console", getConsoleJScrollPane());
 		}
+
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "getJTabbedPane");
+
 		return this.jTabbedPane;
 	}
 
 	/**
-	 * Implements the <code>LogListener<code> interface.
+	 * Adds a tab to the network.
 	 * 
-	 *  A tab is created in the lower area of the Gui that is supposed to print 
-	 *  the output of an <code>EventManager<code> of a Network. To do this an 
-	 *  <code>EventListener<code> is created and its stub is returned.
+	 * A tab is created in the lower area of the Gui that is supposed to print
+	 * the output of an <code>EventManager<code> of a Network. To do this an 
+	 * <code>EventListener<code> is created and its stub is returned.
 	 *  
-	 *  @return the stub of the event Listener added to the output tab of a 
-	 *  registered network
+	 * @return the stub of the event Listener added to the output tab of a 
+	 * registered network
 	 */
 	public EventListener addLogTab(String tabName) {
+
+		// log entering
+		this.logger.entering(this.getClass().getName(), "addLogTab", tabName);
+
 		// Creating ScrollPane & TextArea
 		JScrollPane jScrollPane = new JScrollPane();
 		final JTextArea jTextArea = new JTextArea();
@@ -381,8 +622,43 @@
 		try {
 			elStub = (EventListener) UnicastRemoteObject.exportObject(el, 0);
 		} catch (RemoteException e) {
+			this.logger.throwing(this.getClass().getName(), "addLogTab", e);
 			e.printStackTrace();
 		}
+		// log exiting
+		this.logger.exiting(this.getClass().getName(), "addLogTab");
+
 		return elStub;
 	}
-}
+
+	/**
+	 * This method cycles throught the previous inputs and displays them to the
+	 * gui.
+	 */
+	private void displayPreviousInput() {
+
+		if (!(shellEntries.size() == 0)) {
+			listCounter++;
+			if (listCounter >= shellEntries.size()) {
+				listCounter = 0;
+			}
+			inputJTextArea.setText(shellEntries.get(listCounter));
+		}
+	}
+
+	/**
+	 * This method cycles throught the previous inputs in reverse order and
+	 * displays them to the gui.
+	 */
+	private void displayNextInput() {
+
+		if (!(shellEntries.size() == 0)) {
+			listCounter--;
+			if (listCounter < 0) {
+				listCounter = shellEntries.size() - 1;
+			}
+			inputJTextArea.setText(shellEntries.get(listCounter));
+		}
+	}
+
+} // @jve:decl-index=0:visual-constraint="28,41"

Modified: puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/NetworkImpl.java
===================================================================
--- puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/NetworkImpl.java	2007-09-27 16:41:42 UTC (rev 11668)
+++ puppetor/trunk/src/de/uniba/wiai/lspi/puppetor/impl/NetworkImpl.java	2007-09-27 16:44:02 UTC (rev 11669)
@@ -262,7 +262,8 @@
 	private Map<String, ProxyNode> nodes;
 
 	/**
-	 * Determines if the given <code>name</code> is unique in this network.
+	 * Determines if the given <code>name</code> is unique in this network
+	 * (including the network name).
 	 * 
 	 * @param name
 	 *            Name to look up.
@@ -271,8 +272,9 @@
 	 */
 	private boolean isLocallyUnique(String name) {
 		return (!this.clients.containsKey(name)
-				&& !this.servers.containsKey(name) && !this.nodes
-				.containsKey(name));
+				&& !this.servers.containsKey(name)
+				&& !this.nodes.containsKey(name) && !(this.getName()
+				.equals(name)));
 	}
 
 	/**