1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.orekit.files.ccsds.section;
18
19 import org.orekit.errors.OrekitException;
20 import org.orekit.errors.OrekitMessages;
21 import org.orekit.files.ccsds.utils.FileFormat;
22 import org.orekit.files.ccsds.utils.lexical.ParseToken;
23 import org.orekit.files.ccsds.utils.lexical.TokenType;
24 import org.orekit.files.ccsds.utils.parsing.AbstractConstituentParser;
25 import org.orekit.files.ccsds.utils.parsing.ProcessingState;
26
27
28
29
30
31 public class XmlStructureProcessingState implements ProcessingState {
32
33
34 private final String root;
35
36
37 private final AbstractConstituentParser<?, ?, ?> parser;
38
39
40
41
42
43 public XmlStructureProcessingState(final String root, final AbstractConstituentParser<?, ?, ?> parser) {
44 this.root = root;
45 this.parser = parser;
46 }
47
48
49 @Override
50 public boolean processToken(final ParseToken token) {
51
52 if (root.equals(token.getName())) {
53 parser.setEndTagSeen(token.getType() == TokenType.STOP);
54 return true;
55 }
56
57 if (Double.isNaN(parser.getHeader().getFormatVersion())) {
58
59 if (parser.getFormatVersionKey() != null &&
60 parser.getFormatVersionKey().equals(token.getName()) && token.getType() == TokenType.ENTRY) {
61 parser.getHeader().setFormatVersion(token.getContentAsDouble());
62 return true;
63 } else {
64 throw new OrekitException(OrekitMessages.UNSUPPORTED_FILE_FORMAT, token.getFileName());
65 }
66 }
67
68 try {
69 return XmlStructureKey.valueOf(token.getName()).process(token, parser);
70 } catch (IllegalArgumentException iae) {
71
72 return false;
73 }
74 }
75
76 }