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 public enum AngularVelocityKey {
29
30
31 COMMENT((token, context, container) ->
32 token.getType() == TokenType.ENTRY ? container.addComment(token.getContentAsNormalizedString()) : true),
33
34
35 REF_FRAME_A((token, context, container) -> token.processAsFrame(container.getEndpoints()::setFrameA, context, true, true, true)),
36
37
38 REF_FRAME_B((token, context, container) -> {
39 if (token.getType() == TokenType.ENTRY) {
40 container.checkNotNull(container.getEndpoints().getFrameA(), REF_FRAME_A.name());
41 final boolean aIsSpaceraftBody = container.getEndpoints().getFrameA().asSpacecraftBodyFrame() != null;
42 return token.processAsFrame(container.getEndpoints()::setFrameB, context,
43 aIsSpaceraftBody, aIsSpaceraftBody, !aIsSpaceraftBody);
44 }
45 return true;
46 }),
47
48
49 ANGVEL_FRAME((token, context, container) -> token.processAsFrame(container::setFrame, context, true, true, true)),
50
51
52 ANGVEL_X((token, context, container) -> token.processAsDouble(Units.DEG_PER_S, context.getParsedUnitsBehavior(),
53 container::setAngVelX)),
54
55
56 ANGVEL_Y((token, context, container) -> token.processAsDouble(Units.DEG_PER_S, context.getParsedUnitsBehavior(),
57 container::setAngVelY)),
58
59
60 ANGVEL_Z((token, context, container) -> token.processAsDouble(Units.DEG_PER_S, context.getParsedUnitsBehavior(),
61 container::setAngVelZ));
62
63
64 private final transient TokenProcessor processor;
65
66
67
68
69 AngularVelocityKey(final TokenProcessor processor) {
70 this.processor = processor;
71 }
72
73
74
75
76
77
78
79 public boolean process(final ParseToken token, final ContextBinding context, final AngularVelocity container) {
80 return processor.process(token, context, container);
81 }
82
83
84 interface TokenProcessor {
85
86
87
88
89
90
91 boolean process(ParseToken token, ContextBinding context, AngularVelocity container);
92 }
93
94 }