aixm 1.2.1 → 1.3.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- checksums.yaml.gz.sig +0 -0
- data/CHANGELOG.md +23 -3
- data/README.md +37 -2
- data/exe/ckmid +1 -7
- data/exe/mkmid +1 -7
- data/lib/aixm/classes.rb +3 -1
- data/lib/aixm/component/address.rb +12 -15
- data/lib/aixm/component/approach_lighting.rb +11 -16
- data/lib/aixm/component/fato.rb +22 -34
- data/lib/aixm/component/frequency.rb +10 -15
- data/lib/aixm/component/geometry/arc.rb +2 -3
- data/lib/aixm/component/geometry/border.rb +6 -10
- data/lib/aixm/component/geometry/circle.rb +4 -4
- data/lib/aixm/component/geometry/point.rb +4 -4
- data/lib/aixm/component/geometry/rhumb_line.rb +4 -4
- data/lib/aixm/component/geometry.rb +4 -4
- data/lib/aixm/component/helipad.rb +13 -20
- data/lib/aixm/component/layer.rb +6 -8
- data/lib/aixm/component/lighting.rb +12 -17
- data/lib/aixm/component/runway.rb +26 -38
- data/lib/aixm/component/service.rb +12 -16
- data/lib/aixm/component/surface.rb +8 -10
- data/lib/aixm/component/timesheet.rb +9 -10
- data/lib/aixm/component/timetable.rb +6 -7
- data/lib/aixm/component/vasis.rb +6 -8
- data/lib/aixm/component/vertical_limit.rb +8 -8
- data/lib/aixm/component.rb +3 -2
- data/lib/aixm/concerns/association.rb +381 -0
- data/lib/aixm/concerns/memoize.rb +107 -0
- data/lib/aixm/concerns/xml_builder.rb +34 -0
- data/lib/aixm/document.rb +52 -21
- data/lib/aixm/feature/airport.rb +44 -47
- data/lib/aixm/feature/airspace.rb +29 -34
- data/lib/aixm/feature/generic.rb +67 -0
- data/lib/aixm/feature/navigational_aid/designated_point.rb +11 -13
- data/lib/aixm/feature/navigational_aid/dme.rb +12 -15
- data/lib/aixm/feature/navigational_aid/marker.rb +12 -15
- data/lib/aixm/feature/navigational_aid/ndb.rb +13 -16
- data/lib/aixm/feature/navigational_aid/tacan.rb +15 -17
- data/lib/aixm/feature/navigational_aid/vor.rb +16 -19
- data/lib/aixm/feature/navigational_aid.rb +7 -7
- data/lib/aixm/feature/obstacle.rb +20 -21
- data/lib/aixm/feature/obstacle_group.rb +19 -20
- data/lib/aixm/feature/organisation.rb +11 -12
- data/lib/aixm/feature/unit.rb +16 -18
- data/lib/aixm/feature.rb +26 -7
- data/lib/aixm/object.rb +1 -1
- data/lib/aixm/refinements.rb +57 -0
- data/lib/aixm/schedule/date.rb +13 -1
- data/lib/aixm/schedule/date_time.rb +56 -0
- data/lib/aixm/schedule/time.rb +5 -1
- data/lib/aixm/shortcuts.rb +8 -2
- data/lib/aixm/version.rb +1 -1
- data/lib/aixm.rb +5 -3
- data/schemas/ofmx/0.1/OFMX-Snapshot.xsd +6 -1
- data.tar.gz.sig +2 -3
- metadata +26 -38
- metadata.gz.sig +2 -3
- data/lib/aixm/association.rb +0 -378
- data/lib/aixm/memoize.rb +0 -105
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: c4dd1d553f6bf8c1f704cd521b14f26e89dc1161d065b82fd867fde1a556d97e
|
4
|
+
data.tar.gz: 9fcba185054638267827d2e7a5eec09e849d237738455ec1bd9bb1cbabbabf5f
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 0ab5bd974c993d0813e550c129040c6fac9f2d31f787f428e3582aef9486d1a2e95983dca76c822be9b621c97fe87c0263d571e92a485b0a3f9b2af76a7a6d0b
|
7
|
+
data.tar.gz: 2969d03eb3bf308ad19fd481c1ca5244525848a5802eea3b9d4a999bb3feeb826ef483dbfdec23b567a2e326a3704fe1c45a61a74825cd0483bc4bfb2c7e9b97
|
checksums.yaml.gz.sig
CHANGED
Binary file
|
data/CHANGELOG.md
CHANGED
@@ -2,6 +2,26 @@
|
|
2
2
|
|
3
3
|
Nothing so far
|
4
4
|
|
5
|
+
## 1.3.1
|
6
|
+
|
7
|
+
#### Changes
|
8
|
+
* Update certificate
|
9
|
+
|
10
|
+
## 1.3.0
|
11
|
+
|
12
|
+
#### Breaking Changes
|
13
|
+
* `Document#created_at` no longer falls back to `Document#effective_at`
|
14
|
+
* Renamed `AIXM::Date#succ` to `AIXM::Date#next`
|
15
|
+
|
16
|
+
#### Additions
|
17
|
+
* Refinement to pretty print Nokogiri XML documents
|
18
|
+
* XML comments on features (e.g. to include raw NOTAM)
|
19
|
+
* `Document#expiration_at` for OFMX
|
20
|
+
* Generic features as raw XML (e.g. extracted from another AIXM/OFMX file)
|
21
|
+
* Convenience combinator `AIXM::Schedule::DateTime`
|
22
|
+
* Shortcuts `AIXM::BEGINNING_OF_DAY` and `AIXM::END_OF_DAY`
|
23
|
+
* `AIXM::Date#next` and `AIXM::Date#-`
|
24
|
+
|
5
25
|
## 1.2.1
|
6
26
|
|
7
27
|
#### Additions
|
@@ -20,7 +40,7 @@ Nothing so far
|
|
20
40
|
## 1.1.0
|
21
41
|
|
22
42
|
#### Breaking Changes
|
23
|
-
* `AIXM::Association:Array#duplicates` now returns an array of arrays which
|
43
|
+
* `AIXM::Concerns::Association:Array#duplicates` now returns an array of arrays which
|
24
44
|
group all duplicates together.
|
25
45
|
* `VOR#associate_dme` and `VOR#associate_tacan` no longer take the channel
|
26
46
|
as argument but calculate it from the (ghost) frequency of the VOR.
|
@@ -74,10 +94,10 @@ Nothing so far
|
|
74
94
|
|
75
95
|
#### Additions
|
76
96
|
* Proper `has_many` and `has_one` associations
|
77
|
-
* `AIXM::Association:Array#find_by|find|duplicates` on `has_many` associations
|
97
|
+
* `AIXM::Concerns::Association:Array#find_by|find|duplicates` on `has_many` associations
|
78
98
|
* `AIXM.config.mid` now defines whether `mid` attributes are inserted or not
|
79
99
|
provided the selected schema is OFMX
|
80
|
-
* `AIXM::Memoize` module
|
100
|
+
* `AIXM::Concerns::Memoize` module
|
81
101
|
* `AIXM::PayloadHash` class
|
82
102
|
* `mkmid` executable to insert `mid` attributes into valid OFMX file
|
83
103
|
* `ckmid` executable to check `mid` attributes in an OFMX file
|
data/README.md
CHANGED
@@ -28,7 +28,7 @@ gem cert --add <(curl -Ls https://raw.github.com/svoop/aixm/main/certs/svoop.pem
|
|
28
28
|
Add the following to the <tt>Gemfile</tt> or <tt>gems.rb</tt> of your [Bundler](https://bundler.io) powered Ruby project:
|
29
29
|
|
30
30
|
```ruby
|
31
|
-
gem aixm
|
31
|
+
gem 'aixm'
|
32
32
|
```
|
33
33
|
|
34
34
|
And then install the bundle:
|
@@ -163,6 +163,7 @@ AIXM.config.ignored_errors = /invalid date/i
|
|
163
163
|
* [Organisation](https://www.rubydoc.info/gems/aixm/AIXM/Feature/Organisation.html)
|
164
164
|
* [Service](https://www.rubydoc.info/gems/aixm/AIXM/Component/Service.html)
|
165
165
|
* [Unit](https://www.rubydoc.info/gems/aixm/AIXM/Feature/Unit.html)
|
166
|
+
* [Generic](https://www.rubydoc.info/gems/aixm/AIXM/Feature/Generic.html)
|
166
167
|
|
167
168
|
### Components
|
168
169
|
|
@@ -186,11 +187,18 @@ AIXM.config.ignored_errors = /invalid date/i
|
|
186
187
|
* [VASIS](https://www.rubydoc.info/gems/aixm/AIXM/Component/VASIS.html)
|
187
188
|
* [Vertical limit](https://www.rubydoc.info/gems/aixm/AIXM/Component/VerticalLimit.html)
|
188
189
|
|
190
|
+
### Schedule
|
191
|
+
|
192
|
+
* [Date](https://www.rubydoc.info/gems/aixm/AIXM/Schedule/Date.html)
|
193
|
+
* [Day](https://www.rubydoc.info/gems/aixm/AIXM/Schedule/Day.html)
|
194
|
+
* [Time](https://www.rubydoc.info/gems/aixm/AIXM/Schedule/Time.html)
|
195
|
+
* [DateTime](https://www.rubydoc.info/gems/aixm/AIXM/Schedule/DateTime.html)
|
196
|
+
|
189
197
|
## Associations
|
190
198
|
|
191
199
|
The different models are interwoven with [`has_many` and `has_one` associations](https://www.rubydoc.info/gems/aixm/AIXM/Association).
|
192
200
|
|
193
|
-
Please note that `has_many` associations are instances `AIXM::Association::Array` which mostly behave like normal arrays. However, you must not add or remove elements on the array directly but use the corresponding method on the associating model instead:
|
201
|
+
Please note that `has_many` associations are instances `AIXM::Concerns::Association::Array` which mostly behave like normal arrays. However, you must not add or remove elements on the array directly but use the corresponding method on the associating model instead:
|
194
202
|
|
195
203
|
```ruby
|
196
204
|
document.features << airport # => NoMethodError
|
@@ -230,6 +238,33 @@ Equally on `has_many` associations, use `duplicates` to find identical or equal
|
|
230
238
|
document.features.duplicates # => [#<AIXM::Feature::Unit>, #<AIXM::Component::Service>, ...]
|
231
239
|
```
|
232
240
|
|
241
|
+
## XML Comments
|
242
|
+
|
243
|
+
All features implement the `comment` attribute which accepts any object and converts it `#to_s`. When set, an XML comment is inserted right after the opening tag of the feature. This comes in handy e.g. in case you want to include source data facsimile such as NOTAM. Oneline and multiline comments are inserted differently:
|
244
|
+
|
245
|
+
```xml
|
246
|
+
<Ase>
|
247
|
+
<!--
|
248
|
+
B0330/22 NOTAMR B1756/21
|
249
|
+
Q) LSAS/QAFLT/V/NBO/E/000/050/4734N00841E005
|
250
|
+
A) LSAS B) 2203170746 C) 2206242359 EST
|
251
|
+
-->
|
252
|
+
<AseUid>
|
253
|
+
<codeType>RAS</codeType>
|
254
|
+
<codeId>B0330/22</codeId>
|
255
|
+
</AseUid>
|
256
|
+
(...)
|
257
|
+
</Ase>
|
258
|
+
|
259
|
+
<Org>
|
260
|
+
<!-- Generic organisation -->
|
261
|
+
<OrgUid>
|
262
|
+
<txtName>FRANCE</txtName>
|
263
|
+
</OrgUid>
|
264
|
+
(...)
|
265
|
+
</Org>
|
266
|
+
```
|
267
|
+
|
233
268
|
## Payload Hash
|
234
269
|
|
235
270
|
OFMX defines a [payload hash function](https://gitlab.com/openflightmaps/ofmx/wikis/Functions) used to facilitate association and modification tracking. It is used internally, but you can also use it in your own code:
|
data/exe/ckmid
CHANGED
data/exe/mkmid
CHANGED
data/lib/aixm/classes.rb
CHANGED
@@ -14,6 +14,7 @@ module AIXM
|
|
14
14
|
date: 'AIXM::Schedule::Date',
|
15
15
|
day: 'AIXM::Schedule::Day',
|
16
16
|
time: 'AIXM::Schedule::Time',
|
17
|
+
datetime: 'AIXM::Schedule::DateTime',
|
17
18
|
address: 'AIXM::Component::Address',
|
18
19
|
approach_lighting: 'AIXM::Component::ApproachLighting',
|
19
20
|
organisation: 'AIXM::Feature::Organisation',
|
@@ -45,7 +46,8 @@ module AIXM
|
|
45
46
|
obstacle_group: 'AIXM::Feature::ObstacleGroup',
|
46
47
|
timetable: 'AIXM::Component::Timetable',
|
47
48
|
timesheet: 'AIXM::Component::Timesheet',
|
48
|
-
vasis: 'AIXM::Component::VASIS'
|
49
|
+
vasis: 'AIXM::Component::VASIS',
|
50
|
+
generic: 'AIXM::Feature::Generic'
|
49
51
|
}.freeze
|
50
52
|
|
51
53
|
end
|
@@ -14,8 +14,7 @@ module AIXM
|
|
14
14
|
#
|
15
15
|
# @see https://gitlab.com/openflightmaps/ofmx/wikis/Airport#aha-airport-address
|
16
16
|
class Address < Component
|
17
|
-
include AIXM::Association
|
18
|
-
include AIXM::Memoize
|
17
|
+
include AIXM::Concerns::Association
|
19
18
|
include AIXM::Concerns::Remarks
|
20
19
|
|
21
20
|
public_class_method :new
|
@@ -82,26 +81,24 @@ module AIXM
|
|
82
81
|
end
|
83
82
|
end
|
84
83
|
|
85
|
-
#
|
86
|
-
def
|
87
|
-
builder
|
88
|
-
|
89
|
-
tag << addressable.to_uid.indent(2) if addressable
|
84
|
+
# @!visibility private
|
85
|
+
def add_uid_to(builder, as:, sequence:)
|
86
|
+
builder.send(as) do |tag|
|
87
|
+
addressable.add_uid_to(tag) if addressable
|
90
88
|
tag.codeType(TYPES.key(type).to_s.then_if(AIXM.aixm?) { _1.sub(/-\w+$/, '') })
|
91
89
|
tag.noSeq(sequence)
|
92
90
|
end
|
93
91
|
end
|
94
|
-
memoize :to_uid
|
95
92
|
|
96
|
-
#
|
97
|
-
def
|
98
|
-
builder
|
99
|
-
builder.
|
100
|
-
builder.
|
101
|
-
tag
|
93
|
+
# @!visibility private
|
94
|
+
def add_to(builder, as:, sequence:)
|
95
|
+
builder.comment ["Address: #{TYPES.key(type)}", addressable&.id].compact.join(' for ').dress
|
96
|
+
builder.text "\n"
|
97
|
+
builder.send(as) do |tag|
|
98
|
+
add_uid_to(tag, as: :"#{as}Uid", sequence: sequence)
|
102
99
|
case type
|
103
100
|
when :radio_frequency
|
104
|
-
tag.txtAddress(address.freq
|
101
|
+
tag.txtAddress(address.freq)
|
105
102
|
else
|
106
103
|
tag.txtAddress(address)
|
107
104
|
end
|
@@ -17,8 +17,7 @@ module AIXM
|
|
17
17
|
#
|
18
18
|
# @see https://gitlab.com/openflightmaps/ofmx/wikis/Airport#rda-runway-direction-approach-lighting
|
19
19
|
class ApproachLighting < Component
|
20
|
-
include AIXM::Association
|
21
|
-
include AIXM::Memoize
|
20
|
+
include AIXM::Concerns::Association
|
22
21
|
include AIXM::Concerns::Intensity
|
23
22
|
include AIXM::Concerns::Remarks
|
24
23
|
|
@@ -108,31 +107,27 @@ module AIXM
|
|
108
107
|
@flash_description = value&.to_s
|
109
108
|
end
|
110
109
|
|
111
|
-
#
|
112
|
-
def
|
113
|
-
builder
|
114
|
-
|
115
|
-
tag
|
116
|
-
tag.codeType(TYPES.key(type).to_s)
|
110
|
+
# @!visibility private
|
111
|
+
def add_uid_to(builder, as:)
|
112
|
+
builder.send(as) do |tag|
|
113
|
+
approach_lightable.add_uid_to(tag)
|
114
|
+
tag.codeType(TYPES.key(type))
|
117
115
|
end
|
118
116
|
end
|
119
|
-
memoize :to_uid
|
120
117
|
|
121
|
-
#
|
122
|
-
def
|
123
|
-
builder
|
124
|
-
|
125
|
-
tag << to_uid(as: "#{as}Uid").indent(2)
|
118
|
+
# @!visibility private
|
119
|
+
def add_to(builder, as:)
|
120
|
+
builder.send(as) do |tag|
|
121
|
+
add_uid_to(tag, as: "#{as}Uid")
|
126
122
|
if length
|
127
123
|
tag.valLen(length.dim.round)
|
128
124
|
tag.uomLen(length.unit.to_s.upcase)
|
129
125
|
end
|
130
|
-
tag.codeIntst(INTENSITIES.key(intensity)
|
126
|
+
tag.codeIntst(INTENSITIES.key(intensity)) if intensity
|
131
127
|
tag.codeSequencedFlash(sequenced_flash ? 'Y' : 'N') unless sequenced_flash.nil?
|
132
128
|
tag.txtDescrFlash(flash_description) if flash_description
|
133
129
|
tag.txtRmk(remarks) if remarks
|
134
130
|
end
|
135
|
-
builder.target!
|
136
131
|
end
|
137
132
|
end
|
138
133
|
end
|
data/lib/aixm/component/fato.rb
CHANGED
@@ -28,8 +28,7 @@ module AIXM
|
|
28
28
|
#
|
29
29
|
# @see https://gitlab.com/openflightmaps/ofmx/wikis/Airport#fto-fato
|
30
30
|
class FATO < Component
|
31
|
-
include AIXM::Association
|
32
|
-
include AIXM::Memoize
|
31
|
+
include AIXM::Concerns::Association
|
33
32
|
include AIXM::Concerns::Marking
|
34
33
|
include AIXM::Concerns::Remarks
|
35
34
|
|
@@ -128,46 +127,41 @@ module AIXM
|
|
128
127
|
@status = value.nil? ? nil : (STATUSES.lookup(value.to_s.to_sym, nil) || fail(ArgumentError, "invalid status"))
|
129
128
|
end
|
130
129
|
|
131
|
-
#
|
132
|
-
def
|
133
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
130
|
+
# @!visibility private
|
131
|
+
def add_uid_to(builder)
|
134
132
|
builder.FtoUid do |fto_uid|
|
135
|
-
|
133
|
+
airport.add_uid_to(fto_uid)
|
136
134
|
fto_uid.txtDesig(name)
|
137
135
|
end
|
138
136
|
end
|
139
|
-
memoize :to_uid
|
140
137
|
|
141
|
-
#
|
142
|
-
def
|
143
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
138
|
+
# @!visibility private
|
139
|
+
def add_to(builder)
|
144
140
|
builder.Fto do |fto|
|
145
|
-
fto
|
141
|
+
add_uid_to(fto)
|
146
142
|
if dimensions
|
147
143
|
fto.valLen(dimensions.length.to_m.dim.trim)
|
148
144
|
fto.valWid(dimensions.width.to_m.dim.trim)
|
149
145
|
fto.uomDim('M')
|
150
146
|
end
|
151
|
-
|
152
|
-
fto << xml.indent(2)
|
153
|
-
end
|
147
|
+
surface.add_to(fto) if surface
|
154
148
|
fto.txtProfile(profile) if profile
|
155
149
|
fto.txtMarking(marking) if marking
|
156
|
-
fto.codeSts(STATUSES.key(status)
|
150
|
+
fto.codeSts(STATUSES.key(status)) if status
|
157
151
|
fto.txtRmk(remarks) if remarks
|
158
152
|
end
|
159
153
|
directions.each do |direction|
|
160
|
-
|
154
|
+
direction.add_to(builder)
|
161
155
|
end
|
162
|
-
builder.target!
|
163
156
|
end
|
164
157
|
|
165
158
|
# FATO directions further describe each direction to and from the FATO.
|
166
159
|
#
|
167
160
|
# @see https://gitlab.com/openflightmaps/ofmx/wikis/Airport#fdn-fato-direction
|
168
161
|
class Direction
|
169
|
-
include AIXM::Association
|
170
|
-
include AIXM::Memoize
|
162
|
+
include AIXM::Concerns::Association
|
163
|
+
include AIXM::Concerns::Memoize
|
164
|
+
include AIXM::Concerns::XMLBuilder
|
171
165
|
include AIXM::Concerns::Remarks
|
172
166
|
|
173
167
|
# @!method lightings
|
@@ -239,35 +233,29 @@ module AIXM
|
|
239
233
|
@vasis = value
|
240
234
|
end
|
241
235
|
|
242
|
-
#
|
243
|
-
def
|
244
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
236
|
+
# @!visibility private
|
237
|
+
def add_uid_to(builder)
|
245
238
|
builder.FdnUid do |fdn_uid|
|
246
|
-
|
239
|
+
fato.add_uid_to(fdn_uid)
|
247
240
|
fdn_uid.txtDesig(name.to_s(:runway))
|
248
241
|
end
|
249
242
|
end
|
250
|
-
memoize :to_uid
|
251
243
|
|
252
|
-
#
|
253
|
-
def
|
254
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
244
|
+
# @!visibility private
|
245
|
+
def add_to(builder)
|
255
246
|
builder.Fdn do |fdn|
|
256
|
-
fdn
|
247
|
+
add_uid_to(fdn)
|
257
248
|
fdn.valTrueBrg(geographic_bearing.to_s(:bearing)) if geographic_bearing
|
258
249
|
fdn.valMagBrg(magnetic_bearing.to_s(:bearing)) if magnetic_bearing
|
259
|
-
if vasis
|
260
|
-
fdn << vasis.to_xml.indent(2)
|
261
|
-
end
|
250
|
+
vasis.add_to(fdn) if vasis
|
262
251
|
fdn.txtRmk(remarks) if remarks
|
263
252
|
end
|
264
253
|
lightings.each do |lighting|
|
265
|
-
|
254
|
+
lighting.add_to(builder, as: :Fls)
|
266
255
|
end
|
267
256
|
approach_lightings.each do |approach_lighting|
|
268
|
-
|
257
|
+
approach_lighting.add_to(builder, as: :Fda)
|
269
258
|
end
|
270
|
-
builder.target!
|
271
259
|
end
|
272
260
|
end
|
273
261
|
end
|
@@ -22,8 +22,7 @@ module AIXM
|
|
22
22
|
#
|
23
23
|
# @see https://gitlab.com/openflightmaps/ofmx/wikis/Organisation#fqy-frequency
|
24
24
|
class Frequency < Component
|
25
|
-
include AIXM::Association
|
26
|
-
include AIXM::Memoize
|
25
|
+
include AIXM::Concerns::Association
|
27
26
|
include AIXM::Concerns::Timetable
|
28
27
|
include AIXM::Concerns::Remarks
|
29
28
|
|
@@ -112,32 +111,28 @@ module AIXM
|
|
112
111
|
@type = value.nil? ? nil : TYPES.lookup(value.to_s.to_sym, nil) || fail(ArgumentError, "invalid type")
|
113
112
|
end
|
114
113
|
|
115
|
-
#
|
116
|
-
def
|
117
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
114
|
+
# @!visibility private
|
115
|
+
def add_uid_to(builder)
|
118
116
|
builder.FqyUid do |fqy_uid|
|
119
|
-
|
117
|
+
service.add_uid_to(fqy_uid)
|
120
118
|
fqy_uid.valFreqTrans(transmission_f.freq)
|
121
119
|
end
|
122
120
|
end
|
123
|
-
memoize :to_uid
|
124
121
|
|
125
|
-
#
|
126
|
-
def
|
127
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
122
|
+
# @!visibility private
|
123
|
+
def add_to(builder)
|
128
124
|
builder.Fqy do |fqy|
|
129
|
-
fqy
|
125
|
+
add_uid_to(fqy)
|
130
126
|
fqy.valFreqRec(reception_f.freq) if reception_f
|
131
|
-
fqy.uomFreq(transmission_f.unit.upcase
|
132
|
-
|
127
|
+
fqy.uomFreq(transmission_f.unit.upcase)
|
128
|
+
timetable.add_to(fqy, as: :Ftt) if timetable
|
133
129
|
fqy.txtRmk(remarks) if remarks
|
134
130
|
callsigns.each do |language, callsign|
|
135
131
|
fqy.Cdl do |cdl|
|
136
132
|
cdl.txtCallSign(callsign)
|
137
|
-
cdl.codeLang(language.upcase
|
133
|
+
cdl.codeLang(language.upcase)
|
138
134
|
end
|
139
135
|
end
|
140
|
-
fqy.target!
|
141
136
|
end
|
142
137
|
end
|
143
138
|
end
|
@@ -58,9 +58,8 @@ module AIXM
|
|
58
58
|
@clockwise = value
|
59
59
|
end
|
60
60
|
|
61
|
-
#
|
62
|
-
def
|
63
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
61
|
+
# @!visibility private
|
62
|
+
def add_to(builder)
|
64
63
|
builder.Avx do |avx|
|
65
64
|
avx.codeType(clockwise? ? 'CWA' : 'CCA')
|
66
65
|
avx.geoLat(xy.lat(AIXM.schema))
|
@@ -15,7 +15,6 @@ module AIXM
|
|
15
15
|
#
|
16
16
|
# @see https://gitlab.com/openflightmaps/ofmx/wikis/Airspace#frontier
|
17
17
|
class Border < Point
|
18
|
-
include AIXM::Memoize
|
19
18
|
|
20
19
|
# Name of the border
|
21
20
|
#
|
@@ -42,20 +41,17 @@ module AIXM
|
|
42
41
|
@name = value
|
43
42
|
end
|
44
43
|
|
45
|
-
#
|
46
|
-
def
|
47
|
-
builder
|
48
|
-
builder.tag!(as) do |tag|
|
44
|
+
# @!visibility private
|
45
|
+
def add_uid_to(builder, as: :GbrUid)
|
46
|
+
builder.send(as) do |tag|
|
49
47
|
tag.txtName(name.to_s)
|
50
48
|
end
|
51
49
|
end
|
52
|
-
memoize :to_uid
|
53
50
|
|
54
|
-
#
|
55
|
-
def
|
56
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
51
|
+
# @!visibility private
|
52
|
+
def add_to(builder)
|
57
53
|
builder.Avx do |avx|
|
58
|
-
avx
|
54
|
+
add_uid_to(avx)
|
59
55
|
avx.codeType('FNT')
|
60
56
|
avx.geoLat(xy.lat(AIXM.schema))
|
61
57
|
avx.geoLong(xy.long(AIXM.schema))
|
@@ -14,7 +14,8 @@ module AIXM
|
|
14
14
|
#
|
15
15
|
# @see https://gitlab.com/openflightmaps/ofmx/wikis/Airspace#circle
|
16
16
|
class Circle
|
17
|
-
include AIXM::Association
|
17
|
+
include AIXM::Concerns::Association
|
18
|
+
include AIXM::Concerns::XMLBuilder
|
18
19
|
|
19
20
|
# @!method geometry
|
20
21
|
# @return [AIXM::Component::Geometry] geometry this segment belongs to
|
@@ -57,9 +58,8 @@ module AIXM
|
|
57
58
|
@radius = value
|
58
59
|
end
|
59
60
|
|
60
|
-
#
|
61
|
-
def
|
62
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
61
|
+
# @!visibility private
|
62
|
+
def add_to(builder)
|
63
63
|
builder.Avx do |avx|
|
64
64
|
avx.codeType('CWA')
|
65
65
|
avx.geoLat(north_xy.lat(AIXM.schema))
|
@@ -14,7 +14,8 @@ module AIXM
|
|
14
14
|
#
|
15
15
|
# @see https://gitlab.com/openflightmaps/ofmx/wikis/Airspace#point
|
16
16
|
class Point
|
17
|
-
include AIXM::Association
|
17
|
+
include AIXM::Concerns::Association
|
18
|
+
include AIXM::Concerns::XMLBuilder
|
18
19
|
|
19
20
|
# @!method geometry
|
20
21
|
# @return [AIXM::Component::Geometry] geometry this segment belongs to
|
@@ -44,9 +45,8 @@ module AIXM
|
|
44
45
|
@xy = value
|
45
46
|
end
|
46
47
|
|
47
|
-
#
|
48
|
-
def
|
49
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
48
|
+
# @!visibility private
|
49
|
+
def add_to(builder)
|
50
50
|
builder.Avx do |avx|
|
51
51
|
avx.codeType('GRC')
|
52
52
|
avx.geoLat(xy.lat(AIXM.schema))
|
@@ -14,7 +14,8 @@ module AIXM
|
|
14
14
|
#
|
15
15
|
# @see https://gitlab.com/openflightmaps/ofmx/wikis/Airspace#rhumb-line
|
16
16
|
class RhumbLine
|
17
|
-
include AIXM::Association
|
17
|
+
include AIXM::Concerns::Association
|
18
|
+
include AIXM::Concerns::XMLBuilder
|
18
19
|
|
19
20
|
# @!method geometry
|
20
21
|
# @return [AIXM::Component::Geometry] geometry this segment belongs to
|
@@ -44,9 +45,8 @@ module AIXM
|
|
44
45
|
@xy = value
|
45
46
|
end
|
46
47
|
|
47
|
-
#
|
48
|
-
def
|
49
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
48
|
+
# @!visibility private
|
49
|
+
def add_to(builder)
|
50
50
|
builder.Avx do |avx|
|
51
51
|
avx.codeType('RHL')
|
52
52
|
avx.geoLat(xy.lat(AIXM.schema))
|
@@ -27,7 +27,7 @@ module AIXM
|
|
27
27
|
#
|
28
28
|
# @see https://gitlab.com/openflightmaps/ofmx/wikis/Airspace#avx-border-vertex
|
29
29
|
class Geometry < Component
|
30
|
-
include AIXM::Association
|
30
|
+
include AIXM::Concerns::Association
|
31
31
|
|
32
32
|
# @!method segments
|
33
33
|
# @return [Array<AIXM::Component::Geometry::Point,
|
@@ -93,10 +93,10 @@ module AIXM
|
|
93
93
|
segments.first.xy == segments.last.xy
|
94
94
|
end
|
95
95
|
|
96
|
-
#
|
97
|
-
def
|
96
|
+
# @!visibility private
|
97
|
+
def add_to(builder)
|
98
98
|
fail(GeometryError.new("geometry is not closed", self)) unless closed?
|
99
|
-
segments.
|
99
|
+
segments.each { _1.add_to(builder) }
|
100
100
|
end
|
101
101
|
end
|
102
102
|
|
@@ -23,8 +23,7 @@ module AIXM
|
|
23
23
|
#
|
24
24
|
# @see https://gitlab.com/openflightmaps/ofmx/wikis/Airport#tla-helipad-tlof
|
25
25
|
class Helipad < Component
|
26
|
-
include AIXM::Association
|
27
|
-
include AIXM::Memoize
|
26
|
+
include AIXM::Concerns::Association
|
28
27
|
include AIXM::Concerns::Marking
|
29
28
|
include AIXM::Concerns::Remarks
|
30
29
|
|
@@ -159,46 +158,40 @@ module AIXM
|
|
159
158
|
@status = value.nil? ? nil : (STATUSES.lookup(value.to_s.to_sym, nil) || fail(ArgumentError, "invalid status"))
|
160
159
|
end
|
161
160
|
|
162
|
-
#
|
163
|
-
def
|
164
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
161
|
+
# @!visibility private
|
162
|
+
def add_uid_to(builder)
|
165
163
|
builder.TlaUid do |tla_uid|
|
166
|
-
|
164
|
+
airport.add_uid_to(tla_uid)
|
167
165
|
tla_uid.txtDesig(name)
|
168
166
|
end
|
169
167
|
end
|
170
|
-
memoize :to_uid
|
171
168
|
|
172
|
-
#
|
173
|
-
def
|
174
|
-
builder = Builder::XmlMarkup.new(indent: 2)
|
169
|
+
# @!visibility private
|
170
|
+
def add_to(builder)
|
175
171
|
builder.Tla do |tla|
|
176
|
-
tla
|
177
|
-
|
172
|
+
add_uid_to(tla)
|
173
|
+
fato.add_uid_to(tla) if fato
|
178
174
|
tla.geoLat(xy.lat(AIXM.schema))
|
179
175
|
tla.geoLong(xy.long(AIXM.schema))
|
180
176
|
tla.codeDatum('WGE')
|
181
177
|
if z
|
182
178
|
tla.valElev(z.alt)
|
183
|
-
tla.uomDistVer(z.unit.upcase
|
179
|
+
tla.uomDistVer(z.unit.upcase)
|
184
180
|
end
|
185
181
|
if dimensions
|
186
182
|
tla.valLen(dimensions.length.to_m.dim.trim)
|
187
183
|
tla.valWid(dimensions.width.to_m.dim.trim)
|
188
184
|
tla.uomDim('M')
|
189
185
|
end
|
190
|
-
|
191
|
-
|
192
|
-
end
|
193
|
-
tla.codeClassHel(PERFORMANCE_CLASSES.key(performance_class).to_s) if performance_class
|
186
|
+
surface.add_to(tla) if surface
|
187
|
+
tla.codeClassHel(PERFORMANCE_CLASSES.key(performance_class)) if performance_class
|
194
188
|
tla.txtMarking(marking) if marking
|
195
|
-
tla.codeSts(STATUSES.key(status)
|
189
|
+
tla.codeSts(STATUSES.key(status)) if status
|
196
190
|
tla.txtRmk(remarks) if remarks
|
197
191
|
end
|
198
192
|
lightings.each do |lighting|
|
199
|
-
|
193
|
+
lighting.add_to(builder, as: :Tls)
|
200
194
|
end
|
201
|
-
builder.target!
|
202
195
|
end
|
203
196
|
end
|
204
197
|
end
|