forked from proximax-storage/catbuffer
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.py
More file actions
75 lines (57 loc) · 2.74 KB
/
main.py
File metadata and controls
75 lines (57 loc) · 2.74 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
# pylint: disable=too-few-public-methods
import argparse
import os
import pprint
from catparser.CatsParser import CatsParser
from generators.All import AVAILABLE_GENERATORS
class MultiFileParser:
"""CATS parser that resolves imports in global namespace"""
def __init__(self):
self.cats_parser = CatsParser(self._process_import_file)
self.dirname = None
def set_include_path(self, include_path):
self.dirname = include_path
def parse(self, schema_filename):
self._process_file(schema_filename)
def _process_import_file(self, filename):
filename = os.path.join(self.dirname, filename)
self._process_file(filename)
def _process_file(self, filename):
self.cats_parser.push_scope(filename)
with open(filename) as input_file:
lines = input_file.readlines()
for line in lines:
self.cats_parser.process_line(line)
self.cats_parser.pop_scope()
def _generate_output(generator_name, directory, schema, options):
generator_class = AVAILABLE_GENERATORS[generator_name]
output_path = os.path.join(directory, generator_name)
os.makedirs(output_path, exist_ok=True)
generator = generator_class(schema, options)
for generated_descriptor in generator:
output_filename = os.path.join(output_path, generated_descriptor.filename)
with open(output_filename, 'w', newline='\n') as output_file:
for line in generated_descriptor.code:
output_file.write('%s\n' % line)
def generate():
parser = argparse.ArgumentParser(description='CATS code generator')
parser.add_argument('-s', '--schema', help='input CATS file', required=True)
parser.add_argument('-o', '--output', help='output directory', default='_generated')
parser.add_argument('-i', '--include', help='schema root directory', default='./schemas')
generators_list = list(AVAILABLE_GENERATORS.keys())
parser.add_argument('-g', '--generator', help='generator to use to produce output files', choices=generators_list)
parser.add_argument('-c', '--copyright', help='file containing copyright data to use with output files', default='../HEADER.inc')
args = parser.parse_args()
file_parser = MultiFileParser()
file_parser.set_include_path(args.include)
file_parser.parse(args.schema)
# console output the parsed schema
printer = pprint.PrettyPrinter(width=140)
printer.pprint('*** *** ***')
type_descriptors = file_parser.cats_parser.type_descriptors()
for key in type_descriptors:
printer.pprint((key, type_descriptors[key]))
# generate and output code
if args.generator:
_generate_output(args.generator, args.output, type_descriptors, {'copyright': args.copyright})
generate()