Merge pull request #6948 from Jason2866/patch-1

Copy compiled firmware(s) in folder `build_output/firmware`...
This commit is contained in:
Theo Arends 2019-11-17 10:43:59 +01:00 committed by GitHub
commit 210ef1eea2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 29 additions and 8 deletions

View File

@ -2,11 +2,32 @@ Import('env')
import os
import shutil
def name_firmware(source, target, env):
base_dir = os.path.dirname(str(target[0]))
new_file = "{}{}{}.bin".format(base_dir, os.path.sep, str(target[0]).split(os.path.sep)[1])
if os.path.isfile(new_file):
os.remove(new_file)
shutil.copyfile(str(target[0]), new_file)
OUTPUT_DIR = "build_output{}".format(os.path.sep)
env.AddPostAction("$BUILD_DIR/${PROGNAME}.bin", [name_firmware])
def bin_map_copy(source, target, env):
variant = str(target[0]).split(os.path.sep)[1]
# check if output directories exist and create if necessary
if not os.path.isdir(OUTPUT_DIR):
os.mkdir(OUTPUT_DIR)
for d in ['firmware', 'map']:
if not os.path.isdir("{}{}".format(OUTPUT_DIR, d)):
os.mkdir("{}{}".format(OUTPUT_DIR, d))
# create string with location and file names based on variant
map_file = "{}map{}{}.map".format(OUTPUT_DIR, os.path.sep, variant)
bin_file = "{}firmware{}{}.bin".format(OUTPUT_DIR, os.path.sep, variant)
# check if new target files exist and remove if necessary
for f in [map_file, bin_file]:
if os.path.isfile(f):
os.remove(f)
# copy firmware.bin to firmware/<variant>.bin
shutil.copy(str(target[0]), bin_file)
# copy firmware.map to map/<variant>.map
shutil.copy("firmware.map", map_file)
env.AddPostAction("$BUILD_DIR/${PROGNAME}.bin", [bin_map_copy])

View File

@ -86,7 +86,7 @@ upload_resetmethod = nodemcu
; *** Upload Serial reset method for Wemos and NodeMCU
upload_port = COM5
extra_scripts = pio/strip-floats.py
; pio/name-firmware.py
pio/name-firmware.py
; pio/obj-dump.py
; *** Upload file to OTA server using SCP