1   /**********************************************
2    * Copyright (C) 2011 Lukas Laag
3    * This file is part of svgreal.
4    * 
5    * svgreal is free software: you can redistribute it and/or modify
6    * it under the terms of the GNU General Public License as published by
7    * the Free Software Foundation, either version 3 of the License, or
8    * (at your option) any later version.
9    * 
10   * svgreal is distributed in the hope that it will be useful,
11   * but WITHOUT ANY WARRANTY; without even the implied warranty of
12   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13   * GNU General Public License for more details.
14   * 
15   * You should have received a copy of the GNU General Public License
16   * along with svgreal.  If not, see http://www.gnu.org/licenses/
17   **********************************************/
18  package org.vectomatic.svg.edit.client.command;
19  
20  import com.extjs.gxt.ui.client.data.BeanModel;
21  
22  
23  /**
24   * Interface to represent a command. A command is an atomic modification of
25   * the SVG model. The modification can be done or undone. The command provides various descriptions
26   * of its effect on the model.
27   */
28  public interface ICommand {
29  	public static final String NAME = "name";
30  	public static final String DESCRIPTION = "description";
31  	/**
32  	 * Provides a detailed description of this command. The message 
33  	 * must describe precisely what the command does ("Group circle #11, square #207" or
34  	 * "Apply translate(24, 14) to circle #22")
35  	 */
36  	public String getDescription();
37  
38  	/**
39  	 * Applies the modification represented by this command to the model
40  	 */
41  	public void commit();
42  
43  	/**
44  	 * Restores the model to its previous state
45  	 */
46  	public void rollback();
47  	
48  	/**
49  	 * Returns the factory which manufactured this command
50  	 */
51  	public ICommandFactory getFactory();
52  	
53  	/**
54  	 * Returns a BeanModel wrapping this command
55  	 * @return a BeanModel wrapping this command
56  	 */
57  	public BeanModel asModel();
58  }