1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.orekit.files.ccsds.ndm.adm.apm;
18
19 import org.orekit.files.ccsds.definitions.Units;
20 import org.orekit.files.ccsds.utils.ContextBinding;
21 import org.orekit.files.ccsds.utils.lexical.ParseToken;
22 import org.orekit.files.ccsds.utils.lexical.TokenType;
23
24
25
26
27
28
29 public enum InertiaKey {
30
31
32 COMMENT((token, context, container) ->
33 token.getType() == TokenType.ENTRY ? container.addComment(token.getContentAsNormalizedString()) : true),
34
35
36 INERTIA_REF_FRAME((token, context, container) -> token.processAsFrame(container::setFrame, context, false, false, true)),
37
38
39 I11((token, context, container) -> token.processAsDoublyIndexedDouble(0, 0, Units.KG_M2, context.getParsedUnitsBehavior(),
40 container::setInertiaMatrixEntry)),
41
42
43 IXX((token, context, container) -> token.processAsDoublyIndexedDouble(0, 0, Units.KG_M2, context.getParsedUnitsBehavior(),
44 container::setInertiaMatrixEntry)),
45
46
47 I22((token, context, container) -> token.processAsDoublyIndexedDouble(1, 1, Units.KG_M2, context.getParsedUnitsBehavior(),
48 container::setInertiaMatrixEntry)),
49
50
51 IYY((token, context, container) -> token.processAsDoublyIndexedDouble(1, 1, Units.KG_M2, context.getParsedUnitsBehavior(),
52 container::setInertiaMatrixEntry)),
53
54
55 I33((token, context, container) -> token.processAsDoublyIndexedDouble(2, 2, Units.KG_M2, context.getParsedUnitsBehavior(),
56 container::setInertiaMatrixEntry)),
57
58
59 IZZ((token, context, container) -> token.processAsDoublyIndexedDouble(2, 2, Units.KG_M2, context.getParsedUnitsBehavior(),
60 container::setInertiaMatrixEntry)),
61
62
63 I12((token, context, container) -> token.processAsDoublyIndexedDouble(0, 1, Units.KG_M2, context.getParsedUnitsBehavior(),
64 container::setInertiaMatrixEntry)),
65
66
67 IXY((token, context, container) -> token.processAsDoublyIndexedDouble(0, 1, Units.KG_M2, context.getParsedUnitsBehavior(),
68 container::setInertiaMatrixEntry)),
69
70
71 I13((token, context, container) -> token.processAsDoublyIndexedDouble(0, 2, Units.KG_M2, context.getParsedUnitsBehavior(),
72 container::setInertiaMatrixEntry)),
73
74
75 IXZ((token, context, container) -> token.processAsDoublyIndexedDouble(0, 2, Units.KG_M2, context.getParsedUnitsBehavior(),
76 container::setInertiaMatrixEntry)),
77
78
79 I23((token, context, container) -> token.processAsDoublyIndexedDouble(1, 2, Units.KG_M2, context.getParsedUnitsBehavior(),
80 container::setInertiaMatrixEntry)),
81
82
83 IYZ((token, context, container) -> token.processAsDoublyIndexedDouble(1, 2, Units.KG_M2, context.getParsedUnitsBehavior(),
84 container::setInertiaMatrixEntry));
85
86
87 private final transient TokenProcessor processor;
88
89
90
91
92 InertiaKey(final TokenProcessor processor) {
93 this.processor = processor;
94 }
95
96
97
98
99
100
101
102 public boolean process(final ParseToken token, final ContextBinding context, final Inertia data) {
103 return processor.process(token, context, data);
104 }
105
106
107 interface TokenProcessor {
108
109
110
111
112
113
114 boolean process(ParseToken token, ContextBinding context, Inertia data);
115 }
116
117 }