Update support for embedding files // Issue #161, Resolves #220

This commit is contained in:
valeros
2019-10-18 18:19:53 +03:00
parent cfe5140c44
commit 671234e193
3 changed files with 33 additions and 18 deletions
@@ -12,8 +12,9 @@
# See the License for the specific language governing permissions and
# limitations under the License.
from os import SEEK_CUR, SEEK_END
from os.path import basename, isfile, join
import shutil
from os import SEEK_CUR, SEEK_END, makedirs
from os.path import basename, isfile, isdir, join
from SCons.Script import Builder
@@ -21,9 +22,8 @@ from platformio.util import cd
Import("env")
#
# TXT files helpers
# Embedded files helpers
#
@@ -31,28 +31,38 @@ def prepare_files(files):
if not files:
return
fixed_files = []
build_dir = env.subst("$BUILD_DIR")
if not isdir(build_dir):
makedirs(build_dir)
for f in files:
with open(env.subst(f), "rb+") as fp:
fixed_file = join(build_dir, basename(f))
shutil.copy(env.subst(f), fixed_file)
with open(fixed_file, "rb+") as fp:
fp.seek(-1, SEEK_END)
if fp.read(1) != '\0':
fp.seek(0, SEEK_CUR)
fp.write(b'\0')
fixed_files.append(fixed_file)
def extract_files(cppdefines):
return fixed_files
def extract_files(cppdefines, files_type):
for define in cppdefines:
if "COMPONENT_EMBED_TXTFILES" not in define:
if files_type not in define:
continue
if not isinstance(define, tuple):
print("Warning! COMPONENT_EMBED_TXTFILES macro cannot be empty!")
print("Warning! %s macro cannot be empty!" % files_type)
return []
with cd(env.subst("$PROJECT_DIR")):
value = define[1]
if not isinstance(value, str):
print("Warning! COMPONENT_EMBED_TXTFILES macro must contain "
"a list of files separated by ':'")
print("Warning! %s macro must contain "
"a list of files separated by ':'" % files_type)
return []
result = []
@@ -65,9 +75,9 @@ def extract_files(cppdefines):
return result
def remove_config_define(cppdefines):
def remove_config_define(cppdefines, files_type):
for define in cppdefines:
if "COMPONENT_EMBED_TXTFILES" in define:
if files_type in define:
env.ProcessUnFlags("-D%s" % "=".join(str(d) for d in define))
return
@@ -94,9 +104,14 @@ env.Append(
suffix=".txt.o"))
)
flags = env.get("CPPDEFINES")
if "COMPONENT_EMBED_TXTFILES" in env.Flatten(flags):
files = extract_files(flags)
prepare_files(files)
for component_files in ("COMPONENT_EMBED_TXTFILES", "COMPONENT_EMBED_FILES"):
if component_files not in env.Flatten(flags):
continue
files = extract_files(flags, component_files)
if component_files == "COMPONENT_EMBED_TXTFILES":
files = prepare_files(files)
embed_files(files)
remove_config_define(flags)
remove_config_define(flags, component_files)
+1 -1
View File
@@ -28,7 +28,7 @@ from SCons.Script import DefaultEnvironment, SConscript
env = DefaultEnvironment()
SConscript("_embedtxt_files.py", exports="env")
SConscript("_embed_files.py", exports="env")
if "espidf" not in env.subst("$PIOFRAMEWORK"):
SConscript(
+1 -1
View File
@@ -33,7 +33,7 @@ env = DefaultEnvironment()
platform = env.PioPlatform()
env.SConscript("_bare.py", exports="env")
env.SConscript("_embedtxt_files.py", exports="env")
env.SConscript("_embed_files.py", exports="env")
ulp_lib = None
ulp_dir = join(env.subst("$PROJECT_DIR"), "ulp")