Merge pull request #44 from b8raoult/develop

Update memos.py so it produces the same files on Windows
This commit is contained in:
shahramn 2020-10-20 15:45:12 +01:00 committed by GitHub
commit 84b66d40c0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 42 additions and 25 deletions

7
eccodes.code-workspace Normal file
View File

@ -0,0 +1,7 @@
{
"folders": [
{
"path": "."
}
]
}

View File

@ -4,9 +4,13 @@ import os
import re import re
import sys import sys
import binascii import binascii
import time
assert len(sys.argv) > 2 assert len(sys.argv) > 2
start = time.time()
print("MEMFS: starting")
# Exclude experimental features e.g. GRIB3 and TAF # Exclude experimental features e.g. GRIB3 and TAF
# The BUFR codetables is not used in the engine # The BUFR codetables is not used in the engine
EXCLUDED = ["grib3", "codetables", "taf", "stations"] EXCLUDED = ["grib3", "codetables", "taf", "stations"]
@ -29,7 +33,7 @@ print("Excluding: ", EXCLUDED)
FILES = {} FILES = {}
SIZES = {} SIZES = {}
NAMES = [] NAMES = []
CHUNK = 5500 * 1000 # chunk size in bytes CHUNK = 16 * 1024 * 1024 # chunk size in bytes
# Binary to ASCII function. Different in Python 2 and 3 # Binary to ASCII function. Different in Python 2 and 3
try: try:
@ -45,11 +49,9 @@ def get_outfile_name(base, count):
# The last argument is the base name of the generated C file(s) # The last argument is the base name of the generated C file(s)
output_file_base = sys.argv[-1] output_file_base = sys.argv[-1]
totsize = 0 # amount written
fcount = 0 buffer = None
opath = get_outfile_name(output_file_base, fcount) fcount = -1
print("MEMFS: Generating output: ", opath)
g = open(opath, "w")
for directory in dirs: for directory in dirs:
@ -58,13 +60,19 @@ for directory in dirs:
NAMES.append(dname) NAMES.append(dname)
for dirpath, dirnames, files in os.walk(directory, followlinks=True): for dirpath, dirnames, files in os.walk(directory, followlinks=True):
# for ex in EXCLUDED:
# if ex in dirnames:
# print('Note: eccodes memfs.py script: %s/%s will not be included.' % (dirpath,ex))
# Prune the walk by modifying the dirnames in-place # Prune the walk by modifying the dirnames in-place
dirnames[:] = [dirname for dirname in dirnames if dirname not in EXCLUDED] dirnames[:] = [dirname for dirname in dirnames if dirname not in EXCLUDED]
for name in files: for name in files:
if buffer is None:
fcount += 1
opath = get_outfile_name(output_file_base, fcount)
print("MEMFS: Generating output:", opath)
buffer = open(opath, 'wb')
full = "%s/%s" % (dirpath, name) full = "%s/%s" % (dirpath, name)
_, ext = os.path.splitext(full) _, ext = os.path.splitext(full)
if ext not in [".def", ".table", ".tmpl", ".list", ".txt"]: if ext not in [".def", ".table", ".tmpl", ".list", ".txt"]:
@ -72,8 +80,6 @@ for directory in dirs:
if name == "CMakeLists.txt": if name == "CMakeLists.txt":
continue continue
fsize = os.path.getsize(full)
totsize += fsize
full = full.replace("\\", "/") full = full.replace("\\", "/")
fname = full[full.find("/%s/" % (dname,)) :] fname = full[full.find("/%s/" % (dname,)) :]
# print("MEMFS: Add ", fname) # print("MEMFS: Add ", fname)
@ -82,9 +88,9 @@ for directory in dirs:
assert name not in FILES assert name not in FILES
assert name not in SIZES assert name not in SIZES
FILES[name] = fname FILES[name] = fname
SIZES[name] = fsize SIZES[name] = os.path.getsize(full)
print("const unsigned char %s[] = {" % (name,), file=g) buffer.write("const unsigned char %s[] = {" % (name,))
with open(full, "rb") as f: with open(full, "rb") as f:
i = 0 i = 0
@ -98,24 +104,22 @@ for directory in dirs:
# e.g. 23 -> 0x23 # e.g. 23 -> 0x23
for n in range(0, len(contents_hex), 2): for n in range(0, len(contents_hex), 2):
twoChars = ascii(contents_hex[n : n + 2]) twoChars = ascii(contents_hex[n : n + 2])
print("0x%s," % (twoChars,), end="", file=g) buffer.write("0x%s," % (twoChars,))
i += 1 i += 1
if (i % 20) == 0: if (i % 20) == 0:
print("", file=g) buffer.write("\n")
print("};", file=g) buffer.write("};\n")
if totsize >= CHUNK: if buffer.tell() >= CHUNK:
g.close() buffer.close()
fcount += 1 buffer = None
opath = get_outfile_name(output_file_base, fcount)
print("MEMFS: Generating output: ", opath) if buffer is not None:
g = open(opath, "w") buffer.close()
totsize = 0
g.close()
# The number of generated C files is hard coded. # The number of generated C files is hard coded.
# See memfs/CMakeLists.txt # See memfs/CMakeLists.txt
assert fcount == 3, fcount assert fcount == 6, fcount
opath = output_file_base + "_final.c" opath = output_file_base + "_final.c"
print("MEMFS: Generating output: ", opath) print("MEMFS: Generating output: ", opath)
g = open(opath, "w") g = open(opath, "w")
@ -311,3 +315,6 @@ FILE* codes_memfs_open(const char* path) {
) )
print("Finished") print("Finished")
print("MEMFS: done", time.time() - start)

View File

@ -10,6 +10,9 @@ set( generated_c_files
${CMAKE_CURRENT_BINARY_DIR}/memfs_gen_001.c ${CMAKE_CURRENT_BINARY_DIR}/memfs_gen_001.c
${CMAKE_CURRENT_BINARY_DIR}/memfs_gen_002.c ${CMAKE_CURRENT_BINARY_DIR}/memfs_gen_002.c
${CMAKE_CURRENT_BINARY_DIR}/memfs_gen_003.c ${CMAKE_CURRENT_BINARY_DIR}/memfs_gen_003.c
${CMAKE_CURRENT_BINARY_DIR}/memfs_gen_004.c
${CMAKE_CURRENT_BINARY_DIR}/memfs_gen_005.c
${CMAKE_CURRENT_BINARY_DIR}/memfs_gen_006.c
${CMAKE_CURRENT_BINARY_DIR}/memfs_gen_final.c) ${CMAKE_CURRENT_BINARY_DIR}/memfs_gen_final.c)
add_custom_command( add_custom_command(