com.ibm.cloud.objectstorage.thirdparty.ion.IonStruct Maven / Gradle / Ivy
/*
* Copyright 2007-2016 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at:
*
* http://aws.amazon.com/apache2.0/
*
* or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific
* language governing permissions and limitations under the License.
*/
package software.amazon.ion;
import java.util.Map;
/**
* An Ion struct
value.
*
* WARNING: This interface should not be implemented or extended by
* code outside of this library.
*
* Note that this cannot extend {@link java.util.Map} because that interface
* requires unique keys, while Ion's structs allow duplicate field names.
*/
public interface IonStruct
extends IonContainer
{
/**
* Gets the number of fields in this struct. If any field names are
* repeated, they are counted individually. For example, the size of
* {a:1,a:2}
is 2.
*
* @return the number of fields.
* @throws NullValueException if this.isNullValue()
.
*/
public int size()
throws NullValueException;
/**
* Determines whether this struct contains one or more fields
* for the specified field name (i.e., key). If this struct is an
* {@linkplain #isNullValue() Ion null value}, it will behave like an empty
* struct.
*
* @param fieldName field name whose presence in this struct is to be tested
*
* @return true
if this struct contains a field for the
* specified field name
*
* @throws ClassCastException if the specified field name is not a
* {@link String}
* @throws NullPointerException if the specified field name is
* null
*/
public boolean containsKey(Object fieldName);
/**
* Determines whether this struct contains one or more fields with
* the specified value. If this struct is an
* {@linkplain #isNullValue() Ion null value}, it will behave like an empty
* struct. This uses reference equality to compare the specified value with
* the value of the struct fields.
*
* @param value value whose presence in this struct is to be tested
*
* @return true
if this struct contains a field for the
* specified value
*
* @throws ClassCastException if the specified value is not an
* {@link IonValue}
* @throws NullPointerException if the specified value is null
*/
public boolean containsValue(Object value);
/**
* Gets the value of a field in this struct. If the field name appears
* more than once, one of the fields will be selected arbitrarily. For
* example, calling get("a")
on the struct:
*
* { a:1, b:2, a:3 }
*
* will return either 1 or 3.
*
* @param fieldName the desired field.
* @return the value of the field, or null
if it doesn't
* exist in this struct, or if this is {@code null.struct}.
* @throws NullPointerException if the fieldName
* is null
.
*/
public IonValue get(String fieldName);
/**
* Puts a new field in this struct, replacing all existing fields
* with the same name. If {@code child == null} then all existing fields
* with the given name will be removed.
*
* If this is null.struct
and {@code child != null} then this
* becomes a single-field struct.
*
* The effect of this method is such that if
* {@code put(fieldName, child)} succeeds, then
* {@code get(fieldName) == child} will be true afterwards.
*
* @param fieldName the name of the new field.
* @param child the value of the new field.
*
* @throws NullPointerException
* if {@code fieldName} is null
.
* @throws ContainedValueException
* if {@code child} is already part of a container.
* @throws IllegalArgumentException
* if {@code element} is an {@link IonDatagram}.
*/
public void put(String fieldName, IonValue child)
throws ContainedValueException;
/**
* Provides a factory that when invoked constructs a new value and
* {@link #put(String,IonValue) put}s it into this struct using the given
* {@code fieldName}.
*
* These two lines are equivalent:
*
* str.put("f").newInt(3);
* str.put("f", str.getSystem().newInt(3));
*
*
* @throws NullPointerException
* if {@code fieldName} is null
.
*
* @see #put(String, IonValue)
*/
public ValueFactory put(String fieldName);
/**
* Copies all of the mappings from the specified map to this struct.
* The effect of this call is equivalent to that of calling
* {@link #put(String, IonValue) put(k, v)} on this struct once for each
* mapping from key {@code k} to value {@code v} in the specified map.
* The behavior of this operation is undefined if the specified map is
* modified while the operation is in progress.
*
* If a key in the map maps to {@code null}, then all fields with that name
* will be removed from this struct.
*
* @throws NullPointerException if the given map is null.
* @throws ContainedValueException if any values in the map are already
* part of an {@link IonContainer} (even this one).
*/
public void putAll(Map extends String, ? extends IonValue> m);
/**
* Adds a new field to this struct.
* If this is null.struct
, then it becomes a single-field
* struct.
*
* If a field with the given name already exists in this struct,
* this call will result in repeated fields.
*
* @param fieldName the name of the new field.
* @param child the value of the new field.
*
* @throws NullPointerException
* if {@code fieldName} or {@code child} is null
.
* @throws ContainedValueException
* if {@code child} is already part of a container.
* @throws IllegalArgumentException
* if {@code element} is an {@link IonDatagram}.
*/
public void add(String fieldName, IonValue child)
throws ContainedValueException;
/**
* Adds a new field to this struct using a given name and/or SID.
* If this is null.struct
, then it becomes a single-field
* struct.
*
* If a field with the given name already exists in this struct,
* this call will result in repeated fields.
*
* This is an "expert method": correct use requires deep understanding
* of the Ion binary format. You almost certainly don't want to use it.
*
* @param fieldName the name of the new field.
* @param child the value of the new field.
*
* @throws NullPointerException
* if {@code fieldName} or {@code child} is null
.
* @throws ContainedValueException
* if {@code child} is already part of a container.
* @throws IllegalArgumentException
* if {@code element} is an {@link IonDatagram}.
*
*/
public void add(SymbolToken fieldName, IonValue child)
throws ContainedValueException;
/**
* Provides a factory that when invoked constructs a new value and
* {@link #add(String,IonValue) add}s it to this struct using the given
* {@code fieldName}.
*
* These two lines are equivalent:
*
* str.add("f").newInt(3);
* str.add("f", str.getSystem().newInt(3));
*
*
* @throws NullPointerException
* if {@code fieldName} is null
.
*
* @see #add(String, IonValue)
*/
public ValueFactory add(String fieldName);
/**
* Removes a field by name, returning a value that was previously
* associated with the field, or {@code null} if this struct contained no
* such field.
*
* Because Ion structs may have repeated fields, additional fields with the
* given name may still exist after this method returns.
*
* If this struct is an {@linkplain #isNullValue() Ion null value} or empty,
* then this method returns null and has no effect.
*
* @param fieldName must not be null.
*
* @return previous value associated with the specified field name, or
* {@code null} if there was no such field.
*/
public IonValue remove(String fieldName);
/**
* Removes from this struct all fields with names in the given list.
* If multiple fields with a given name exist in this struct,
* they will all be removed.
*
* If this struct is an {@linkplain #isNullValue() Ion null value} or empty,
* then this method returns {@code false} and has no effect.
*
* @param fieldNames the names of the fields to remove.
*
* @return true if this struct changed as a result of this call.
*
* @throws NullPointerException
* if {@code fieldNames}, or any element within it, is null
.
*/
public boolean removeAll(String... fieldNames);
/**
* Retains only the fields in this struct that have one of the given names.
* In other words, removes all fields with names that are not in
* {@code fieldNames}.
*
* If this struct is an {@linkplain #isNullValue() Ion null value} or empty,
* then this method returns {@code false} and has no effect.
*
* @param fieldNames the names of the fields to retain.
*
* @return true if this struct changed as a result of this call.
*
* @throws NullPointerException
* if {@code fieldNames}, or any element within it, is null
.
*/
public boolean retainAll(String... fieldNames);
// TODO public Set keySet();
// TODO public Collection values();
// TODO public Set> entrySet();
public IonStruct clone()
throws UnknownSymbolException;
/**
* Clones this struct, excluding certain fields. This can be more
* efficient than cloning the struct and removing fields later on.
*
* @param fieldNames the names of the fields to remove.
* A null field name causes removal of fields with unknown names.
*
* @throws UnknownSymbolException
* if any part of the cloned value would have unknown text but known SID
* for its field name, annotation or symbol.
*
* @see IonValue#clone()
*/
public IonStruct cloneAndRemove(String... fieldNames)
throws UnknownSymbolException;
/**
* Clones this struct, including only certain fields. This can be more
* efficient than cloning the struct and removing fields later on.
*
* @param fieldNames the names of the fields to retain.
* Nulls are not allowed.
*
* @throws NullPointerException
* if {@code fieldNames}, or any element within it, is null
.
* @throws UnknownSymbolException
* if any part of the cloned value would have unknown text but known SID
* for its field name, annotation or symbol.
*
* @see IonValue#clone()
*/
public IonStruct cloneAndRetain(String... fieldNames)
throws UnknownSymbolException;
}