Package org.apache.sis.metadata
Enum Class ValueExistencePolicy
- All Implemented Interfaces:
- Serializable,- Comparable<ValueExistencePolicy>,- Constable
Whatever 
MetadataStandard.asValueMap(…) shall contain entries for null,
 nil or empty values. By default the value map does not provide
 entries for null metadata properties, nil objects or
 empty collections.
 This enumeration allows to control this behavior.
 Difference between null and nil
A null property is a reference which isnull in the Java sense.
 Null references can be used for missing properties when no information is provided about why the property is missing.
 On the other hand, a nil object is a placeholder for a missing property similar in purpose to null references,
 except that an explanation about why the property is missing can be attached to those objects.
 Those explanations can be obtained by calls to the NilReason.forObject(Object) method.- Since:
- 0.3
- See Also:
Defined in the sis-metadata module
- 
Nested Class SummaryNested classes/interfaces inherited from class EnumEnum.EnumDesc<E extends Enum<E>>
- 
Enum Constant SummaryEnum ConstantsEnum ConstantDescriptionIncludes all entries in the map, including those having a null value or an empty collection.Includes non-empty properties but omits title properties.Includes only the properties that are non-null, non-nil and non empty.Includes only the non-null and non-nil properties.Includes only the non-null properties.
- 
Method SummaryModifier and TypeMethodDescriptionstatic ValueExistencePolicyReturns the enum constant of this class with the specified name.static ValueExistencePolicy[]values()Returns an array containing the constants of this enum class, in the order they are declared.Methods inherited from class Enumclone, compareTo, describeConstable, equals, finalize, getDeclaringClass, hashCode, name, ordinal, toString, valueOf
- 
Enum Constant Details- 
ALLIncludes all entries in the map, including those having a null value or an empty collection.
- 
NON_NULLIncludes only the non-null properties.NilObjects are included. Collections are included no matter if they are empty or not.The set of NON_NULLproperties is a subset ofALLproperties.
- 
NON_NILIncludes only the non-null and non-nil properties. Collections are included no matter if they are empty or not.The set of NON_NILproperties is a subset ofNON_NULLproperties.- Since:
- 0.4
 
- 
NON_EMPTYIncludes only the properties that are non-null, non-nil and non empty. A non-null and non-nil property is considered empty in any of the following cases:- It is a character sequence containing only whitespaces.
- It is an empty collection.
- It is an empty map.
- It is an empty array (of length 0).
 AbstractMetadata.asMap().The set of NON_EMPTYproperties is a subset ofNON_NILproperties.
- 
COMPACTIncludes non-empty properties but omits title properties. Values associated to title properties are instead associated with the parent node. This policy is relevant for metadata classes annotated withTitleProperty; for all other classes, this policy is identical toNON_EMPTY.Example: theThis policy is the default behavior ofDefaultCitationandDefaultCitationDateclasses are annotated with@TitleProperty(name="title")and@TitleProperty(name="date")respectively. The following table compares the trees produced by two policies:Comparison of "non-empty" and "compact" policy on the same metadata NON_EMPTYCOMPACTCitation ├─Title……………………… My document └─Date ├─Date………………… 2012/01/01 └─Date type…… CreationCitation……………………… My document └─Date………………………… 2012/01/01 └─Date type…… CreationAbstractMetadata.asTreeTable(), and consequently defines the default rendering ofAbstractMetadata.toString().- Since:
- 0.8
- See Also:
 
 
- 
- 
Method Details- 
valuesReturns an array containing the constants of this enum class, in the order they are declared.- Returns:
- an array containing the constants of this enum class, in the order they are declared
 
- 
valueOfReturns the enum constant of this class with the specified name. The string must match exactly an identifier used to declare an enum constant in this class. (Extraneous whitespace characters are not permitted.)- Parameters:
- name- the name of the enum constant to be returned.
- Returns:
- the enum constant with the specified name
- Throws:
- IllegalArgumentException- if this enum class has no constant with the specified name
- NullPointerException- if the argument is null
 
 
-