add a configuration that parses all relevant airport data
This commit is contained in:
98
aman/config/Airport.py
Normal file
98
aman/config/Airport.py
Normal file
@@ -0,0 +1,98 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
import configparser
|
||||||
|
import glob
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from formats.SctEseFormat import SctEseFormat
|
||||||
|
|
||||||
|
class Airport:
|
||||||
|
def parseAirport(self, airport):
|
||||||
|
if None == airport.get('runways'):
|
||||||
|
return False
|
||||||
|
self.runways = airport['runways'].split(':')
|
||||||
|
return True
|
||||||
|
|
||||||
|
def findGngData(data, path):
|
||||||
|
if None == data.get('gngwildcard'):
|
||||||
|
return None, None
|
||||||
|
|
||||||
|
# find the newest ESE file
|
||||||
|
files = glob.glob(os.path.join(path, data['gngwildcard'] + '.ese'))
|
||||||
|
latestEse = max(files, key=os.path.getctime)
|
||||||
|
|
||||||
|
# search for the corresponding SCT file
|
||||||
|
latestSct = os.path.splitext(latestEse)[0] + '.sct'
|
||||||
|
|
||||||
|
# check if the files exist
|
||||||
|
if False == os.path.isfile(latestEse) or False == os.path.isfile(latestSct):
|
||||||
|
return None, None
|
||||||
|
|
||||||
|
return latestSct, latestEse
|
||||||
|
|
||||||
|
def parsePlanning(self, planning):
|
||||||
|
for key in planning:
|
||||||
|
# check if the runways match
|
||||||
|
rwy = key.upper()
|
||||||
|
if rwy not in self.runways:
|
||||||
|
sys.stderr.write('Unable to find ' + rwy + ' in defined runways')
|
||||||
|
return False
|
||||||
|
|
||||||
|
# check if arrivals are defined
|
||||||
|
arrivals = planning[key].split(':')
|
||||||
|
if 0 == len(arrivals):
|
||||||
|
sys.stderr.write('No arrival routes for ' + rwy)
|
||||||
|
return False
|
||||||
|
|
||||||
|
# assign the arrival routes to the runways
|
||||||
|
self.arrivalRoutes[rwy] = arrivals
|
||||||
|
|
||||||
|
return True
|
||||||
|
|
||||||
|
def __init__(self, filepath : str, icao : str):
|
||||||
|
self.runways = []
|
||||||
|
self.arrivalRoutes = {}
|
||||||
|
|
||||||
|
config = configparser.ConfigParser()
|
||||||
|
config.read(filepath)
|
||||||
|
|
||||||
|
dataConfig = None
|
||||||
|
airportConfig = None
|
||||||
|
planningConfig = None
|
||||||
|
|
||||||
|
# search the required sections
|
||||||
|
for key in config:
|
||||||
|
if 'DATA' == key:
|
||||||
|
dataConfig = config['DATA']
|
||||||
|
elif 'AIRPORT' == key:
|
||||||
|
airportConfig = config['AIRPORT']
|
||||||
|
elif 'PLANNING' == key:
|
||||||
|
planningConfig = config['PLANNING']
|
||||||
|
|
||||||
|
# find the GNG-file data
|
||||||
|
sctFile, eseFile = Airport.findGngData(dataConfig, os.path.dirname(filepath))
|
||||||
|
if None == sctFile or None == eseFile:
|
||||||
|
sys.stderr.write('No GNG-files found')
|
||||||
|
sys.exit(-1)
|
||||||
|
|
||||||
|
# parse the airport information
|
||||||
|
if None == airportConfig or False == self.parseAirport(airportConfig):
|
||||||
|
sys.stderr.write('No or no valid airport configuration found')
|
||||||
|
sys.exit(-1)
|
||||||
|
|
||||||
|
# parse the planning information
|
||||||
|
if None == planningConfig or False == self.parsePlanning(planningConfig):
|
||||||
|
sys.stderr.write('No or no valid planning configuration found')
|
||||||
|
sys.exit(-1)
|
||||||
|
|
||||||
|
# get all required arrival routes and avoid duplicates
|
||||||
|
requiredArrivalRoutes = []
|
||||||
|
for rwy in self.arrivalRoutes:
|
||||||
|
for arrival in self.arrivalRoutes[rwy]:
|
||||||
|
if arrival not in requiredArrivalRoutes:
|
||||||
|
requiredArrivalRoutes.append(arrival)
|
||||||
|
|
||||||
|
# parse the GNG data
|
||||||
|
print('Used GNG-Data: ' + eseFile)
|
||||||
|
self.gngData = SctEseFormat(sctFile, eseFile, icao, requiredArrivalRoutes)
|
||||||
Reference in New Issue
Block a user