ModeShape Distribution 3.0.0.Beta4

org.infinispan.schematic.document
Class MergeDocument

java.lang.Object
  extended by org.infinispan.schematic.document.MergeDocument
All Implemented Interfaces:
Serializable, Document

public class MergeDocument
extends Object
implements Document

A Document implementation that presents the merger of two other documents, where the first document is used before the second.

Since:
5.1
See Also:
Serialized Form

Nested Class Summary
 
Nested classes/interfaces inherited from interface org.infinispan.schematic.document.Document
Document.Field, Document.ValueTransformer
 
Constructor Summary
MergeDocument(Document document1, Document document2)
          Create a document that contains all of the fields from the two documents, with the first document taking precedence.
MergeDocument(Document document1, Document document2, Document document3)
          Create a document that contains all of the fields from the three documents, with the first document taking precedence over the others, and the second taking precedence over the third.
 
Method Summary
 MergeDocument clone()
          Obtain a clone of this document.
 boolean containsAll(Document document)
          Checks if this object contains all of the fields in the supplied document.
 boolean containsField(String name)
          Checks if this object contains a field with the given name.
 Iterable<Document.Field> fields()
          Obtain an iterator over the Document.Fields in this object.
 Object get(String name)
          Gets the value in this document for the given field name.
 List<?> getArray(String name)
          Get the array value in this document for the given field name.
 Binary getBinary(String name)
          Get the Binary value in this document for the given field name.
 Boolean getBoolean(String name)
          Get the boolean value in this document for the given field name.
 boolean getBoolean(String name, boolean defaultValue)
          Get the boolean value in this document for the given field name.
 Code getCode(String name)
          Get the Code value in this document for the given field name.
 CodeWithScope getCodeWithScope(String name)
          Get the CodeWithScope value in this document for the given field name.
 Document getDocument(String name)
          Get the document value in this document for the given field name.
 Double getDouble(String name)
          Get the double value in this document for the given field name.
 double getDouble(String name, double defaultValue)
          Get the double value in this document for the given field name.
 Integer getInteger(String name)
          Get the integer value in this document for the given field name.
 int getInteger(String name, int defaultValue)
          Get the integer value in this document for the given field name.
 Long getLong(String name)
          Get the integer value in this document for the given field name.
 long getLong(String name, long defaultValue)
          Get the long value in this document for the given field name.
 MaxKey getMaxKey(String name)
          Get the MaxKey value in this document for the given field name.
 MinKey getMinKey(String name)
          Get the MinKey value in this document for the given field name.
 Number getNumber(String name)
          Get the number value in this document for the given field name.
 Number getNumber(String name, Number defaultValue)
          Get the number value in this document for the given field name.
 ObjectId getObjectId(String name)
          Get the ObjectId value in this document for the given field name.
 Pattern getPattern(String name)
          Get the Pattern value in this document for the given field name.
 String getString(String name)
          Get the string value in this document for the given field name.
 String getString(String name, String defaultValue)
          Get the string value in this document for the given field name.
 Symbol getSymbol(String name)
          Get the Symbol value in this document for the given field name.
 int getType(String name)
          Get the Bson.Type constant that describes the type of value for the given field name.
 UUID getUuid(String name)
          Get the UUID value in this document for the given field name.
 UUID getUuid(String name, UUID defaultValue)
          Get the UUID value in this document for the given field name.
 boolean isEmpty()
          Return whether this document contains no fields and is therefore empty.
 boolean isNull(String name)
          Determine whether this object has a pair with the given the name and the value is null.
 boolean isNullOrMissing(String name)
          Determine whether this object has a pair with the given the name and the value is null, or if this object has no field with the given name.
 Set<String> keySet()
          Returns this object's fields' names
 int size()
          Return the number of name-value pairs in this object.
 Map<String,? extends Object> toMap()
          Returns a map representing this BSONObject.
 Document with(Document.ValueTransformer transformer)
          Obtain a clone of this document, but with the field values transformed using the supplied Document.ValueTransformer.
 MergeDocument with(Map<String,Object> changedFields)
          Obtain a clone of this document, but with the supplied fields replaced.
 Document withVariablesReplaced(Properties properties)
          Obtain a clone of this document, but with all variables in string field values replaced with the referenced values from the supplied properties.
 Document withVariablesReplacedWithSystemProperties()
          Obtain a clone of this document, but with all variables in string field values replaced with the referenced values from the System properties.
 
Methods inherited from class java.lang.Object
equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

MergeDocument

public MergeDocument(Document document1,
                     Document document2)
Create a document that contains all of the fields from the two documents, with the first document taking precedence.

Parameters:
document1 - the first (preceding) document; may not be null
document2 - the second document; may not be null

MergeDocument

public MergeDocument(Document document1,
                     Document document2,
                     Document document3)
Create a document that contains all of the fields from the three documents, with the first document taking precedence over the others, and the second taking precedence over the third.

Parameters:
document1 - the first (preceding) document; may not be null
document2 - the second document; may not be null
document3 - the third document; may not be null
Method Detail

clone

public MergeDocument clone()
Description copied from interface: Document
Obtain a clone of this document.

Specified by:
clone in interface Document
Overrides:
clone in class Object
Returns:
the clone of this document; never null

with

public MergeDocument with(Map<String,Object> changedFields)
Description copied from interface: Document
Obtain a clone of this document, but with the supplied fields replaced.

Specified by:
with in interface Document
Parameters:
changedFields - the fields that should be changed; may be null
Returns:
the clone of this document with the change fields, or this document if there are no changes

with

public Document with(Document.ValueTransformer transformer)
Description copied from interface: Document
Obtain a clone of this document, but with the field values transformed using the supplied Document.ValueTransformer.

Specified by:
with in interface Document
Parameters:
transformer - the transformer that should be used to transform each field value; may not be null
Returns:
the clone of this document with transformed fields, or this document if the transformer changed none of the values

withVariablesReplaced

public Document withVariablesReplaced(Properties properties)
Description copied from interface: Document
Obtain a clone of this document, but with all variables in string field values replaced with the referenced values from the supplied properties.

Variables may appear anywhere within a string value, and multiple variables can be used within the same value. Variables take the form:

    variable := '${' variableNames [ ':' defaultValue ] '}'
    
    variableNames := variableName [ ',' variableNames ]
    
    variableName := /* any characters except ',' and ':' and '}'
    
    defaultValue := /* any characters except
 
Note that variableName is the name used to look up the Properties property.

Notice that the syntax supports multiple variables. The logic will process the variables from let to right, until an existing System property is found. And at that point, it will stop and will not attempt to find values for the other variables.

Specified by:
withVariablesReplaced in interface Document
Parameters:
properties - the properties keyed by variable name
Returns:
the clone of this document with variables in fields string values replaced with values from the properties object, or this document if no variables were found
See Also:
Document.withVariablesReplacedWithSystemProperties(), Document.with(ValueTransformer), SchemaLibrary.convertValues(Document, String)

withVariablesReplacedWithSystemProperties

public Document withVariablesReplacedWithSystemProperties()
Description copied from interface: Document
Obtain a clone of this document, but with all variables in string field values replaced with the referenced values from the System properties.

Variables may appear anywhere within a string value, and multiple variables can be used within the same value. Variables take the form:

    variable := '${' variableNames [ ':' defaultValue ] '}'
    
    variableNames := variableName [ ',' variableNames ]
    
    variableName := /* any characters except ',' and ':' and '}'
    
    defaultValue := /* any characters except
 
Note that variableName is the name used to look up a System property via System.getProperty(String).

Notice that the syntax supports multiple variables. The logic will process the variables from let to right, until an existing System property is found. And at that point, it will stop and will not attempt to find values for the other variables.

Because only string values can contain variables, the resulting values are left as strings. This may not be valid according to the document's JSON Schema, so see SchemaLibrary.convertValues(Document, String) to convert the string values after variable substitution into the expected non-string types.

Specified by:
withVariablesReplacedWithSystemProperties in interface Document
Returns:
the clone of this document with variables in fields string values replaced with values from the System properties, or this document if no variables were found
See Also:
Document.withVariablesReplaced(Properties), Document.with(ValueTransformer), SchemaLibrary.convertValues(Document, String)

get

public Object get(String name)
Description copied from interface: Document
Gets the value in this document for the given field name.

Specified by:
get in interface Document
Parameters:
name - The name of the pair
Returns:
The field value, if found, or null otherwise

getBoolean

public Boolean getBoolean(String name)
Description copied from interface: Document
Get the boolean value in this document for the given field name.

Specified by:
getBoolean in interface Document
Parameters:
name - The name of the pair
Returns:
The boolean field value, if found, or null if there is no such pair or if the value is not a boolean

getBoolean

public boolean getBoolean(String name,
                          boolean defaultValue)
Description copied from interface: Document
Get the boolean value in this document for the given field name.

Specified by:
getBoolean in interface Document
Parameters:
name - The name of the pair
defaultValue - the default value to return if there is no such pair or if the value is not a boolean
Returns:
The boolean field value if found, or defaultValue if there is no such pair or if the value is not a boolean

getInteger

public Integer getInteger(String name)
Description copied from interface: Document
Get the integer value in this document for the given field name.

Specified by:
getInteger in interface Document
Parameters:
name - The name of the pair
Returns:
The integer field value, if found, or null if there is no such pair or if the value is not an integer

getInteger

public int getInteger(String name,
                      int defaultValue)
Description copied from interface: Document
Get the integer value in this document for the given field name.

Specified by:
getInteger in interface Document
Parameters:
name - The name of the pair
defaultValue - the default value to return if there is no such pair or if the value is not a integer
Returns:
The integer field value if found, or defaultValue if there is no such pair or if the value is not a integer

getLong

public Long getLong(String name)
Description copied from interface: Document
Get the integer value in this document for the given field name.

Specified by:
getLong in interface Document
Parameters:
name - The name of the pair
Returns:
The long field value, if found, or null if there is no such pair or if the value is not a long value

getLong

public long getLong(String name,
                    long defaultValue)
Description copied from interface: Document
Get the long value in this document for the given field name.

Specified by:
getLong in interface Document
Parameters:
name - The name of the pair
defaultValue - the default value to return if there is no such pair or if the value is not a long value
Returns:
The long field value if found, or defaultValue if there is no such pair or if the value is not a long value

getDouble

public Double getDouble(String name)
Description copied from interface: Document
Get the double value in this document for the given field name.

Specified by:
getDouble in interface Document
Parameters:
name - The name of the pair
Returns:
The double field value, if found, or null if there is no such pair or if the value is not a double

getDouble

public double getDouble(String name,
                        double defaultValue)
Description copied from interface: Document
Get the double value in this document for the given field name.

Specified by:
getDouble in interface Document
Parameters:
name - The name of the pair
defaultValue - the default value to return if there is no such pair or if the value is not a double
Returns:
The double field value if found, or defaultValue if there is no such pair or if the value is not a double

getNumber

public Number getNumber(String name)
Description copied from interface: Document
Get the number value in this document for the given field name.

Specified by:
getNumber in interface Document
Parameters:
name - The name of the pair
Returns:
The double field value, if found, or null if there is no such pair or if the value is not a number

getNumber

public Number getNumber(String name,
                        Number defaultValue)
Description copied from interface: Document
Get the number value in this document for the given field name.

Specified by:
getNumber in interface Document
Parameters:
name - The name of the pair
defaultValue - the default value to return if there is no such pair or if the value is not a number
Returns:
The number field value if found, or defaultValue if there is no such pair or if the value is not a number

getString

public String getString(String name)
Description copied from interface: Document
Get the string value in this document for the given field name. This method will return the string even if the actual value is a Symbol.

Specified by:
getString in interface Document
Parameters:
name - The name of the pair
Returns:
The string field value, if found, or null if there is no such pair or if the value is not a string

getString

public String getString(String name,
                        String defaultValue)
Description copied from interface: Document
Get the string value in this document for the given field name. This method will return the string even if the actual value is a Symbol.

Specified by:
getString in interface Document
Parameters:
name - The name of the pair
defaultValue - the default value to return if there is no such pair or if the value is not a string
Returns:
The string field value if found, or defaultValue if there is no such pair or if the value is not a string

getArray

public List<?> getArray(String name)
Description copied from interface: Document
Get the array value in this document for the given field name.

Specified by:
getArray in interface Document
Parameters:
name - The name of the pair
Returns:
The array field value (as a list), if found, or null if there is no such pair or if the value is not an array

getDocument

public Document getDocument(String name)
Description copied from interface: Document
Get the document value in this document for the given field name.

Specified by:
getDocument in interface Document
Parameters:
name - The name of the pair
Returns:
The document field value, if found, or null if there is no such pair or if the value is not a document

isNull

public boolean isNull(String name)
Description copied from interface: Document
Determine whether this object has a pair with the given the name and the value is null. This is equivalent to calling:
 this.get(name) instanceof Null;
 

Specified by:
isNull in interface Document
Parameters:
name - The name of the pair
Returns:
true if the field has been set to a Null value, or false otherwise
See Also:
Document.isNullOrMissing(String)

isNullOrMissing

public boolean isNullOrMissing(String name)
Description copied from interface: Document
Determine whether this object has a pair with the given the name and the value is null, or if this object has no field with the given name. This is equivalent to calling:
 Null.matches(this.get(name));
 

Specified by:
isNullOrMissing in interface Document
Parameters:
name - The name of the pair
Returns:
true if the field value for the name is null or if there is no such field.
See Also:
Document.isNull(String)

getMaxKey

public MaxKey getMaxKey(String name)
Description copied from interface: Document
Get the MaxKey value in this document for the given field name.

Specified by:
getMaxKey in interface Document
Parameters:
name - The name of the pair
Returns:
The MaxKey field value, if found, or null if there is no such pair or if the value is not a MaxKey

getMinKey

public MinKey getMinKey(String name)
Description copied from interface: Document
Get the MinKey value in this document for the given field name.

Specified by:
getMinKey in interface Document
Parameters:
name - The name of the pair
Returns:
The MinKey field value, if found, or null if there is no such pair or if the value is not a MinKey

getCode

public Code getCode(String name)
Description copied from interface: Document
Get the Code value in this document for the given field name.

Specified by:
getCode in interface Document
Parameters:
name - The name of the pair
Returns:
The Code field value, if found, or null if there is no such pair or if the value is not a Code

getCodeWithScope

public CodeWithScope getCodeWithScope(String name)
Description copied from interface: Document
Get the CodeWithScope value in this document for the given field name.

Specified by:
getCodeWithScope in interface Document
Parameters:
name - The name of the pair
Returns:
The CodeWithScope field value, if found, or null if there is no such pair or if the value is not a CodeWithScope

getObjectId

public ObjectId getObjectId(String name)
Description copied from interface: Document
Get the ObjectId value in this document for the given field name.

Specified by:
getObjectId in interface Document
Parameters:
name - The name of the pair
Returns:
The ObjectId field value, if found, or null if there is no such pair or if the value is not a ObjectId

getBinary

public Binary getBinary(String name)
Description copied from interface: Document
Get the Binary value in this document for the given field name.

Specified by:
getBinary in interface Document
Parameters:
name - The name of the pair
Returns:
The Binary field value, if found, or null if there is no such pair or if the value is not a Binary

getSymbol

public Symbol getSymbol(String name)
Description copied from interface: Document
Get the Symbol value in this document for the given field name.

Specified by:
getSymbol in interface Document
Parameters:
name - The name of the pair
Returns:
The Symbol field value, if found, or null if there is no such pair or if the value is not a Symbol

getPattern

public Pattern getPattern(String name)
Description copied from interface: Document
Get the Pattern value in this document for the given field name.

Specified by:
getPattern in interface Document
Parameters:
name - The name of the pair
Returns:
The Pattern field value, if found, or null if there is no such pair or if the value is not a Pattern

getUuid

public UUID getUuid(String name)
Description copied from interface: Document
Get the UUID value in this document for the given field name.

Specified by:
getUuid in interface Document
Parameters:
name - The name of the pair
Returns:
The UUID field value, if found, or null if there is no such pair or if the value is not a UUID

getUuid

public UUID getUuid(String name,
                    UUID defaultValue)
Description copied from interface: Document
Get the UUID value in this document for the given field name.

Specified by:
getUuid in interface Document
Parameters:
name - The name of the pair
defaultValue - the default value to return if there is no such pair or if the value is not a string
Returns:
The UUID field value if found, or defaultValue if there is no such pair or if the value is not a UUID (or a string that is convertable from a UUID)

getType

public int getType(String name)
Description copied from interface: Document
Get the Bson.Type constant that describes the type of value for the given field name.

Specified by:
getType in interface Document
Parameters:
name - The name of the pair
Returns:
the Bson.Type constant describing the value, or -1 if there is no field with the supplied name

toMap

public Map<String,? extends Object> toMap()
Description copied from interface: Document
Returns a map representing this BSONObject.

Specified by:
toMap in interface Document
Returns:
the map

fields

public Iterable<Document.Field> fields()
Description copied from interface: Document
Obtain an iterator over the Document.Fields in this object.

Specified by:
fields in interface Document
Returns:
a field iterator; never null

containsField

public boolean containsField(String name)
Description copied from interface: Document
Checks if this object contains a field with the given name.

Specified by:
containsField in interface Document
Parameters:
name - The name of the pair for which to check
Returns:
true if this document contains a field with the supplied name, or false otherwise

containsAll

public boolean containsAll(Document document)
Description copied from interface: Document
Checks if this object contains all of the fields in the supplied document.

Specified by:
containsAll in interface Document
Parameters:
document - The document with the fields that should be in this document
Returns:
true if this document contains all of the fields in the supplied document, or false otherwise

keySet

public Set<String> keySet()
Description copied from interface: Document
Returns this object's fields' names

Specified by:
keySet in interface Document
Returns:
The names of the fields in this object

size

public int size()
Description copied from interface: Document
Return the number of name-value pairs in this object.

Specified by:
size in interface Document
Returns:
the number of name-value pairs; never negative

isEmpty

public boolean isEmpty()
Description copied from interface: Document
Return whether this document contains no fields and is therefore empty.

Specified by:
isEmpty in interface Document
Returns:
true if there are no fields in this document, or false if there is at least one.

ModeShape Distribution 3.0.0.Beta4

Copyright © 2008-2012 JBoss, a division of Red Hat. All Rights Reserved.