All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.amazon.ion.impl.lite.IonContext Maven / Gradle / Ivy

/*
 * Copyright 2007-2019 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://www.apache.org/licenses/LICENSE-2.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 com.amazon.ion.impl.lite;

import com.amazon.ion.IonContainer;
import com.amazon.ion.SymbolTable;

/**
 * Provides the parent, system and symbol table definitions that are shared
 * by one or more hierarchies of IonValues.
 * 

* The type of context used by a value depends on its position. *

    *
  • Top-level values have either a {@link TopLevelContext} or an * {@link IonSystemLite} for a context. *
  • Non-top-level values have their {@link IonContainer} for a context. *
  • Datagrams have their {@link IonSystemLite} for a context. *
*

* Concrete * contexts simply return the correct values (and * own them). Containers return themselves as the * parent and delegate to their parent for the * system and symbol table values. Note that values * contained directly by a datagram may store a * symbol table locally as there may be more than * one symbol table in a datagram. */ interface IonContext { /** * Return the container of values associated with this context. * If this context is an {@link IonContainerLite} it returns itself. * * @return the container of the value; * null for stand-alone top level values. */ abstract IonContainerLite getContextContainer(); /** * Get the IonSystem concrete object that created * the IonValue that is associated with this context. * Generally this delegates to the parent. * * @return not null */ abstract IonSystemLite getSystem(); /** * Returns the symbol table that is directly assigned to this context. * For {@link TopLevelContext} it is the symbol table member. * For {@link IonContainerLite} and {@link IonSystemLite} it is null. * * @return the directly assigned symbol table, with no recursive lookup. */ abstract SymbolTable getContextSymbolTable(); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy