/************************************************************************ * * Config.java * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * * Copyright: 2002-2009 by Henrik Just * * All Rights Reserved. * * Version 1.2 (2009-11-19) * */ package writer2latex.api; import java.util.HashMap; import java.util.Map; import java.util.Set; /** A complex option is a set of named keys, each pointing to a set of named attributes */ public class ComplexOption { private Map> options = new HashMap>(); /** Clear the contents of the set * */ public void clear() { options.clear(); } /** Remove an option from the set, if it exists * * @param sName the name of the key to remove */ public void remove(String sName) { if (options.containsKey(sName)) { options.remove(sName); } } /** Define a key. If the key already exists, the old value will be replaced * * @param sName the name of the key. The name must be non-empty, otherwise the request will be ignored. * @param attributes */ public void put(String sName, Map attributes) { if (sName!=null && sName.length()>0) { options.put(sName, attributes); } } /** Define a key using a copy of a the provided attributes. * If the key already exists, the old value will be replaced * * @param sName the name of the key. The name must be non-empty, otherwise the request will be ignored. * @param attributes */ public void copy(String sName, Map attributes) { if (sName!=null && sName.length()>0) { Map newAttributes = new HashMap(); for (String sAttrName : attributes.keySet()) { newAttributes.put(sAttrName, attributes.get(sAttrName)); } put(sName, newAttributes); } } /** Get the value belonging to a key * * @param sName the name of the key * @return the attributes, or null if the option doesn't exist */ public Map get(String sName) { return options.get(sName); } /** Copy all values from another ComplexOption * (overwrites existing values) * @param co another instance of ComplexOption */ public void copyAll(ComplexOption co) { for (String sName : co.keySet()) { copy(sName, co.get(sName)); } } /** Get the names of all options that are currently defined by this complex option * * @return all names as a Set */ public Set keySet() { return options.keySet(); } /** Test if this complex options contains a specific option name * * @param sName the name to test * @return true if the name exists */ public boolean containsKey(String sName) { return options.containsKey(sName); } }