org.simpleframework.util.parse
Class MapParser<T>

java.lang.Object
  extended by org.simpleframework.util.parse.Parser
      extended by org.simpleframework.util.parse.MapParser<T>
All Implemented Interfaces:
java.util.Map<T,T>
Direct Known Subclasses:
QueryParser

public abstract class MapParser<T>
extends Parser
implements java.util.Map<T,T>

The MapParser object represents a parser for name value pairs. Any parser extending this will typically be parsing name=value tokens or the like, and inserting these pairs into the internal map. This type of parser is useful as it exposes all pairs extracted using the java.util.Map interface and as such can be used with the Java collections framework. The internal map used by this is a Hashtable, however subclasses are free to assign a different type to the map used.

Author:
Niall Gallagher

Nested Class Summary
 
Nested classes/interfaces inherited from interface java.util.Map
java.util.Map.Entry<K,V>
 
Field Summary
protected  java.util.Map<T,java.util.List<T>> all
          Represents all values inserted to the map as a list of values.
protected  java.util.Map<T,T> map
          Represents the last value inserted into this map instance.
 
Fields inherited from class org.simpleframework.util.parse.Parser
buf, count, off
 
Constructor Summary
protected MapParser()
          Constructor for the MapParser object.
 
Method Summary
 void clear()
          The clear method is used to wipe out all the currently existing tokens from the collection.
 boolean containsKey(java.lang.Object name)
          This is used to determine whether a token representing the name of a pair has been inserted into the internal map.
 boolean containsValue(java.lang.Object value)
          This method is used to determine whether any pair that has been inserted into the internal map had the presented value.
 java.util.Set<java.util.Map.Entry<T,T>> entrySet()
          This method is used to acquire the name and value pairs that have currently been collected by this parser.
 T get(java.lang.Object name)
          The get method is used to acquire the value for a named pair.
 java.util.List<T> getAll(java.lang.Object key)
          This method is used to acquire a List for all of the values that have been put in to the map.
 boolean isEmpty()
          This method is used to determine whether the parser has any tokens available.
 java.util.Set<T> keySet()
          This is used to acquire the names for all the tokens that have currently been collected by this parser.
 T put(T name, T value)
          The put method is used to insert the name and value provided into the collection of tokens.
 void putAll(java.util.Map<? extends T,? extends T> data)
          This method is used to insert a collection of tokens into the parsers map.
 T remove(java.lang.Object name)
          The remove method is used to remove the named token pair from the collection of tokens.
 int size()
          This obviously enough provides the number of tokens that have been inserted into the internal map.
 java.util.Collection<T> values()
          This method is used to acquire the value for all tokens that have currently been collected by this parser.
 
Methods inherited from class org.simpleframework.util.parse.Parser
digit, ensureCapacity, init, parse, parse, skip, space, toLower
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 
Methods inherited from interface java.util.Map
equals, hashCode
 

Field Detail

all

protected java.util.Map<T,java.util.List<T>> all
Represents all values inserted to the map as a list of values.


map

protected java.util.Map<T,T> map
Represents the last value inserted into this map instance.

Constructor Detail

MapParser

protected MapParser()
Constructor for the MapParser object. This is used to create a new parser that makes use of a thread safe map implementation. The HashMap is used so that the resulting parser can be accessed in a concurrent environment with the fear of data corruption.

Method Detail

containsKey

public boolean containsKey(java.lang.Object name)
This is used to determine whether a token representing the name of a pair has been inserted into the internal map. The object passed into this method should be a string, as all tokens stored within the map will be stored as strings.

Specified by:
containsKey in interface java.util.Map<T,T>
Parameters:
name - this is the name of a pair within the map
Returns:
this returns true if the pair of that name exists

containsValue

public boolean containsValue(java.lang.Object value)
This method is used to determine whether any pair that has been inserted into the internal map had the presented value. If one or more pairs within the collected tokens contains the value provided then this method will return true.

Specified by:
containsValue in interface java.util.Map<T,T>
Parameters:
value - this is the value that is to be searched for
Returns:
this returns true if any value is equal to this

entrySet

public java.util.Set<java.util.Map.Entry<T,T>> entrySet()
This method is used to acquire the name and value pairs that have currently been collected by this parser. This is used to determine which tokens have been extracted from the source. It is useful when the tokens have to be gathered.

Specified by:
entrySet in interface java.util.Map<T,T>
Returns:
this set of token pairs that have been extracted

get

public T get(java.lang.Object name)
The get method is used to acquire the value for a named pair. So if a pair of name=value has been parsed and inserted into the collection of tokens this will return the value given the name. The value returned will be a string.

Specified by:
get in interface java.util.Map<T,T>
Parameters:
name - this is a string used to search for the value
Returns:
this is the value, as a string, that has been found

getAll

public java.util.List<T> getAll(java.lang.Object key)
This method is used to acquire a List for all of the values that have been put in to the map. The list allows all values associated with the specified key. This enables a parser to collect a number of associated tokens.

Parameters:
key - this is the key used to search for the value
Returns:
this is the list of values associated with the key

isEmpty

public boolean isEmpty()
This method is used to determine whether the parser has any tokens available. If the size is zero then the parser is empty and this returns true. The is acts as a proxy the the isEmpty of the internal map.

Specified by:
isEmpty in interface java.util.Map<T,T>
Returns:
this is true if there are no available tokens

keySet

public java.util.Set<T> keySet()
This is used to acquire the names for all the tokens that have currently been collected by this parser. This is used to determine which tokens have been extracted from the source. It is useful when the tokens have to be gathered.

Specified by:
keySet in interface java.util.Map<T,T>
Returns:
the set of name tokens that have been extracted

put

public T put(T name,
             T value)
The put method is used to insert the name and value provided into the collection of tokens. Although it is up to the parser to decide what values will be inserted it is generally the case that the inserted tokens will be text.

Specified by:
put in interface java.util.Map<T,T>
Parameters:
name - this is the name token from a name=value pair
value - this is the value token from a name=value pair
Returns:
this returns the previous value if there was any

putAll

public void putAll(java.util.Map<? extends T,? extends T> data)
This method is used to insert a collection of tokens into the parsers map. This is used when another source of tokens is required to populate the connection currently maintained within this parsers internal map. Any tokens that currently exist with similar names will be overwritten by this.

Specified by:
putAll in interface java.util.Map<T,T>
Parameters:
data - this is the collection of tokens to be added

remove

public T remove(java.lang.Object name)
The remove method is used to remove the named token pair from the collection of tokens. This acts like a take, in that it will get the token value and remove if from the collection of tokens the parser has stored.

Specified by:
remove in interface java.util.Map<T,T>
Parameters:
name - this is a string used to search for the value
Returns:
this is the value, as a string, that is removed

size

public int size()
This obviously enough provides the number of tokens that have been inserted into the internal map. This acts as a proxy method for the internal map size.

Specified by:
size in interface java.util.Map<T,T>
Returns:
this returns the number of tokens are available

values

public java.util.Collection<T> values()
This method is used to acquire the value for all tokens that have currently been collected by this parser. This is used to determine which tokens have been extracted from the source. It is useful when the tokens have to be gathered.

Specified by:
values in interface java.util.Map<T,T>
Returns:
the list of value tokens that have been extracted

clear

public void clear()
The clear method is used to wipe out all the currently existing tokens from the collection. This is used to recycle the parser so that it can be used to parse some other source of tokens without any lingering state.

Specified by:
clear in interface java.util.Map<T,T>