mirror of
https://github.com/opentx/opentx.git
synced 2025-07-13 19:40:20 +03:00
* [build][CMake] Use `find_package(Git)` to confirm existence before trying to use git for version stamp; Use friendlier detection of grep executable on Windows; Use "del" on Windows instead of "rm". * [build][Windows] Include dirent and msinttypes headers in source tree. * Remove grep dependency for lua exports generation * Sneaky pythons hiding in code. * [build] Change `git_id` macro to skip check if no git directory is present, also now fails gracefully; Fix `today` macro on Windows; Report git revision; Make sure QtSvg module is found.
174 lines
5.1 KiB
Python
Executable file
174 lines
5.1 KiB
Python
Executable file
#!/usr/bin/env python
|
|
# -*- coding: utf-8 -*-
|
|
|
|
from __future__ import print_function
|
|
|
|
import sys
|
|
import os
|
|
import traceback
|
|
import time
|
|
import re
|
|
|
|
PREC1 = 10
|
|
PREC2 = 100
|
|
|
|
CONSTANT_VALUE = ""
|
|
dups_cnst = []
|
|
dups_name = []
|
|
exports = []
|
|
exports_multiple = []
|
|
exports_script_outputs = []
|
|
|
|
warning = None
|
|
error = None
|
|
|
|
|
|
def checkName(name):
|
|
global warning
|
|
if name in dups_name:
|
|
print("WARNING: Duplicate name %s found for constant %s" % (name, CONSTANT_VALUE))
|
|
warning = True
|
|
dups_name.append(name)
|
|
if name != name.lower():
|
|
print("WARNING: Name not in lower case %s found for constant %s" % (name, CONSTANT_VALUE))
|
|
warning = True
|
|
|
|
|
|
def LEXP(name, description):
|
|
# print "LEXP %s, %s" % (name, description)
|
|
checkName(name)
|
|
exports.append((CONSTANT_VALUE, name, description))
|
|
|
|
|
|
def LEXP_MULTIPLE(nameFormat, descriptionFormat, valuesCount):
|
|
# print "LEXP_MULTIPLE %s, %s, %s" % (nameFormat, descriptionFormat, valuesCount)
|
|
for v in range(valuesCount):
|
|
name = nameFormat + str(v)
|
|
# print name
|
|
checkName(name)
|
|
exports_multiple.append((CONSTANT_VALUE, nameFormat, descriptionFormat, valuesCount))
|
|
|
|
|
|
if len(sys.argv) < 3:
|
|
print("Error: not enough arguments!")
|
|
print("Usage:")
|
|
print(" luaexport.py <version> <input txt> <output cpp> [<doc output>]")
|
|
|
|
version = sys.argv[1]
|
|
inputFile = sys.argv[2]
|
|
outputFile = sys.argv[3]
|
|
docFile = None
|
|
if len(sys.argv) >= 4:
|
|
docFile = sys.argv[4]
|
|
print("Version %s" % version)
|
|
print("Input file %s" % inputFile)
|
|
print("Output file %s" % outputFile)
|
|
if docFile:
|
|
print("Documentation file %s" % docFile)
|
|
|
|
with open(inputFile, "r") as inp:
|
|
while True:
|
|
line = inp.readline()
|
|
if len(line) == 0:
|
|
break
|
|
line = line.strip('\r\n')
|
|
line = line.strip()
|
|
# print "line: %s" % line
|
|
|
|
if line.find('LEXP') < 0:
|
|
continue
|
|
|
|
parts = line.split('LEXP')
|
|
# print parts
|
|
if len(parts) != 2:
|
|
print("Wrong line: %s" % line)
|
|
continue
|
|
cmd = 'LEXP' + parts[1]
|
|
cnst = parts[0].rstrip(', ')
|
|
if cnst.find('=') != -1:
|
|
# constant contains =
|
|
cnst = cnst.split('=')[0].strip()
|
|
# print "Found constant %s with command: %s" % (cnst, cmd)
|
|
try:
|
|
CONSTANT_VALUE = cnst
|
|
# if CONSTANT_VALUE in dups_cnst:
|
|
# print "WARNING: Duplicate CONSTANT_VALUE found: %s" % CONSTANT_VALUE
|
|
# warning = True
|
|
# continue
|
|
# dups_cnst.append(CONSTANT_VALUE)
|
|
# print cmd
|
|
eval(cmd)
|
|
except:
|
|
print("ERROR: problem with the definition: %s" % line)
|
|
traceback.print_exc()
|
|
error = True
|
|
|
|
with open(outputFile, "w") as out:
|
|
out.write("//This file was generated by luaexport.py script on %s for OpenTX version %s\n\n\n"
|
|
% (time.asctime(), version))
|
|
|
|
header = """
|
|
struct LuaSingleField {
|
|
uint16_t id;
|
|
const char * name;
|
|
const char * desc;
|
|
};
|
|
|
|
struct LuaMultipleField {
|
|
uint16_t id;
|
|
const char * name;
|
|
const char * desc;
|
|
uint8_t count;
|
|
};
|
|
|
|
"""
|
|
out.write(header)
|
|
|
|
out.write("""
|
|
// The list of Lua fields
|
|
// this aray is alphabetically sorted by the second field (name)
|
|
const LuaSingleField luaSingleFields[] = {
|
|
""")
|
|
exports.sort(key=lambda x: x[1]) # sort by name
|
|
data = [" {%s, \"%s\", \"%s\"}" % export for export in exports]
|
|
out.write(",\n".join(data))
|
|
out.write("\n};\n\n")
|
|
print("Generated %d items in luaFields[]" % len(exports))
|
|
|
|
out.write("""
|
|
// The list of Lua fields that have a range of values
|
|
const LuaMultipleField luaMultipleFields[] = {
|
|
""")
|
|
data = [" {%s, \"%s\", \"%s\", %d}" % export for export in exports_multiple]
|
|
out.write(",\n".join(data))
|
|
out.write("\n};\n\n")
|
|
print("Generated %d items in luaMultipleFields[]" % len(exports_multiple))
|
|
|
|
if docFile:
|
|
# prepare fields
|
|
all_exports = [(name, desc) for (id, name, desc) in exports]
|
|
for (id, nameFormat, descriptionFormat, valuesCount) in exports_multiple:
|
|
for v in range(1, valuesCount + 1):
|
|
name = nameFormat + str(v)
|
|
desc = descriptionFormat % v
|
|
all_exports.append((name, desc))
|
|
# natural sort by field name
|
|
convert = lambda text: int(text) if text.isdigit() else text
|
|
alphanum_key = lambda key: [convert(c) for c in re.split('([0-9]+)', key[0])]
|
|
all_exports.sort(key=alphanum_key)
|
|
|
|
with open(docFile, "w") as out:
|
|
out.write("Alphabetical list of Lua fields for OpenTX version %s\n\n\n" % version)
|
|
FIELD_NAME_WIDTH = 25
|
|
out.write("Field name%sField description\n" % (' ' * (FIELD_NAME_WIDTH - len('Field name'))))
|
|
out.write("----------------------------------------------\n")
|
|
data = ["%s%s%s" % (name_, ' ' * (FIELD_NAME_WIDTH - len(name_)), desc_) for (name_, desc_) in all_exports]
|
|
out.write("\n".join(data))
|
|
out.write("\n")
|
|
|
|
if warning:
|
|
sys.exit(1)
|
|
elif error:
|
|
os.remove(outputFile)
|
|
sys.exit(2)
|
|
sys.exit(0)
|