Expand environment variables in gen_esp32part

Allows parametrizing partition table with (exported) make variables.
pull/301/head
Deomid Ryabkov 2017-01-26 01:47:53 +00:00
rodzic 6bc9cd39e9
commit 22c3877183
1 zmienionych plików z 11 dodań i 3 usunięć

Wyświetl plik

@ -5,8 +5,10 @@
# Converts partition tables to/from CSV and binary formats. # Converts partition tables to/from CSV and binary formats.
# #
# See the sdkng README.md file for details about how to use this tool. # See the sdkng README.md file for details about how to use this tool.
import struct
import argparse import argparse
import os
import re
import struct
import sys import sys
MAX_PARTITION_LENGTH = 0xC00 # 3K for partition data (96 entries) leaves 1K in a 4K sector for signature MAX_PARTITION_LENGTH = 0xC00 # 3K for partition data (96 entries) leaves 1K in a 4K sector for signature
@ -163,7 +165,13 @@ class PartitionDefinition(object):
def from_csv(cls, line): def from_csv(cls, line):
""" Parse a line from the CSV """ """ Parse a line from the CSV """
line_w_defaults = line + ",,,," # lazy way to support default fields line_w_defaults = line + ",,,," # lazy way to support default fields
fields = [ f.strip() for f in line_w_defaults.split(",") ] def expand_vars(f):
f = os.path.expandvars(f)
m = re.match(r'(?<!\\)\$([A-Za-z_][A-Za-z0-9_]*)', f)
if m:
raise InputError("unknown variable '%s'" % m.group(1))
return f
fields = [ expand_vars(f.strip()) for f in line_w_defaults.split(",") ]
res = PartitionDefinition() res = PartitionDefinition()
res.name = fields[0] res.name = fields[0]
@ -346,5 +354,5 @@ if __name__ == '__main__':
try: try:
main() main()
except InputError as e: except InputError as e:
print(e) print >>sys.stderr, e
sys.exit(2) sys.exit(2)