public interface BindingStreamEventWriter extends Closeable, Flushable
container - Container node representation, start event is
 emitted using startContainerNode(Class, int) and node end event is
 emitted using endNode(). Container node is implementing
 DataObject interface.
 list - YANG list statement has two representation in event
 stream - unkeyed list and map. Unkeyed list is YANG list which did not
 specify key.
 Map - Map start event is emitted using
 startMapNode(Class, int) and is ended using endNode(). Each map
 entry start is emitted using startMapEntryNode(Identifier, int) with Map of keys
 and finished using endNode().UnkeyedList - Unkeyed list represent list without keys,
 unkeyed list start is emitted using startUnkeyedList(Class, int) list
 end is emitted using endNode(). Each list item is emitted using
 startUnkeyedListItem(int) and ended using endNode().leaf - Leaf node event is emitted using
 leafNode(String, Object). endNode() MUST be not emitted for
 leaf node.leaf-list - Leaf list start is emitted using
 startLeafSet(String, int). Leaf list end is emitted using
 endNode(). Leaf list entries are emitted using
 leafSetEntryNode(Object).
 anyxml - Anyxml node event is emitted using
 leafNode(String, Object). endNode() MUST be not emitted
 for anyxml node.choice Choice node event is emitted by
 startChoiceNode(Class, int) event and must be immediately followed by
 startCase(Class, int) event. Choice node is finished by emitting an
 endNode() event.case - Case node may be emitted only inside choice node by
 invoking startCase(Class, int). Case node is finished be emitting an
 endNode() event.augment - Represents augmentation, augmentation node is started
 by invoking startAugmentationNode(Class) and
 finished by invoking endNode().This interface is intended as API definition of facade for real Event / Stream Writer, without explicitly requiring stream writer and related interfaces to be imported by all generated Binding DTOs.
Existence of this interface in base Java Binding package is required to support runtime generation of users of this interface in OSGI and OSGI-like environment, since this package is only package which is imported by all generated Binding DTOs and wired in OSGI.
| Modifier and Type | Field and Description | 
|---|---|
| static int | UNKNOWN_SIZEMethods in this interface allow users to hint the underlying implementation about the sizing of container-like
 constructors (leafLists, containers, etc.). | 
| Modifier and Type | Method and Description | 
|---|---|
| void | anyxmlNode(String name,
          Object value)Emits anyxml node event. | 
| void | close() | 
| void | endNode()Emits end event for node. | 
| void | flush() | 
| void | leafNode(String localName,
        Object value)Emits a leaf node event with supplied value. | 
| void | leafSetEntryNode(Object value)Emits a leaf set entry node. | 
| void | startAugmentationNode(Class<? extends Augmentation<?>> augmentationType)Emits start of augmentation node. | 
| void | startCase(Class<? extends DataObject> caze,
         int childSizeHint)Starts a case node. | 
| void | startChoiceNode(Class<? extends DataContainer> choice,
               int childSizeHint)Emits start of choice node. | 
| void | startContainerNode(Class<? extends DataObject> container,
                  int childSizeHint)Emits start of new container. | 
| void | startLeafSet(String localName,
            int childSizeHint)Emits a start of leaf set (leaf-list). | 
| void | startMapEntryNode(Identifier<?> keyValues,
                 int childSizeHint)Emits start of map entry. | 
| <T extends DataObject & Identifiable<?>> | startMapNode(Class<T> mapEntryType,
            int childSizeHint)Emits start of unordered map node event. | 
| void | startOrderedLeafSet(String localName,
                   int childSizeHint)Emits a start of leaf set (leaf-list). | 
| <T extends DataObject & Identifiable<?>> | startOrderedMapNode(Class<T> mapEntryType,
                   int childSizeHint)Emits start of ordered map node event. | 
| void | startUnkeyedList(Class<? extends DataObject> localName,
                int childSizeHint)Emits start of unkeyed list node event. | 
| void | startUnkeyedListItem(int childSizeHint)Emits start of new unkeyed list item. | 
static final int UNKNOWN_SIZE
The acceptable hint values are non-negative integers and this constant, all other values will result, based on implementation preference, in the hint being completely ignored or IllegalArgumentException being thrown.
void leafNode(String localName, Object value) throws IOException
localName - name of node as defined in schema, namespace and revision are
            derived from parent node.value - Value of leaf node.IllegalArgumentException - If emitted leaf node has invalid value in current context or
             was emitted multiple times.IllegalStateException - If node was emitted inside map,
             choice unkeyed list node.IOException - if an underlying IO error occursvoid startLeafSet(String localName, int childSizeHint) throws IOException
leafSetEntryNode(Object) calls are valid. Leaf set event is finished by calling endNode().localName - name of node as defined in schema, namespace and revision are
            derived from parent node.childSizeHint - Non-negative count of expected direct child nodes or
            UNKNOWN_SIZE if count is unknown. This is only hint
            and should not fail writing of child events, if there are more
            events than count.IllegalArgumentException - If emitted leaf node is invalid in current context or was
             emitted multiple times.IllegalStateException - If node was emitted inside map,
             choice unkeyed list node.IOException - if an underlying IO error occursvoid startOrderedLeafSet(String localName, int childSizeHint) throws IOException
 Emits start of leaf set, during writing leaf set event, only
 leafSetEntryNode(Object) calls are valid. Leaf set event is
 finished by calling endNode().
localName - name of node as defined in schema, namespace and revision are
            derived from parent node.childSizeHint - Non-negative count of expected direct child nodes or
            UNKNOWN_SIZE if count is unknown. This is only hint
            and should not fail writing of child events, if there are more
            events than count.IllegalArgumentException - If emitted leaf node is invalid in current context or was
             emitted multiple times.IllegalStateException - If node was emitted inside map,
             choice unkeyed list node.IOException - if an underlying IO error occursvoid leafSetEntryNode(Object value) throws IOException
value - Value of leaf set entry node.IllegalArgumentException - If emitted leaf node has invalid value.IllegalStateException - If node was emitted outside leaf set node.IOException - if an underlying IO error occursvoid startContainerNode(Class<? extends DataObject> container, int childSizeHint) throws IOException
endNode().
 Valid sub-events are:
container - name of node as defined in schema, namespace and revision are
            derived from parent node.childSizeHint - Non-negative count of expected direct child nodes or
            UNKNOWN_SIZE if count is unknown. This is only hint
            and should not fail writing of child events, if there are more
            events than count.IllegalArgumentException - If emitted node is invalid in current context or was emitted
             multiple times.IllegalStateException - If node was emitted inside map,
             choice unkeyed list node.IOException - if an underlying IO error occursvoid startUnkeyedList(Class<? extends DataObject> localName, int childSizeHint) throws IOException
 End of unkeyed list event is emitted by invoking endNode().
 Valid subevents is only startUnkeyedListItem(int). All other
 methods will throw IllegalArgumentException.
localName - name of node as defined in schema, namespace and revision are
            derived from parent node.childSizeHint - Non-negative count of expected direct child nodes or
            UNKNOWN_SIZE if count is unknown. This is only hint
            and should not fail writing of child events, if there are more
            events than count.IllegalArgumentException - If emitted node is invalid in current context or was emitted
             multiple times.IllegalStateException - If node was emitted inside map,
             choice unkeyed list node.IOException - if an underlying IO error occursvoid startUnkeyedListItem(int childSizeHint)
                   throws IOException
 Unkeyed list item event is finished by invoking endNode(). Valid
 sub-events are:
 
childSizeHint - Non-negative count of expected direct child nodes or
            UNKNOWN_SIZE if count is unknown. This is only hint
            and should not fail writing of child events, if there are more
            events than count.IllegalStateException - If node was emitted outside unkeyed list node.IOException - if an underlying IO error occurs<T extends DataObject & Identifiable<?>> void startMapNode(Class<T> mapEntryType, int childSizeHint) throws IOException
 End of map node event is emitted by invoking endNode(). Valid
 subevent is only startMapEntryNode(Identifier, int). All other methods will
 throw IllegalArgumentException.
mapEntryType - Class of list item, which has defined key.childSizeHint - Non-negative count of expected direct child nodes or
            UNKNOWN_SIZE if count is unknown. This is only hint
            and should not fail writing of child events, if there are more
            events than count.IllegalArgumentExceptionIllegalStateException - If node was emitted inside map,
             choice unkeyed list node.IOException - if an underlying IO error occurs<T extends DataObject & Identifiable<?>> void startOrderedMapNode(Class<T> mapEntryType, int childSizeHint) throws IOException
 End of map node event is emitted by invoking endNode(). Valid
 subevent is only startMapEntryNode(Identifier, int). All other methods will
 throw IllegalArgumentException.
mapEntryType - Class of list item, which has defined key.childSizeHint - Non-negative count of expected direct child nodes or
            UNKNOWN_SIZE if count is unknown. This is only hint
            and should not fail writing of child events, if there are more
            events than count.IllegalArgumentExceptionIllegalStateException - If node was emitted inside map,
             choice unkeyed list node.IOException - if an underlying IO error occursvoid startMapEntryNode(Identifier<?> keyValues, int childSizeHint) throws IOException
 End of map entry event is emitted by invoking endNode().
 
Valid sub-events are:
keyValues - Key of map entry nodechildSizeHint - Non-negative count of expected direct child nodes or
            UNKNOWN_SIZE if count is unknown. This is only hint
            and should not fail writing of child events, if there are more
            events than count.IllegalArgumentException - If key contains incorrect value.IllegalStateException - If node was emitted outside map entry node.IOException - if an underlying IO error occursvoid startChoiceNode(Class<? extends DataContainer> choice, int childSizeHint) throws IOException
 Valid sub-event in startCase(Class, int), which selects case
 which should be written.
choice - Choice class.childSizeHint - Non-negative count of expected direct child nodes or
            UNKNOWN_SIZE if count is unknown. This is only hint
            and should not fail writing of child events, if there are more
            events than count.IllegalStateException - If node was emitted inside map, choice,
             unkeyed list node.IOException - if an underlying IO error occursvoid startCase(Class<? extends DataObject> caze, int childSizeHint) throws IOException
Valid sub-events are:
caze - Case classIOException - if an underlying IO error occursvoid startAugmentationNode(Class<? extends Augmentation<?>> augmentationType) throws IOException
 End of augmentation event is emitted by invoking endNode().
 
Valid sub-events are:
leafNode(String, Object)startContainerNode(Class, int)startChoiceNode(Class, int)startLeafSet(String, int)startMapNode(Class, int)startUnkeyedList(Class, int)
 Note this is only method, which does not require childSizeHint, since
 maximum value is always size of possibleChildren.
augmentationType - augmentation classIllegalArgumentException - If augmentation is invalid in current context.IOException - if an underlying IO error occursvoid anyxmlNode(String name, Object value) throws IOException
name - node namevalue - node valueIllegalStateException - If node was emitted inside map,
             choice unkeyed list node.IOException - if an underlying IO error occursvoid endNode()
      throws IOException
IllegalStateException - If there is no open node.IOException - if an underlying IO error occursvoid flush()
    throws IOException
flush in interface FlushableIOExceptionvoid close()
    throws IOException
close in interface AutoCloseableclose in interface CloseableIOExceptionCopyright © 2018 OpenDaylight. All rights reserved.