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

org.eclipse.emf.common.command.Command Maven / Gradle / Ivy

There is a newer version: 2.4.3
Show newest version
/**
 *  
 *
 * Copyright (c) 2002-2006 IBM Corporation and others.
 * All rights reserved.   This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 * 
 * Contributors: 
 *   IBM - Initial API and implementation
 *
 * 
 *
 * $Id: Command.java,v 1.4 2007/06/12 20:56:17 emerks Exp $
 */
package org.eclipse.emf.common.command;


import java.util.Collection;


/**
 * An interface that every command is expected to support.
 * A command can be tested for executability, 
 * it can be executed, 
 * it can be tested for undoability, 
 * it can be undone, 
 * and can then be redone.
 * A command also provides access to a result collection, an affected-objects collection,
 * a label, and a description.
 *
 * 

* There are important constraints on the valid order in which the various methods may be invoked, * e.g., you cannot ask for the result before you've executed the command. * These constraints are documented with the various methods. */ public interface Command { /** * Returns whether the command is valid to execute. * The {@link UnexecutableCommand#INSTANCE}.canExecute() always returns false. * This must be called before calling execute. * @return whether the command is valid to execute. */ boolean canExecute(); /** * Performs the command activity required for the effect. * The effect of calling execute when canExecute returns false, * or when canExecute hasn't been called, is undefined. */ void execute(); /** * Returns whether the command can be undone. * The result of calling this before execute is well defined, * but the result of calling this before calling canExecute is undefined, i.e., * a command that returns false for canExecute may return true for canUndo, * even though that is a contradiction. * @return whether the command can be undone. */ boolean canUndo(); /** * Performs the command activity required to undo the effects of a preceding execute (or redo). * The effect, if any, of calling undo before execute or redo have been called, * or when canUndo returns false, is undefined. */ void undo(); /** * Performs the command activity required to redo the effect after undoing the effect. * The effect, if any, of calling redo before undo is called is undefined. * Note that if you implement redo to call execute * then any derived class will be restricted by that decision also. */ void redo(); /** * Returns a collection of things which this command wishes to present as it's result. * The result of calling this before an execute or redo, or after an undo, is undefined. * @return a collection of things which this command wishes to present as it's result. */ Collection getResult(); /** * Returns the collection of things which this command wishes to present as the objects affected by the command. * Typically should could be used as the selection that should be highlighted to best illustrate the effect of the command. * The result of calling this before an execute, redo, or undo is undefined. * The result may be different after an undo than it is after an execute or redo, * but the result should be the same (equivalent) after either an execute or redo. * @return the collection of things which this command wishes to present as the objects affected by the command. */ Collection getAffectedObjects(); /** * Returns a string suitable to represent the label that identifies this command. * @return a string suitable to represent the label that identifies this command. */ String getLabel(); /** * Returns a string suitable to help describe the effect of this command. * @return a string suitable to help describe the effect of this command. */ String getDescription(); /** * Called to indicate that the command will never be used again. * Calling any other method after this one has undefined results. */ void dispose(); /** * Returns a command that represents the composition of this command with the given command. * The resulting command may just be this, if this command is capable of composition. * Otherwise, it will be a new command created to compose the two. *

* Instead of the following pattern of usage *

   *   Command result = x;
   *   if (condition) result = result.chain(y);
   * 
* you should consider using a {@link org.eclipse.emf.common.command.CompoundCommand} * and using {@link org.eclipse.emf.common.command.CompoundCommand#unwrap()} to optimize the result: *
   *   CompoundCommand subcommands = new CompoundCommand();
   *   subcommands.append(x);
   *   if (condition) subcommands.append(y);
   *   Command result = subcommands.unwrap();
   * 
* This gives you more control over how the compound command composes it's result and affected objects. * @param command the command to chain. * @return a command that represents the composition of this command with the given command. */ Command chain(Command command); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy