001 //$HeadURL: $
002 /*---------------- FILE HEADER ------------------------------------------
003 This file is part of deegree.
004 Copyright (C) 2001-2008 by:
005 Department of Geography, University of Bonn
006 http://www.giub.uni-bonn.de/deegree/
007 lat/lon GmbH
008 http://www.lat-lon.de
009
010 This library is free software; you can redistribute it and/or
011 modify it under the terms of the GNU Lesser General Public
012 License as published by the Free Software Foundation; either
013 version 2.1 of the License, or (at your option) any later version.
014 This library is distributed in the hope that it will be useful,
015 but WITHOUT ANY WARRANTY; without even the implied warranty of
016 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
017 Lesser General Public License for more details.
018 You should have received a copy of the GNU Lesser General Public
019 License along with this library; if not, write to the Free Software
020 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
021 Contact:
022
023 Andreas Poth
024 lat/lon GmbH
025 Aennchenstr. 19
026 53177 Bonn
027 Germany
028 E-Mail: poth@lat-lon.de
029
030 Prof. Dr. Klaus Greve
031 Department of Geography
032 University of Bonn
033 Meckenheimer Allee 166
034 53115 Bonn
035 Germany
036 E-Mail: greve@giub.uni-bonn.de
037 ---------------------------------------------------------------------------*/
038
039
040 package org.deegree.ogcwebservices.csw.capabilities;
041
042 import java.net.URI;
043 import java.util.HashMap;
044 import java.util.List;
045 import java.util.Map;
046
047 import org.deegree.i18n.Messages;
048
049 /**
050 * The <code>CSWFeature</code> class is a simple bean holding a property map.
051 *
052 * @author <a href="mailto:bezema@lat-lon.de">Rutger Bezema</a>
053 *
054 * @author last edited by: $Author:$
055 *
056 * @version $Revision:$, $Date:$
057 *
058 */
059
060 public class CSWFeature {
061 private Map<URI, List<String>> properties;
062
063
064 /**
065 * Initialisded with no properties.
066 */
067 public CSWFeature( ){
068 this.properties = new HashMap< URI, List<String>>();
069 }
070 /**
071 * sets the features properties to the given map.
072 * @param properties to set to.
073 */
074 public CSWFeature( Map<URI, List<String> > properties ){
075 this.properties = properties;
076 }
077
078 /**
079 * @return the properties.
080 */
081 public Map<URI, List<String>> getAllProperties() {
082 return properties;
083 }
084
085 /**
086 * @param propName an unambiguous name for the property to insert
087 * @param values of the properties
088 * @param properties An other properties value.
089 * @throws IllegalArgumentException if the propName is empty, unambiguous or null.
090 */
091 public void addPropertie( URI propName, List<String> values ) {
092 if( propName == null || "".equals( propName.toASCIIString().trim()) ){
093 throw new IllegalArgumentException( Messages.getMessage( "WRS_NULL_FEAT_PROP" ) );
094 }
095 if( properties.containsKey( propName ) ){
096 throw new IllegalArgumentException( Messages.getMessage( "WRS_UNAMBIGUOUS_FEAT_PROP", propName.toString()) );
097 }
098 this.properties.put( propName, values );
099 }
100
101
102
103 }
104