/* * $Id$ * * Copyright (c) 2005 by Rodney Kinney, Brent Easton * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Library General Public * License (LGPL) as published by the Free Software Foundation. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Library General Public License for more details. * * You should have received a copy of the GNU Library General Public * License along with this library; if not, copies are available * at http://www.opensource.org. */ package VASSAL.build.module.gamepieceimage; import java.beans.PropertyChangeEvent; import java.beans.PropertyChangeListener; import java.util.HashMap; import java.util.Map; import VASSAL.build.AbstractConfigurable; import VASSAL.build.Buildable; import VASSAL.build.Configurable; import VASSAL.build.GameModule; import VASSAL.build.module.documentation.HelpFile; import VASSAL.configure.Configurer; import VASSAL.configure.SingleChildInstance; /** * Container for definitions of Generic Counter Definitions. * Actual definition is in inner class * {@link VASSAL.build.module.gamepieceimage.GamePieceLayout}. */ public class GamePieceLayoutsContainer extends AbstractConfigurable { protected Map<String,GamePieceLayout> definitions = new HashMap<String,GamePieceLayout>(); protected GamePieceLayout getDefinition(String name) { return definitions.get(name); } public String[] getAttributeDescriptions() { return new String[0]; } public Class<?>[] getAttributeTypes() { return new Class<?>[0]; } public String[] getAttributeNames() { return new String[0]; } public String getAttributeValueString(String key) { return null; } public void setAttribute(String key, Object value) { } public Configurer getConfigurer() { return null; } public void addTo(Buildable parent) { validator = new SingleChildInstance(GameModule.getGameModule(),getClass()); setAllAttributesUntranslatable(); } public Class<?>[] getAllowableConfigureComponents() { return new Class<?>[]{GamePieceLayout.class}; } public static String getConfigureTypeName() { return "Game Piece Layouts"; } public void add(Buildable b) { super.add(b); if (b instanceof GamePieceLayout) { GamePieceLayout def = (GamePieceLayout) b; definitions.put(def.getConfigureName(), def); def.addPropertyChangeListener(new PropertyChangeListener() { public void propertyChange(PropertyChangeEvent evt) { if (Configurable.NAME_PROPERTY.equals(evt.getPropertyName())) { definitions.remove((String) evt.getOldValue()); definitions.put((String) evt.getNewValue(), (GamePieceLayout) evt.getSource()); } } }); } } public void remove(Buildable b) { super.remove(b); if (b instanceof GamePieceLayout) { definitions.remove(((GamePieceLayout) b).getConfigureName()); } } public HelpFile getHelpFile() { return HelpFile.getReferenceManualPage("GamePieceLayouts.htm"); //$NON-NLS-1$ } public void removeFrom(Buildable parent) { } public GamePieceImage getGenericDefn(String defnName) { for (GamePieceLayout d : definitions.values()) { if (d != null) { return d.getGenericDefn(defnName); } } return null; } }