2 * ============LICENSE_START====================================================
4 * ===========================================================================
5 * Copyright (c) 2018 AT&T Intellectual Property. All rights reserved.
6 * ===========================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END====================================================
22 package org.onap.aaf.misc.rosetta.marshal;
24 import java.util.Iterator;
26 import org.onap.aaf.misc.rosetta.Ladder;
27 import org.onap.aaf.misc.rosetta.Marshal;
28 import org.onap.aaf.misc.rosetta.ParseException;
29 import org.onap.aaf.misc.rosetta.Parsed;
31 public class DocMarshal<T> extends Marshal<T> {
32 private Marshal<T> root;
34 public DocMarshal(Marshal<T> root) {
39 public Parsed<State> parse(T t, Parsed<State> parsed) throws ParseException {
40 Ladder<Iterator<?>> ladder = parsed.state.ladder;
41 Iterator<?> iter = ladder.peek();
43 ladder.push(PENDING_ITERATOR);
44 parsed.event = START_DOC;
45 } else if (DONE_ITERATOR.equals(iter)) {
47 ladder.ascend(); // look at field info
48 Iterator<?> currFieldIter = ladder.peek();
49 if(!DONE_ITERATOR.equals(currFieldIter)){
50 parsed = root.parse(t, parsed);
53 if(DONE_ITERATOR.equals(currFieldIter) || parsed.event==NONE) {
54 parsed.event = END_DOC;
55 ladder.push(DONE_ITERATOR);
58 return parsed; // if unchanged, then it will end process
62 public static final Iterator<Void> PENDING_ITERATOR = new Iterator<Void>() {
64 public boolean hasNext() {
74 public void remove() {
78 public static<T> DocMarshal<T> root(Marshal<T> m) {
79 return (DocMarshal<T>)new DocMarshal<T>(m);