001package armyc2.c5isr.renderer.utilities;
002
003import java.util.ArrayList;
004import java.util.Map;
005
006/**
007 * Modifier Constants to be used as keys in the modifiers map when calling {@link armyc2.c5isr.renderer.MilStdIconRenderer#RenderIcon(String, Map, Map)}
008 * or {@link armyc2.c5isr.web.render.WebRenderer#RenderSymbol(String, String, String, String, String, String, double, String, Map, Map, int)}
009 */
010public class Modifiers {
011    /**
012     * <pre>
013     * Symbol Icon
014     * The innermost part of a symbol, comprised of an icon and optional modifiers, that represents a joint military object (see 5.3.4).
015     * Format: Graphic
016     * Symbol Set: All
017     * Remarks: Determined by SIDC positions 11-20.
018     * </pre>
019     */
020    public static final String A_SYMBOL_ICON = "A_SYMBOL_ICON";
021    /**
022     * <pre>
023     * Echelon
024     * An amplifier in a unit symbol that identifies command level (see 5.3.7.1 and table VII).
025     * Format: Graphic
026     * Symbol Set: All
027     * Remarks: Determined by SIDC positions 9-10.
028     * </pre>
029     */
030    public static final String B_ECHELON = "B_ECHELON";
031    /**
032     * <pre>
033     * Quantity
034     * An amplifier in an equipment symbol that identifies the number of items present.
035     * Examples include:
036     * 350 Beds 50 Gallons
037     * Format:
038     * Alphanumeric - {1,19}
039     * [#########] [XXXXXXXXXX]
040     * Symbol Set: 10, 11, 15, 25, 27, 60
041     * Remarks: Two-part composite field.
042     * Where # is the numeric value [1-999999999], and X is the unit of measure.
043     * Note: There should be a space between the numeric and the unit of measure values.
044     * </pre>
045     */
046    public static final String C_QUANTITY = "C_QUANTITY";
047    /**
048     * <pre>
049     * Task Force Indicator
050     * An amplifier that identifies a unit or activities symbol as a task force (see 5.3.7.2 and figure 14).
051     * Format: Graphic
052     * Symbol Set: 10
053     * Remarks: Determined by SIDC position 8.
054     * </pre>
055     */
056    public static final String D_TASK_FORCE_INDICATOR = "D_TASK_FORCE_INDICATOR";
057
058    /**
059     * <pre>
060     * Frame Shape Modifier
061     * A graphic modifier that displays standard identity, battle dimension, or exercise
062     * amplifying descriptors of an object (see 5.3.1 and table II).
063     * Format: Graphic
064     * Symbol Set: ALL BUT 25,45,46,47
065     * Remarks: 2525C, not processed as a modifier in 2525D+
066     * </pre>
067     */
068    public static final String E_FRAME_SHAPE_MODIFIER = "E_FRAME_SHAPE_MODIFIER";
069
070    /**
071     * <pre>
072     * Reinforced or Reduced
073     * An amplifier in a unit symbol that displays (+) for reinforced, (-) for reduced, (<u>+</u>) reinforced and reduced.
074     * Format: Alphanumeric - {1,1}
075     * Symbol Set: 10
076     * Remarks:
077     * </pre>
078     */
079    public static final String F_REINFORCED_REDUCED = "F_REINFORCED_REDUCED";
080    /**
081     * <pre>
082     * Staff Comments
083     * An amplifier for units, equipment and installations; content is implementation specific.
084     * Format: Alphanumeric - {1,20}
085     * Symbol Set: 01, 05, 10, 15, 20, 27, 30, 35, 40
086     * Remarks:
087     * </pre>
088     */
089    public static final String G_STAFF_COMMENTS = "G_STAFF_COMMENTS";
090    /**
091     * <pre>
092     * Additional Information
093     * An amplifier for units, equipment and installations; content is implementation specific.
094     * Format: Alphanumeric - {1,20}
095     * Symbol Set: ALL
096     * Remarks:
097     * </pre>
098     */
099    public static final String H_ADDITIONAL_INFO_1 = "H_ADDITIONAL_INFO_1";
100
101    /**
102     * <pre>
103     * Unlisted Point Information
104     * An alphanumeric text amplifier used to provide an up to a three-character letter field acronym to describe a point that is not already listed.
105     * Format: Alphanumeric - {1,3}
106     * Symbol Set: 25
107     * Remarks: Only used with Action Points (General) control measure. SIDC 130100.
108     * </pre>
109     */
110    public static final String H1_ADDITIONAL_INFO_2 = "H1_ADDITIONAL_INFO_2";
111
112    /**
113     * A text modifier for tactical graphics; content is
114     * implementation specific.
115     * CM: P,L,A,N,B/C,R/N
116     * Length: 20
117     * @deprecated 2525C
118     */
119    public static final String H2_ADDITIONAL_INFO_3 = "H2_ADDITIONAL_INFO_3";
120
121    /**
122     * <pre>
123     * Evaluation Rating
124     * An amplifier that consists of a one-letter reliability rating and a one-number credibility rating. (See ATP 2-33.4)
125     * Format: Alphanumeric - {2,2} [X][#]
126     * Symbol Set: 10, 15, 20,27, 40
127     * Remarks:
128     *
129     * Reliability Ratings:
130     * A-completely reliable
131     * B-usually reliable
132     * C-fairly reliable
133     * D-not usually reliable
134     * E-unreliable
135     * F-reliability cannot be judged
136     *
137     * Credibility Ratings:
138     * 1-confirmed by other sources
139     * 2-probably true
140     * 3-possibly true
141     * 4-doubtfully true
142     * 5-improbable
143     * 6-truth cannot be judged
144     * </pre>
145     */
146    public static final String J_EVALUATION_RATING = "J_EVALUATION_RATING";
147    /**
148     * <pre>
149     * Effectiveness
150     * An amplifier for units and installations that indicates unit effectiveness or installation capability.
151     * Format: Alphanumeric - {2,3}
152     * Symbol Set: 10, 15, 27
153     * Remarks:
154     * List of Values:
155     * FO - Fully Operational
156     * SO - Substantially operational
157     * MO - Marginally operational
158     * NO - Not operational
159     * UNK - Unknown
160     * </pre>
161     */
162    public static final String K_COMBAT_EFFECTIVENESS = "K_COMBAT_EFFECTIVENESS";
163    /**
164     * <pre>
165     * Signature Equipment
166     * An amplifier for hostile equipment; "!" indicates detectable electronic signatures.
167     * Format: Alphanumeric - {1,1}
168     * Symbol Set: 15
169     * Remarks: The amplifier displayed is the exclamation mark "!".
170     * </pre>
171     */
172    public static final String L_SIGNATURE_EQUIP = "L_SIGNATURE_EQUIP";
173    /**
174     * <pre>
175     * Higher Formation
176     * An amplifier for units that indicates number or title of higher echelon command (corps are designated by Roman numerals).
177     * Format: Alphanumeric - {1,21}
178     * Symbol Set: 10
179     * Remarks: The amplifier displayed is the exclamation mark "!".
180     * </pre>
181     */
182    public static final String M_HIGHER_FORMATION = "M_HIGHER_FORMATION";
183    /**
184     * <pre>
185     * Hostile (Enemy)
186     * An amplifier for equipment; letters "ENY" denote hostile symbols.
187     * Format: Alphanumeric - {3,3}
188     * Symbol Set: 15,25
189     * Remarks: Determined by SIDC position 4.
190     * Note: This amplifier must be used when displaying enemy/hostile control measures on monochromatic displays
191     * </pre>
192     */
193    public static final String N_HOSTILE = "N_HOSTILE";
194    /**
195     * <pre>
196     * IFF/SIF/AIS
197     * An amplifier displaying IFF/SIF/AIS Identification modes and codes.
198     * Format:
199     * <br></br><img src="" alt="" />
200     * Symbol Set: 01, 10, 15, 27, 30, 35
201     * Remarks: 'MODE' is not required when displaying.
202     * </pre>
203     */
204    public static final String P_IFF_SIF_AIS = "P_IFF_SIF_AIS";
205    /**
206     * <pre>
207     * Direction of Movement Indicator
208     * An amplifier consisting of a line with arrow that identifies the direction of movement or intended movement of an object (see 5.3.7.9 and figure 14).
209     * Format: Graphic (Alphanumeric for exchange only)
210     * Symbol Set: 10, 15, 20, 25, 27
211     * Remarks:
212     * Renderer Assumes a value in degrees with no text
213     * MilStd:
214     * <br></br><img src="" alt="" />
215     *
216     * </pre>
217     */
218    public static final String Q_DIRECTION_OF_MOVEMENT = "Q_DIRECTION_OF_MOVEMENT";
219    /**
220     * <pre>
221     * Mobility Indicator
222     * An amplifier that depicts the mobility of an object not intrinsic to the entity itself (see 5.3.7.9, figure 14 and table IX).
223     * Format: Graphic
224     * Symbol Set: 10
225     * Remarks: Determined by SIDC positions 9-10
226     * </pre>
227     */
228    public static final String R_MOBILITY_INDICATOR = "R_MOBILITY_INDICATOR";
229    /**
230     * <pre>
231     * SIGINT Mobility Indicator
232     * An amplifier that indicates the mobility of a SIGINT unit.
233     * Format: Alphanumeric - {1,1}
234     * Symbol Set: 50, 51, 52, 53, 54
235     * Remarks:
236     * List of Values:
237     * M = Mobile,
238     * S = Static
239     * U = Uncertain.
240     * </pre>
241     */
242    public static final String R2_SIGNIT_MOBILITY_INDICATOR = "R2_SIGNIT_MOBILITY_INDICATOR";
243    /**
244     * <pre>
245     * Headquarters Staff Indicator
246     * An amplifier for units, installations and activities that identifies them as a headquarters (see figure 14 and figure 13).
247     * Format: Graphic
248     * Symbol Set: 10, 20, 40
249     * Remarks: Determined by SIDC position 8.
250     * </pre>
251     */
252    public static final String S_HQ_STAFF_INDICATOR = "S_HQ_STAFF_INDICATOR";
253    /**
254     * <pre>
255     * Offset Location Indicator
256     * An amplifier used to indicate the offset or precise location of a single point symbol (see 5.3.7.5, 5.3.12, and figure 14).
257     * Format: Graphic
258     * Symbol Set: 10, 20, 25, 27, 40
259     * Remarks: Determined by individual system implementations, not implemented by the renderer.
260     * </pre>
261     */
262    public static final String S2_OFFSET_INDICATOR = "S2_OFFSET_INDICATOR";
263    /**
264     * <pre>
265     * Unique Designation
266     * An amplifier that uniquely identifies a particular symbol or track number. Identifies acquisitions number when used with SIGINT symbology.
267     * Format: Alphanumeric - {1,30}
268     * Symbol Set: All
269     * Remarks:
270     * </pre>
271     */
272    public static final String T_UNIQUE_DESIGNATION_1 = "T_UNIQUE_DESIGNATION_1";
273    /**
274     * <pre>
275     * Lines - Unique Identifier or Primary Purpose
276     * An amplifier that uniquely identifies a particular symbol or track number. Identifies acquisitions number when used with SIGINT symbology.
277     * Format: Alphanumeric - Lines: {1,30}, Points: Alphanumeric - {1,7}
278     * Symbol Set: 25
279     * Remarks:
280     * </pre>
281     */
282    public static final String T1_UNIQUE_DESIGNATION_2 = "T1_UNIQUE_DESIGNATION_2";
283    /**
284     * <pre>
285     * Lines - Unique Identifier or Primary Purpose
286     * An amplifier used to provide the designation of the Establishing Headquarters.
287     * Format: Alphanumeric - {1,7}
288     * Symbol Set: 25
289     * Remarks: Used with Fire Support Control Measures only.
290     * </pre>
291     */
292    public static final String T2_UNIQUE_DESIGNATION_3 = "T2_UNIQUE_DESIGNATION_3";
293    /**
294     * <pre>
295     * Type
296     * An amplifier for equipment that indicates types of equipment.
297     * Format: Alphanumeric - {1,24}
298     * Symbol Set: Not Installation(20), Activites(40), or CyberSpace(60)
299     * Remarks:
300     * Example:
301     * AH-64 for Attack Helicopter
302     * </pre>
303     */
304    public static final String V_EQUIP_TYPE = "V_EQUIP_TYPE";
305    /**
306     * <pre>
307     * Date/Time Group (DTG) W
308     * An amplifier for displaying a date-time group (DDHHMMSSZMONYYYY) or (DDHHMMZMMMYYYY) or "O/O" for On Order.
309     * Field "W" is used to provide DTG or if used with field "W1" the start of a period of time.
310     * Field "W1" is used to provide the end of a period of time.
311     * Format: Alphanumeric - {3,16}
312     * Symbol Set: 10, 15, 20, 25, 27, 40, 45
313     * Remarks:
314     * The date-time group is composed of a group of six numeric digits with a time zone suffix and the standardized three-letter abbreviation for the month followed by four digits representing the year.
315     * The first pair of digits represents the day; the second pair, the hour; the third pair, the minutes. For automated systems, two digits may be added before the time zone suffix and after the minutes to designate seconds (see 5.3.7.8).
316     * </pre>
317     */
318    public static final String W_DTG_1 = "W_DTG_1";
319    /**
320     * <pre>
321     * Date/Time Group (DTG) W1
322     * An amplifier for displaying a date-time group (DDHHMMSSZMONYYYY) or (DDHHMMZMMMYYYY) or "O/O" for On Order.
323     * Field "W" is used to provide DTG or if used with field "W1" the start of a period of time.
324     * Field "W1" is used to provide the end of a period of time.
325     * Format: Alphanumeric - {3,16}
326     * Symbol Set: 25
327     * Remarks:
328     * The date-time group is composed of a group of six numeric digits with a time zone suffix and the standardized three-letter abbreviation for the month followed by four digits representing the year.
329     * The first pair of digits represents the day; the second pair, the hour; the third pair, the minutes. For automated systems, two digits may be added before the time zone suffix and after the minutes to designate seconds (see 5.3.7.8).
330     * </pre>
331     */
332    public static final String W1_DTG_2 = "W1_DTG_2";
333    /**
334     * <pre>
335     * Altitude/Depth
336     * An amplifier that displays either altitude, flight level, depth for submerged objects or height of equipment or structures on the ground, the minimum, maximum and/or specific altitude (in feet or meters in relation to a reference datum) or depth (for submerged objects in feet below sea level). See 5.3.7.6 for content.
337     * Format:
338     * <br></br><img src="" alt="" />
339     * Symbol Set: All but 40 & 60
340     * Remarks:
341     * SM = Statute Miles
342     * DM = Data Miles
343     * Notes:
344     * The Renderer handles the whole value as a string for Single Point Icons.
345     * For multipoints, it expects just a number and an accompanying attribute {@link MilStdAttributes#AltitudeUnits}
346     * Default behavior assumes feet.
347     * </pre>
348     */
349    public static final String X_ALTITUDE_DEPTH = "X_ALTITUDE_DEPTH";
350    /**
351     * <pre>
352     * Location
353     * An amplifier that displays a symbol's location in degrees, minutes and decimal minutes (or in MGRS, GARS, or other applicable display formats).
354     * Format: Alphanumeric - {3,16}
355     * Symbol Set: 10, 15, 20, 25, 27, 30, 40
356     * Remarks: Exchange format is implementation specific.
357     * </pre>
358     */
359    public static final String Y_LOCATION = "Y_LOCATION";
360    /**
361     * <pre>
362     * Speed
363     * An amplifier that displays velocity (see 5.3.7.7).
364     * Format: Alphanumeric - {5,9} [#####] [XXX]
365     * Symbol Set: NOT 20, 35, 40, 60
366     * Remarks:
367     * Two-part composite field.
368     * Where # is the numeric value [1-999999999], and XXX is the unit of measure (KPH, KPS, MPH, NMH, KTS).
369     * Note: There should be a space between the numeric and the unit of measure values.
370     * </pre>
371     */
372    public static final String Z_SPEED = "Z_SPEED";
373    /**
374     * <pre>
375     * Special C2 Headquarters
376     * A amplifier that is contained inside the frame in place of the main icon and contains the name of the special C2 Headquarters.
377     * Format: Alphanumeric - {1,9}
378     * Symbol Set: 10
379     * Remarks:
380     * Examples: Named command such as SHAPE, PACOM, and joint, multinational, or coalition commands such as CJTF, JTF, or MJTF.
381     * </pre>
382     */
383    public static final String AA_SPECIAL_C2_HQ = "AA_SPECIAL_C2_HQ";
384    /**
385     * <pre>
386     * Feint/Dummy indicator
387     * An amplifier that identifies an offensive or defensive unit, intended to draw the enemy's attention away from the area of the main attack.
388     * Format: Graphic
389     * Symbol Set: 10, 15, 20, 25
390     * Remarks: Determined by SIDC position 8.
391     * </pre>
392     */
393    public static final String AB_FEINT_DUMMY_INDICATOR = "AB_FEINT_DUMMY_INDICATOR";
394
395    /**
396     * <pre>
397     * Platform Type
398     * An amplifier that identifies the electronic identification for a pulsed or non-pulsed electromagnetic emission.
399     * Format: Alphanumeric - {5,5}
400     * Symbol Set: 10, 15
401     * Remarks:
402     * List of Values:
403     * ELNOT = Electronic intelligence notation
404     * CENOT = Communications intelligence notation
405     * </pre>
406     */
407    public static final String AD_PLATFORM_TYPE = "AD_PLATFORM_TYPE";
408    /**
409     * <pre>
410     * Platform Type
411     * An amplifier that identifies equipment teardown time in minutes.
412     * Format: Numeric – {1,3}
413     * Symbol Set: 10(2525E), 15
414     * Remarks:
415     * </pre>
416     */
417    public static final String AE_EQUIPMENT_TEARDOWN_TIME = "AE_EQUIPMENT_TEARDOWN_TIME";
418    /**
419     * <pre>
420     * Common Identifier
421     * An amplifier to provide a common name used to identify an entity.
422     * Format: Alphanumeric - {1,12}
423     * Symbol Set: 10(2525E), 15, 27
424     * Remarks: Example: "Hawk" for Hawk SAM system.
425     * </pre>
426     */
427    public static final String AF_COMMON_IDENTIFIER = "AF_COMMON_IDENTIFIER";
428    /**
429     * <pre>
430     * Auxiliary Equipment Indicator
431     * An amplifier for equipment that indicates the presence of a towed sonar array (see 5.3.7.11, figure 14 and table IX).
432     * Format: Graphic
433     * Symbol Set: 15
434     * Remarks: Determined by SIDC positions 9-10.
435     * </pre>
436     */
437    public static final String AG_AUX_EQUIP_INDICATOR = "AG_AUX_EQUIP_INDICATOR";
438    /**
439     * <pre>
440     * Area of Uncertainty
441     * An amplifier that indicates the area where an object is most likely to be, based on the object's last report and
442     * the reporting accuracy of the sensor that detected the object (see 5.3.7.13.1 and figure 18.
443     * Format: Graphic (Alphanumeric for exchange only)
444     * Symbol Set: 01, 05, 10, 15, 20, 25, 27, 30, 35, 40
445     * Remarks:
446     * The amplifier can be displayed as an ellipse, a bearing box, or a line of bearing, depending on the report received for the object.
447     * Notes: Not implemented by the renderer
448     * </pre>
449     */
450    public static final String AH_AREA_OF_UNCERTAINTY = "AH_AREA_OF_UNCERTAINTY";
451    /**
452     * <pre>
453     * Dead Reckoning Trailer
454     * An amplifier that identifies where an object should be located at present, given its last reported course and speed (see 5.3.7.13.2).
455     * Format: Graphic
456     * Symbol Set: 01, 05, 10, 15, 20, 25, 27, 30, 35, 40
457     * Remarks:
458     * Locally derived information. This datum is not exchanged.
459     * Notes: Not implemented by the renderer
460     * </pre>
461     */
462    public static final String AI_DEAD_RECKONING_TRAILER = "AI_DEAD_RECKONING_TRAILER";
463    /**
464     * <pre>
465     * Speed Leader
466     * An amplifier that depicts the speed and direction of movement of an object (see 5.3.7.13.3 and figure 18).
467     * Format: Graphic
468     * Symbol Set: 10, 15, 30, 35
469     * Remarks: Set as "[Speed] [unit of measure] [angle in degrees if 3 characters "045", and in mils if 4 characters "0150]" like [100 KPH 045]
470     * Valid units of measure are: KPH, KPS, MPH, NMH, KTS
471     * Notes: It is recommended users handle this amplifier within their map engine as many maps always show icons in the upright position when the map
472     * is rotated, invalidating the line that's render with the symbol.
473     * </pre>
474     */
475    public static final String AJ_SPEED_LEADER = "AJ_SPEED_LEADER";
476    /**
477     * <pre>
478     * Pairing Line
479     * An amplifier that connects two objects and is updated dynamically as the positions of the two objects change (see 5.3.7.13.4 and figure 18).
480     * Format: Graphic
481     * Symbol Set: NA
482     * Remarks:
483     * Notes: Not implemented by the renderer
484     * </pre>
485     */
486    public static final String AK_PAIRING_LINE = "AK_PAIRING_LINE";
487    /**
488     * <pre>
489     * Operational Condition
490     * An amplifier that indicates operational condition or capacity.
491     * Format: Graphic
492     * Symbol Set: 01, 05,10, 15, 20, 30, 35
493     * Remarks: Determined by SIDC position 7.
494     * </pre>
495     */
496    public static final String AL_OPERATIONAL_CONDITION = "AL_OPERATIONAL_CONDITION";
497
498    /**
499     * <pre>
500     * Distance
501     * An amplifier that displays a minimum, maximum, or a specific distance (range, radius, width, length, etc.), in meters.
502     * Format: Alphanumeric - {3,9} [#] [X]
503     * Symbol Set: 25
504     * Remarks:
505     * "#" is the value (range 0-99999)
506     * XXX is the distance unit.
507     * There should be a space between the integer and the unit of measure values.
508     * Where more than one distance is specified the AM amplifier will be suffixed with a numeric entry, e.g. AM1, AM2.
509     * Note:
510     * Renderer expects just a number or a comma delimited string of numbers and an accompanying attribute {@link MilStdAttributes#DistanceUnits}
511     * Default behavior assumes meters.
512     * </pre>
513     */
514    public static final String AM_DISTANCE = "AM_DISTANCE";
515    /**
516     * <pre>
517     * Azimuth
518     * An amplifier that displays an angle measured from true north to any other line in degrees.
519     * Format: Alphanumeric - {7,8} [#####] [XXX]
520     * Symbol Set: 25
521     * Remarks:
522     * For Degrees entries.
523     * XXX DGT, where XXX is degrees from 000-359 and DGT is referenced to TRUE North.
524     * For Mils entries.
525     * XXXX MGT, where XXXX is MILS from 0000-6399 and MGT is referenced to TRUE North.
526     * Where more than one angle is specified the AN amplifier will be suffixed with a numeric entry, e.g. AN1, AN2.
527     * Note:
528     * Renderer expects just a number or a comma delimited string of numbers
529     * </pre>
530     */
531    public static final String AN_AZIMUTH = "AN_AZIMUTH";
532
533    /**
534     * Engagement Bar
535     * A graphic amplifier placed immediately atop the symbol. May denote:
536     * A) local/remote engagement status - 'R' for remote, 'B' for mix of local/remote, none for local
537     * B) engagement status
538     * C) weapon type.
539     *
540     * Format:
541     * Composite list of values
542     * Alphanumeric - {6,10}
543     * A:BBB-CC
544     * Symbol Set: 01, 05, 10, 30, 35
545     * Remarks: See 5.3.7.15.3 for explanation of engagement bar structure and codes.
546     * A - Type of Engagement
547     * BBB - Engagement Stage
548     * CC - Type of Weapon Assignment
549     */
550    public static final String AO_ENGAGEMENT_BAR = "AO_ENGAGEMENT_BAR";
551
552    /**
553     * <pre>
554     * Target Number
555     * An amplifier used in Fire Support operations to uniquely designate targets in accordance with STANAG 2934.
556     * Format: Alphanumeric - {6,6} [XX][####]
557     * Symbol Set: 25
558     * Remarks:
559     * Two-part composite field.
560     * Where positions 1-2 are text, and positions 3-6 are numeric.
561     * </pre>
562     */
563    public static final String AP_TARGET_NUMBER = "AP_TARGET_NUMBER";
564
565    /**
566     * <pre>
567     * Target Number Extension
568     * An amplifier used to identify a target number extension which is a sequentially assigned number identifying the individual elements in a target (MIL-STD-6017),
569     * Format: Numeric – {2,3} [-##]
570     * Symbol Set: 25
571     * Remarks:
572     * Position 1 is a dash (-) and positions 2-3 are numbers, from 1 through 15.
573     * It is applicable only to the "Point or Single Target" symbol.
574     * It is conditional upon the presence of the Target Number amplifier and is visually displayed appended to the Target Number amplifier.
575     * </pre>
576     */
577    public static final String AP1_TARGET_NUMBER_EXTENSION = "AP1_TARGET_NUMBER_EXTENSION";
578
579    /**
580     * <pre>
581     * Guarded Unit
582     * An amplifier used during ballistic missile defense. Some tracks are designated as guarded by a particular unit.
583     * Format: Alphanumeric - {6,6} [XX]
584     * Symbol Set: 10(2525E), 15, 20(2525E), 30
585     * Remarks:
586     * Single value:
587     * BG - Guarded Unit
588     * </pre>
589     */
590    public static final String AQ_GUARDED_UNIT = "AQ_GUARDED_UNIT";
591
592    /**
593     * <pre>
594     * Special Designator
595     * An amplifier that identifies special track designators.
596     * Format: Alphanumeric - {3,3}
597     * Symbol Set: 10, 30, 35
598     * Remarks:
599     * List of values:
600     * NRT - Non-Real Time.
601     * SIG - Tactically Significant Tracks.
602     * </pre>
603     */
604    public static final String AR_SPECIAL_DESIGNATOR = "AR_SPECIAL_DESIGNATOR";
605
606    /**
607     * <pre>
608     * Country
609     * A three-letter code that indicates the country of origin of the organization (US systems shall use GENC).
610     * Format: Alphanumeric - {3,3}
611     * Symbol Set: All
612     * Remarks: Determined by SIDC positions 28-30.
613     * </pre>
614     */
615    public static final String AS_COUNTRY = "AS_COUNTRY";
616
617    /**
618     * <pre>
619     * Capacity of Installation
620     * Capacity of installation displayed.
621     * Format: Alphanumeric - {1,19} [#########] [XXXXXXXXXX]
622     * Symbol Set: 2525E addition, not currently defined.  Probably 20
623     * Remarks:
624     * Two-part composite field.
625     * Comprised of:
626     * Quantity 0-99999999 followed by the unit of measure.
627     * e.g. 400 Beds
628     * </pre>
629     */
630    public static final String AT_CAPACITY_OF_INSTALLATION = "AT_CAPACITY_OF_INSTALLATION";
631
632    /**
633     * <pre>
634     * Leadership
635     * Identifies Leadership (ONLY IN DISMOUNTED INDIVIDUAL)
636     * Format: Graphic
637     * Symbol Set: 27(2525E)
638     * Remarks: Determined by SIDC positions 9-10.
639     * </pre>
640     */
641    public static final String AV_LEADERSHIP = "AV_LEADERSHIP";
642
643    /**
644     * <pre>
645     * Headquarters Element
646     * An amplifier that indicates what type of element of a headquarters is being represented, such as TOC, MAIN2.
647     * Format: Alphanumeric {0,8}
648     * Symbol Set: 10(2525E)
649     * Remarks: Location currently undefined
650     * </pre>
651     */
652    public static final String AW_HEADQUARTERS_ELEMENT = "AW_HEADQUARTERS_ELEMENT";
653
654    /**
655     * <pre>
656     * Installation Composition
657     * Indicates the component type of the installation
658     * Format: Alphanumeric {3,7}
659     * Symbol Set: 20(2525E)
660     * Remarks: Location currently undefined
661     * List of Values:
662     * DEVELOP - Development.
663     * RSRCH - Research.
664     * PROD - Production.
665     * SVC - Service.
666     * STORE - Storage.
667     * UTIL - Utility.
668     * </pre>
669     */
670    public static final String AX_INSTALLATION_COMPOSITION = "AX_INSTALLATION_COMPOSITION";
671
672    /**
673     * <pre>
674     * Network Identifier
675     * Indicates the network the entity has privileges within.
676     * Format: Alphanumeric
677     * Symbol Set: undefined
678     * Remarks:
679     * The colour of the graphic shall be assignable by the operator.
680     * Notes: undefined
681     * </pre>
682     */
683    public static final String AY_NETWORK_IDENTIFIER = "AY_NETWORK_IDENTIFIER";
684
685    //public static final String LENGTH = "Length";
686    //public static final String WIDTH = "Width";
687    //public static final String RADIUS = "Radius";
688    //public static final String SEGMENT_DATA = "Segment Data";
689
690    /**
691     * Returns an Arraylist of the all the modifiers that appear as labels and are not
692     * derived from the symbol code or are external to symbol data like offset indicator.
693     * Also includes modifiers that control the shape of a symbol like AM &amp; AN.
694     * @return {@link ArrayList}
695     */
696    public static ArrayList<String> GetModifierList()
697    {
698        ArrayList<String> list = new ArrayList<String>();
699
700        //list.add(A_SYMBOL_ICON);//graphical, feeds off of symbol code,
701        //list.add(B_ECHELON);//graphical, feeds off of symbol code,
702        list.add(C_QUANTITY);
703        list.add(D_TASK_FORCE_INDICATOR);//graphical, feeds off of symbol code,
704        //list.add(E_FRAME_SHAPE_MODIFIER);//symbol frame, feeds off of symbol code, symbol set
705        list.add(F_REINFORCED_REDUCED);//R = reinforced, D = reduced, RD = reinforced and reduced
706        list.add(G_STAFF_COMMENTS);
707        list.add(H_ADDITIONAL_INFO_1);
708        list.add(H1_ADDITIONAL_INFO_2);
709        list.add(J_EVALUATION_RATING);
710        list.add(K_COMBAT_EFFECTIVENESS);
711        list.add(L_SIGNATURE_EQUIP);
712        list.add(M_HIGHER_FORMATION);
713        list.add(N_HOSTILE);
714        list.add(P_IFF_SIF_AIS);
715        list.add(Q_DIRECTION_OF_MOVEMENT);//number in mils
716        //list.add(R_MOBILITY_INDICATOR);//graphical, feeds off of symbol code,
717        list.add(R2_SIGNIT_MOBILITY_INDICATOR);
718        //list.add(S_HQ_STAFF_INDICATOR);//graphical, feeds off of symbol code,
719        list.add(T_UNIQUE_DESIGNATION_1);
720        list.add(T1_UNIQUE_DESIGNATION_2);
721        list.add(V_EQUIP_TYPE);
722        list.add(W_DTG_1);
723        list.add(W1_DTG_2);
724        list.add(X_ALTITUDE_DEPTH);
725        list.add(Y_LOCATION);
726        list.add(Z_SPEED);
727
728        list.add(AA_SPECIAL_C2_HQ);
729        //list.add(AB_FEINT_DUMMY_INDICATOR);//graphical, feeds off of symbol code,
730        //list.add(AC_INSTALLATION);//graphical, feeds off of symbol code,
731        list.add(AD_PLATFORM_TYPE);
732        list.add(AE_EQUIPMENT_TEARDOWN_TIME);
733        list.add(AF_COMMON_IDENTIFIER);
734        //list.add(AG_AUX_EQUIP_INDICATOR);
735        list.add(AH_AREA_OF_UNCERTAINTY);
736        list.add(AI_DEAD_RECKONING_TRAILER);
737        list.add(AJ_SPEED_LEADER);//graphical
738        //list.add(AK_PAIRING_LINE);
739        //list.add(AL_OPERATIONAL_CONDITION);//2525C ////graphical, feeds off of symbol code, SIDC positions 4
740        list.add(AM_DISTANCE);
741        list.add(AN_AZIMUTH);
742        list.add(AO_ENGAGEMENT_BAR);//2525C
743        list.add(AP_TARGET_NUMBER);
744        list.add(AP1_TARGET_NUMBER_EXTENSION);
745        list.add((AQ_GUARDED_UNIT));
746        list.add((AR_SPECIAL_DESIGNATOR));
747        //list.add((AS_COUNTRY));
748
749
750        return list;
751    }
752
753    /**
754     * Returns an ArrayList of the modifier constants that are determined by the symbol code
755     * and therefore don't need their values to be manually typed or selected.
756     * (Based on the comments in GetModifierList, GetUnitModifierList, and GetControlMeasureModifierList.)
757     * @return {@link ArrayList}
758     */
759    public static ArrayList<String> GetSymbolCodeModifiersList() {
760        ArrayList<String> list = new ArrayList<>();
761
762        list.add(A_SYMBOL_ICON);//graphical, feeds off of symbol code,
763        list.add(B_ECHELON);//graphical, feeds off of symbol code,
764        list.add(D_TASK_FORCE_INDICATOR);//graphical, feeds off of symbol code,
765        list.add(N_HOSTILE);//textual, feeds off symbol code (gets set to "ENY" if hostile)
766        list.add(R_MOBILITY_INDICATOR);//graphical, feeds off of symbol code,
767        list.add(S_HQ_STAFF_INDICATOR);//graphical, feeds off of symbol code,
768        list.add(AB_FEINT_DUMMY_INDICATOR);//graphical, feeds off of symbol code,
769        list.add(AG_AUX_EQUIP_INDICATOR);//graphical, feeds off of symbol code,
770        list.add(AJ_SPEED_LEADER);//graphical
771        list.add(AL_OPERATIONAL_CONDITION);//2525C ////graphical, feeds off of symbol code, SIDC positions 4
772        list.add(AS_COUNTRY);//no need to manually enter code as the selector for the code is now implemented
773        //list.add(-1); // TODO add missing modifiers (weather, others?) so this nameless default value doesn't get added
774
775        return list;
776    }
777
778    /**
779     * Returns an Arraylist of the modifier names for units
780     * @return {@link ArrayList}
781     */
782    public static ArrayList<String> GetUnitModifierList()
783    {
784        ArrayList<String> list = new ArrayList<String>();
785
786        //list.add(ModifierType.A_SYMBOL_ICON);//graphical, feeds off of symbol code, SIDC positions 3, 5-10
787        //list.add(ModifierType.B_ECHELON);//graphical, feeds off of symbol code, SIDC positions 11-12
788        list.add(C_QUANTITY);
789        //list.add(D_TASK_FORCE_INDICATOR);//graphical, feeds off of symbol code, SIDC positions 11-12
790        //list.add(E_FRAME_SHAPE_MODIFIER);//symbol frame, feeds off of symbol code, SIDC positions 3-4
791        list.add(F_REINFORCED_REDUCED);//R = reinforced, D = reduced, RD = reinforced and reduced
792        list.add(G_STAFF_COMMENTS);
793        list.add(H_ADDITIONAL_INFO_1);
794        //list.add(H1_ADDITIONAL_INFO_2);
795        //list.add(H2_ADDITIONAL_INFO_3);
796        list.add(J_EVALUATION_RATING);
797        list.add(K_COMBAT_EFFECTIVENESS);
798        list.add(L_SIGNATURE_EQUIP);
799        list.add(M_HIGHER_FORMATION);
800        list.add(N_HOSTILE);
801        list.add(P_IFF_SIF_AIS);
802        list.add(Q_DIRECTION_OF_MOVEMENT);//number in mils
803        //list.add(R_MOBILITY_INDICATOR);//graphical, feeds off of symbol code, SIDC positions 11-12
804        list.add(R2_SIGNIT_MOBILITY_INDICATOR);
805        //list.add(S_HQ_STAFF_OR_OFFSET_INDICATOR);//graphical, feeds off of symbol code, SIDC positions 11-12
806        list.add(T_UNIQUE_DESIGNATION_1);
807        //list.add(T1_UNIQUE_DESIGNATION_2);
808        list.add(V_EQUIP_TYPE);
809        list.add(W_DTG_1);
810        list.add(W1_DTG_2);
811        list.add(X_ALTITUDE_DEPTH);
812        list.add(Y_LOCATION);
813        list.add(Z_SPEED);
814
815        list.add(AA_SPECIAL_C2_HQ);
816        //list.add(AB_FEINT_DUMMY_INDICATOR);//graphical, feeds off of symbol code, SIDC positions 11-12
817        //list.add(AC_INSTALLATION);//graphical, feeds off of symbol code, SIDC positions 11-12
818        list.add(AD_PLATFORM_TYPE);
819        list.add(AE_EQUIPMENT_TEARDOWN_TIME);
820        list.add(AF_COMMON_IDENTIFIER);
821        //list.add(AG_AUX_EQUIP_INDICATOR);//graphical
822        //list.add(AH_AREA_OF_UNCERTAINTY);//graphical and on client of renderer
823        //list.add(AI_DEAD_RECKONING_TRAILER);//graphical
824        list.add(AJ_SPEED_LEADER);
825        list.add(AK_PAIRING_LINE);
826        //list.add(AL_OPERATIONAL_CONDITION);//2525C ////graphical, feeds off of symbol code, SIDC positions 4
827        list.add(AO_ENGAGEMENT_BAR);//2525C
828        list.add(AP_TARGET_NUMBER);
829        list.add(AP1_TARGET_NUMBER_EXTENSION);
830        list.add((AQ_GUARDED_UNIT));
831        list.add((AR_SPECIAL_DESIGNATOR));
832        list.add((AS_COUNTRY));
833
834
835        return list;
836    }
837
838    /**
839     * Returns an Arraylist of the modifiers for Control Measures
840     * @return {@link ArrayList}
841     */
842    public static ArrayList<String> GetControlMeasureModifierList()
843    {
844        ArrayList<String> list = new ArrayList<String>();
845
846        //list.add(ModifierType.B_ECHELON);//graphical, feeds off of symbol code,
847        list.add(C_QUANTITY);
848        list.add(H_ADDITIONAL_INFO_1);
849        list.add(H1_ADDITIONAL_INFO_2);
850        list.add(N_HOSTILE);
851        list.add(Q_DIRECTION_OF_MOVEMENT);//number in mils
852        //list.add(S2);//graphical, up to renderer client
853        list.add(T_UNIQUE_DESIGNATION_1);
854        list.add(T1_UNIQUE_DESIGNATION_2);
855        list.add(V_EQUIP_TYPE);
856        list.add(W_DTG_1);
857        list.add(W1_DTG_2);
858        list.add(X_ALTITUDE_DEPTH);
859        list.add(Y_LOCATION);
860
861        list.add(AM_DISTANCE);
862        list.add(AN_AZIMUTH);
863        list.add(AP_TARGET_NUMBER);
864        list.add(AP1_TARGET_NUMBER_EXTENSION);
865        list.add((AS_COUNTRY));
866
867
868
869
870        return list;
871    }
872
873    /**
874     *
875     * @param modifier like Modifiers.C_QUANTITY
876     * @return modifier name based on modifier constants
877     */
878    public static String getModifierName(String modifier)
879    {
880        switch(modifier)
881        {
882            case A_SYMBOL_ICON:
883                return "Symbol Icon";
884            case B_ECHELON:
885                return "Echelon";
886            case C_QUANTITY:
887                return "Quantity";
888            case D_TASK_FORCE_INDICATOR:
889                return "Task Force Indicator";
890            case F_REINFORCED_REDUCED:
891                return "Reinforce Reduced";
892            case G_STAFF_COMMENTS:
893                return "Staff Comments";
894            case H_ADDITIONAL_INFO_1:
895                return "Additional Info 1";
896            case H1_ADDITIONAL_INFO_2:
897                return "Additional Info 2";
898            case J_EVALUATION_RATING:
899                return "Evaluation Rating";
900            case K_COMBAT_EFFECTIVENESS:
901                return "Combat Effectiveness";
902            case L_SIGNATURE_EQUIP:
903                return "Signature Equipment";
904            case M_HIGHER_FORMATION:
905                return "Higher Formation";
906            case N_HOSTILE:
907                return "Hostile";
908            case P_IFF_SIF_AIS:
909                return "IFF SIF AIS";
910            case Q_DIRECTION_OF_MOVEMENT:
911                return "Direction of Movement";
912            case R_MOBILITY_INDICATOR:
913                return "Mobility Indicator";
914            case R2_SIGNIT_MOBILITY_INDICATOR:
915                return "Signals Intelligence Mobility Indicator";
916            case S_HQ_STAFF_INDICATOR:
917                return "HQ Staff";
918            case S2_OFFSET_INDICATOR:
919                return "Offset Indicator";
920            case T_UNIQUE_DESIGNATION_1:
921                return "Unique Designation 1";
922            case T1_UNIQUE_DESIGNATION_2:
923                return "Unique Designation 2";
924            case V_EQUIP_TYPE:
925                return "Equipment Type";
926            case W_DTG_1:
927                return "Date Time Group 1";
928            case W1_DTG_2:
929                return "Date Time Group 2";
930            case X_ALTITUDE_DEPTH:
931                return "Altitude Depth";
932            case Y_LOCATION:
933                return "Location";
934            case Z_SPEED:
935                return "Speed";
936            case AA_SPECIAL_C2_HQ:
937                return "Special C2 HQ";
938            case AB_FEINT_DUMMY_INDICATOR:
939                return "Feint Dummy Indicator";
940            case AD_PLATFORM_TYPE:
941                return "Platform Type";
942            case AE_EQUIPMENT_TEARDOWN_TIME:
943                return "Equipment Teardown Time";
944            case AF_COMMON_IDENTIFIER:
945                return "Common Identifier";
946            case AG_AUX_EQUIP_INDICATOR:
947                return "Auxiliary Equipment Indicator";
948            case AH_AREA_OF_UNCERTAINTY:
949                return "Area of Uncertainty";
950            case AI_DEAD_RECKONING_TRAILER:
951                return "Dead Reckoning Trailer";
952            case AJ_SPEED_LEADER:
953                return "Speed Leader";
954            case AK_PAIRING_LINE:
955                return "Pairing Line";
956            case AL_OPERATIONAL_CONDITION:
957                return "Operational Condition";
958            case AM_DISTANCE:
959                return "Distance";
960            case AN_AZIMUTH:
961                return "Azimuth";
962            case AO_ENGAGEMENT_BAR:
963                return "Engagement Bar";//*/
964            case AP_TARGET_NUMBER:
965                return "Target Number";
966            case AP1_TARGET_NUMBER_EXTENSION:
967                return "Target Number Extension";
968            case AQ_GUARDED_UNIT:
969                return "Guarded Unit";
970            case AR_SPECIAL_DESIGNATOR:
971                return "Special Designator";
972            case AS_COUNTRY:
973                return "Country";
974            default:
975                return "";
976
977        }
978    }
979
980    /**
981     *
982     * @param modifier like Modifiers.C_QUANTITY
983     * @return modifier name based on modifier constants
984     */
985    public static String getModifierLetterCode(String modifier) {
986        switch (modifier) {
987            case A_SYMBOL_ICON:
988                return "A";
989            case B_ECHELON:
990                return "B";
991            case C_QUANTITY:
992                return "C";
993            case D_TASK_FORCE_INDICATOR:
994                return "D";
995            case F_REINFORCED_REDUCED:
996                return "F";
997            case G_STAFF_COMMENTS:
998                return "G";
999            case H_ADDITIONAL_INFO_1:
1000                return "H";
1001            case H1_ADDITIONAL_INFO_2:
1002                return "H1";
1003            case J_EVALUATION_RATING:
1004                return "J";
1005            case K_COMBAT_EFFECTIVENESS:
1006                return "K";
1007            case L_SIGNATURE_EQUIP:
1008                return "L";
1009            case M_HIGHER_FORMATION:
1010                return "M";
1011            case N_HOSTILE:
1012                return "N";
1013            case P_IFF_SIF_AIS:
1014                return "P";
1015            case Q_DIRECTION_OF_MOVEMENT:
1016                return "Q";
1017            case R_MOBILITY_INDICATOR:
1018                return "R";
1019            case R2_SIGNIT_MOBILITY_INDICATOR:
1020                return "R2";
1021            case S_HQ_STAFF_INDICATOR:
1022                return "S";
1023            case S2_OFFSET_INDICATOR:
1024                return "S2";
1025            case T_UNIQUE_DESIGNATION_1:
1026                return "T";
1027            case T1_UNIQUE_DESIGNATION_2:
1028                return "T1";
1029            case V_EQUIP_TYPE:
1030                return "V";
1031            case W_DTG_1:
1032                return "W";
1033            case W1_DTG_2:
1034                return "W1";
1035            case X_ALTITUDE_DEPTH:
1036                return "X";
1037            case Y_LOCATION:
1038                return "Y";
1039            case Z_SPEED:
1040                return "Z";
1041            case AA_SPECIAL_C2_HQ:
1042                return "AA";
1043            case AB_FEINT_DUMMY_INDICATOR:
1044                return "AB";
1045            case AD_PLATFORM_TYPE:
1046                return "AD";
1047            case AE_EQUIPMENT_TEARDOWN_TIME:
1048                return "AE";
1049            case AF_COMMON_IDENTIFIER:
1050                return "AF";
1051            case AG_AUX_EQUIP_INDICATOR:
1052                return "AG";
1053            case AH_AREA_OF_UNCERTAINTY:
1054                return "AH";
1055            case AI_DEAD_RECKONING_TRAILER:
1056                return "AI";
1057            case AJ_SPEED_LEADER:
1058                return "AJ";
1059            case AK_PAIRING_LINE:
1060                return "AK";
1061            case AL_OPERATIONAL_CONDITION:
1062                return "AL";
1063            case AM_DISTANCE:
1064                return "AM";
1065            case AN_AZIMUTH:
1066                return "AN";
1067            case AO_ENGAGEMENT_BAR:
1068                return "AO";
1069            case AP_TARGET_NUMBER:
1070                return "AP";
1071            case AP1_TARGET_NUMBER_EXTENSION:
1072                return "AP1";
1073            case AQ_GUARDED_UNIT:
1074                return "AQ";
1075            case AR_SPECIAL_DESIGNATOR:
1076                return "AR";
1077            case AS_COUNTRY:
1078                return "AS";
1079            default:
1080                return "";
1081
1082        }
1083    }
1084
1085    /**
1086     * Returns the description for a modifier constant
1087     * @param modifier {@link Modifiers}
1088     * @return {@link String}
1089     */
1090    public static String getModifierDescription(String modifier) {
1091        switch (modifier) {
1092            case A_SYMBOL_ICON:
1093                return "The innermost part of a symbol, comprised of an icon and optional modifiers, that represents a joint military object (see 5.3.4).\n" +
1094                        "Determined by SIDC positions 11-20.";
1095            case B_ECHELON:
1096                return "A graphic amplifier in a unit symbol that identifies command level (see 5.3.7.1 and table D-III).";
1097            case C_QUANTITY:
1098                return "A text amplifier in an equipment symbol that identifies the number of items present.\n" +
1099                        "Examples include: \"350 Beds\" or \"50 Gallons\"";
1100            case D_TASK_FORCE_INDICATOR:
1101                return "A graphic amplifier that identifies a unit or activities symbol as a task force (see 5.3.7.2 and figure 13).\n" +
1102                        "Determined by SIDC position 8.";
1103            case F_REINFORCED_REDUCED:
1104                return "A text modifier in a unit symbol that displays (+) for reinforced, (-) for reduced,(+) reinforced and reduced.\n" +
1105                        "R = reinforced,D = reduced, RD = reinforced and reduced";
1106            case G_STAFF_COMMENTS:
1107            case H_ADDITIONAL_INFO_1:
1108                return "A text modifier for units, equipment and installations; content is implementation specific.";
1109            case H1_ADDITIONAL_INFO_2:
1110                return "An alphanumeric text amplifier used to provide an up to a three-character letter field acronym to describe a point that is not already listed.";
1111            case J_EVALUATION_RATING:
1112                return "A text modifier for units, equipment, and installations that consists of\n "
1113                        + "a one letter reliability rating and a one-number credibility rating.\n"
1114                        + "Reliability Ratings: A-completely reliable, B-usually reliable,\n "
1115                        + "C-fairly reliable, D-not usually reliable, E-unreliable,\n "
1116                        + "F-reliability cannot be judged.\n"
1117                        + "Credibility Ratings: 1-confirmed by other sources,\n"
1118                        + "2-probably true, 3-possibly true, 4-doubtfully true,\n"
1119                        + "5-improbable, 6-truth cannot be judged.\n"
1120                        + "Example \"A1\"";
1121            case K_COMBAT_EFFECTIVENESS:
1122                return "A text modifier for units and installations that indicates unit effectiveness or installation capability." +
1123                        "FO - Fully Operational\n" +
1124                        "SO - Substantially operational\n" +
1125                        "MO - Marginally operational\n" +
1126                        "NO - Not operational\n" +
1127                        "UNK - Unknown";
1128            case L_SIGNATURE_EQUIP:
1129                return "A text modifier for hostile equipment; \"!\" indicates detectable electronic signatures.";
1130            case M_HIGHER_FORMATION:
1131                return "An amplifier for units that indicates number or title of higher echelon command (corps are designated by Roman numerals).";
1132            case N_HOSTILE:
1133                return "An amplifier for equipment; letters \"ENY\" denote hostile symbols." +
1134                        "Determined by SIDC position 4.";
1135            case P_IFF_SIF_AIS:
1136                return "An amplifier displaying IFF/SIF/AIS Identification modes and codes." +
1137                        "Alphanumeric - {4,4}\n" +
1138                        "MODE 1:##, where ## is a two-digit octal number (0-7). The rightmost digit is limited to 0-3.\n" +
1139                        "[1:##]\n" +
1140                        "Note: ‘MODE' is not required when displaying.\n" +
1141                        "Alphanumeric - {6,6}\n" +
1142                        "MODE 2:####, where #### is a four-digit octal number (0-7).\n" +
1143                        "[2:####]\n" +
1144                        "Alphanumeric - {6,6}\n" +
1145                        "MODE 3:####, where #### is a four-digit octal number (0-7).\n" +
1146                        "[3:####]\n" +
1147                        "Alphanumeric - {6,6}\n" +
1148                        "MODE 5:####, where #### is a 4-digit hexadecimal number (0-F). The leftmost digit is limited from 0 to 3.\n" +
1149                        "[5:####]\n" +
1150                        "Alphanumeric - {8,8}\n" +
1151                        "MODE S:XXXXXX\n" +
1152                        "[S:XXXXXX]\n" +
1153                        "Alphanumeric - {x,x}\n" +
1154                        "AIS IMO:XXXXXX";
1155            case Q_DIRECTION_OF_MOVEMENT:
1156                return "An amplifier consisting of a line with arrow that identifies the direction of movement or intended movement of an object (see 5.3.7.9 and figure 14).\n";
1157            case R_MOBILITY_INDICATOR:
1158                return "An amplifier that depicts the mobility of an object not intrinsic to the entity itself (see 5.3.7.9, figure 14 and table IX).\n" +
1159                        "Determined by SIDC positions 9-10";
1160            case R2_SIGNIT_MOBILITY_INDICATOR:
1161                return "An amplifier that indicates the mobility of a SIGINT unit." +
1162                        "List of Values:\n" +
1163                        "M = Mobile,\n" +
1164                        "S = Static\n" +
1165                        "U = Uncertain.";
1166            case S_HQ_STAFF_INDICATOR:
1167                return "An amplifier for units, installations and activities that identifies them as a headquarters (see figure 14 and figure 13).\n" +
1168                        "Determined by SIDC position 8.";
1169            case S2_OFFSET_INDICATOR:
1170                return "An amplifier used to indicate the offset or precise location of a single point symbol (see 5.3.7.5, 5.3.12, and figure 14).";
1171            case T_UNIQUE_DESIGNATION_1:
1172                return "An amplifier that uniquely identifies a particular symbol or track number. Identifies acquisitions number when used with SIGINT symbology.";
1173            case T1_UNIQUE_DESIGNATION_2:
1174                return "Lines - Second unique identifier for boundaries.\n" +
1175                        "Lines - Other than phase lines that have a specific purpose, (for example, restrictive fire line RFL),\n " +
1176                        "   should have the primary purpose labelled on top of the line at both ends of the line inside the\n " +
1177                        "   lateral boundaries or as often as necessary for clarity.\n" +
1178                        "Points - Provides the unit servicing the point";
1179            case V_EQUIP_TYPE:
1180                return "An amplifier for equipment that indicates types of equipment.\n" +
1181                        "Example: " +
1182                        "AH-64 for Attack Helicopter";
1183            case W_DTG_1:
1184            case W1_DTG_2:
1185                return "An amplifier for displaying a date-time group (DDHHMMSSZMONYYYY) or (DDHHMMZMMMYYYY) or \"O/O\" for On Order.\n" +
1186                        "Field \"W\" is used to provide DTG or if used with field \"W1\" the start of a period of time.\n" +
1187                        "Field \"W1\" is used to provide the end of a period of time.\n" +
1188                        "The date-time group is composed of a group of six numeric digits with a time zone suffix and the standardized three-letter abbreviation for the month followed by four digits representing the year.\n" +
1189                        "The first pair of digits represents the day; the second pair, the hour; the third pair, the minutes. For automated systems, two digits may be added before the time zone suffix and after the minutes to designate seconds (see 5.3.7.8).";
1190            case X_ALTITUDE_DEPTH:
1191                return "An amplifier that displays either altitude, flight level, depth for submerged objects or height of equipment or structures on the ground, the minimum, maximum and/or specific altitude (in feet or meters in relation to a reference datum) or depth (for submerged objects in feet below sea level). See 5.3.7.6 for content.";
1192            case Y_LOCATION:
1193                return "An amplifier that displays a symbol's location in degrees, minutes and decimal minutes (or in MGRS, GARS, or other applicable display formats).";
1194            case Z_SPEED:
1195                return "An amplifier that displays velocity (see 5.3.7.7).";
1196            case AA_SPECIAL_C2_HQ:
1197                return "A amplifier that is contained inside the frame in place of the main icon and contains the name of the special C2 Headquarters.";
1198            case AB_FEINT_DUMMY_INDICATOR:
1199                return "An amplifier that identifies an offensive or defensive unit, intended to draw the enemy's attention away from the area of the main attack.\n" +
1200                        "Determined by SIDC position 8.";
1201            case AD_PLATFORM_TYPE:
1202                return "Electronic intelligence notation (ELNOT) or communications intelligence notation (CENOT)";
1203            case AE_EQUIPMENT_TEARDOWN_TIME:
1204                return "Equipment teardown time in minutes.";
1205            case AF_COMMON_IDENTIFIER:
1206                return "Example: \"Hawk\" for Hawk SAM system.";
1207            case AG_AUX_EQUIP_INDICATOR:
1208                return "Towed sonar array indicator: A graphic modifier for equipment that indicates the presence of a towed sonar array (see 5.3.7.10, figure 13 and table IX).\n" +
1209                        "Determined by SIDC positions 9-10";
1210            case AH_AREA_OF_UNCERTAINTY:
1211                return "A graphic modifier for units, equipment and installations that indicates the area where an object is most likely to be, based on the object's last report and the reporting accuracy of the sensor that detected the object (see 5.3.7.12.1 and table D-III).";
1212            case AI_DEAD_RECKONING_TRAILER:
1213                return "A graphic amplifier for units and equipment that identifies where an object should be located at present, given its last reported course and speed (see 5.3.7.12.2).";
1214            case AJ_SPEED_LEADER:
1215                return "A graphic amplifier for units, equipment and installations that depicts the speed and direction of movement of an object (see 5.3.7.12.3 and figure 17).";
1216            case AK_PAIRING_LINE:
1217                return "A graphic amplifier for units, equipment and installations that connects two objects and is updated dynamically as the positions of the two objects change (see 5.3.7.12.4 and figure 17).";
1218            case AL_OPERATIONAL_CONDITION:
1219                return "A graphic amplifier for equipment or installations that indicates operational condition or capacity.";
1220            case AM_DISTANCE:
1221                return "An amplifier that displays a minimum, maximum, or a specific distance (range, radius, width, length, etc.), in meters.";
1222            case AN_AZIMUTH:
1223                return "An amplifier that displays an angle measured from true north to any other line in degrees.";
1224            case AO_ENGAGEMENT_BAR:
1225                return "An amplifier placed immediately atop the symbol.\n" +
1226                        "May denote: 1) local/remote status 2) engagement status 3) weapon type.";
1227            case AP_TARGET_NUMBER:
1228                return "An amplifier used in Fire Support operations to uniquely designate targets in accordance with STANAG 2934.";
1229            case AP1_TARGET_NUMBER_EXTENSION:
1230                return "An amplifier used to identify a target number extension which is a sequentially assigned number identifying the individual elements in a target (MIL-STD-6017),";
1231            case AQ_GUARDED_UNIT:
1232                return "An amplifier used during ballistic missile defense. Some tracks are designated as guarded by a particular unit.";
1233            case AR_SPECIAL_DESIGNATOR:
1234                return "An amplifier that identifies special track designators.";
1235            case AS_COUNTRY:
1236                return "A three-letter code that indicates the country of origin of the organization (US systems shall use GENC).";
1237            default:
1238                return "";
1239
1240        }
1241    }
1242
1243    /**
1244     * go from "T" or "T1" to integer constant values 9 and 10
1245     * @param modLetter {@link String}
1246     * @return {@link Modifiers}
1247     */
1248    public static String getModifierKey(String modLetter) {
1249        switch (modLetter) {
1250            case "A":
1251                return A_SYMBOL_ICON;
1252            case "B":
1253                return B_ECHELON;
1254            case "C":
1255                return C_QUANTITY;
1256            case "D":
1257                return D_TASK_FORCE_INDICATOR;
1258            case "F":
1259                return F_REINFORCED_REDUCED;
1260            case "G":
1261                return G_STAFF_COMMENTS;
1262            case "H":
1263                return H_ADDITIONAL_INFO_1;
1264            case "H1":
1265                return H1_ADDITIONAL_INFO_2;
1266            case "J":
1267                return J_EVALUATION_RATING;
1268            case "K":
1269                return K_COMBAT_EFFECTIVENESS;
1270            case "L":
1271                return L_SIGNATURE_EQUIP;
1272            case "M":
1273                return M_HIGHER_FORMATION;
1274            case "N":
1275                return N_HOSTILE;
1276            case "P":
1277                return P_IFF_SIF_AIS;
1278            case "Q":
1279                return Q_DIRECTION_OF_MOVEMENT;
1280            case "R":
1281                return R_MOBILITY_INDICATOR;
1282            case "R2":
1283                return R2_SIGNIT_MOBILITY_INDICATOR;
1284            case "S":
1285                return S_HQ_STAFF_INDICATOR;
1286            case "S2":
1287                return S2_OFFSET_INDICATOR;
1288            case "T":
1289                return T_UNIQUE_DESIGNATION_1;
1290            case "T1":
1291                return T1_UNIQUE_DESIGNATION_2;
1292            case "V":
1293                return V_EQUIP_TYPE;
1294            case "W":
1295                return W_DTG_1;
1296            case "W1":
1297                return W1_DTG_2;
1298            case "X":
1299                return X_ALTITUDE_DEPTH;
1300            case "Y":
1301                return Y_LOCATION;
1302            case "Z":
1303                return Z_SPEED;
1304            case "AA":
1305                return AA_SPECIAL_C2_HQ;
1306            case "AB":
1307                return AB_FEINT_DUMMY_INDICATOR;
1308            case "AD":
1309                return AD_PLATFORM_TYPE;
1310            case "AE":
1311                return AE_EQUIPMENT_TEARDOWN_TIME;
1312            case "AF":
1313                return AF_COMMON_IDENTIFIER;
1314            case "AG":
1315                return AG_AUX_EQUIP_INDICATOR;
1316            case "AH":
1317                return AH_AREA_OF_UNCERTAINTY;
1318            case "AI":
1319                return AI_DEAD_RECKONING_TRAILER;
1320            case "AJ":
1321                return AJ_SPEED_LEADER;
1322            case "AK":
1323                return AK_PAIRING_LINE;
1324            case "AL":
1325                return AL_OPERATIONAL_CONDITION;
1326            case "AM":
1327                return AM_DISTANCE;
1328            case "AN":
1329                return AN_AZIMUTH;
1330            case "AO":
1331                return AO_ENGAGEMENT_BAR;
1332            case "AP":
1333                return AP_TARGET_NUMBER;
1334            case "AP1":
1335                return AP1_TARGET_NUMBER_EXTENSION;
1336            case "AQ":
1337                return AQ_GUARDED_UNIT;
1338            case "AR":
1339                return AR_SPECIAL_DESIGNATOR;
1340            case "AS":
1341                return AS_COUNTRY;
1342            default:
1343                return null;
1344
1345        }
1346    }
1347}
1348