mirror of https://github.com/arendst/Tasmota.git
PIO tools overrides using .ini file settings
This commit is contained in:
parent
5d3cdb09b2
commit
00f3c3ecd2
|
@ -28,7 +28,7 @@ def map_gzip(source, target, env):
|
||||||
map_file.unlink()
|
map_file.unlink()
|
||||||
|
|
||||||
|
|
||||||
if not tasmotapiolib.is_env_set(tasmotapiolib.DISABLE_MAP_GZ):
|
if not tasmotapiolib.is_env_set(tasmotapiolib.DISABLE_MAP_GZ, env):
|
||||||
env.AddPostAction("$BUILD_DIR/${PROGNAME}.bin", [map_gzip])
|
env.AddPostAction("$BUILD_DIR/${PROGNAME}.bin", [map_gzip])
|
||||||
|
|
||||||
# gzip only for ESP8266
|
# gzip only for ESP8266
|
||||||
|
@ -66,5 +66,5 @@ if env["PIOPLATFORM"] != "espressif32":
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
if not tasmotapiolib.is_env_set(tasmotapiolib.DISABLE_BIN_GZ):
|
if not tasmotapiolib.is_env_set(tasmotapiolib.DISABLE_BIN_GZ, env):
|
||||||
env.AddPostAction("$BUILD_DIR/${PROGNAME}.bin", [bin_gzip])
|
env.AddPostAction("$BUILD_DIR/${PROGNAME}.bin", [bin_gzip])
|
||||||
|
|
|
@ -1,19 +1,43 @@
|
||||||
"""Supporting library for pio-tools scripts"""
|
"""Supporting library for pio-tools scripts
|
||||||
|
|
||||||
|
This also provides functions to allow overrides of some settings, see the available
|
||||||
|
overides below.
|
||||||
|
|
||||||
|
Overrides can be set using environment variables or .ini file settings for controlling
|
||||||
|
build output file locations and formats.
|
||||||
|
|
||||||
|
To set a value using an environment variable, prefix the value with "TASMOTA_" and
|
||||||
|
ensure the entire value is UPPER CASE, for example in bash, it would be:
|
||||||
|
|
||||||
|
export TASMOTA_DISABLE_MAP_GZ=1
|
||||||
|
|
||||||
|
To set a value in your .ini file, such as in platformio_override.ini, create a
|
||||||
|
[tasmota] section, and put the key ensuring it is all lower case, for example:
|
||||||
|
|
||||||
|
[tasmota]
|
||||||
|
disable_map_gz = 1
|
||||||
|
map_dir = /tmp/map_files/
|
||||||
|
|
||||||
|
Values in .ini files override environment variables
|
||||||
|
|
||||||
|
"""
|
||||||
import pathlib
|
import pathlib
|
||||||
import os
|
import os
|
||||||
|
|
||||||
# Constants for environment variables that can be set to control build output file
|
# === AVAILABLE OVERRIDES ===
|
||||||
# locations and formats
|
|
||||||
|
|
||||||
# if set to 1, will not gzip esp8266 bin files
|
# if set to 1, will not gzip esp8266 bin files
|
||||||
DISABLE_BIN_GZ = "TASMOTA_DISABLE_BIN_GZ"
|
DISABLE_BIN_GZ = "disable_bin_gz"
|
||||||
# if set, an alternative ptah to put generated .bin files
|
# if set, an alternative ptah to put generated .bin files, relative to project directory
|
||||||
BIN_DIR = "TASMOTA_BIN_DIR"
|
BIN_DIR = "bin_dir"
|
||||||
# if set to 1, will not gzip generated .map files
|
# if set to 1, will not gzip generated .map files
|
||||||
DISABLE_MAP_GZ = "TASMOTA_DISABLE_MAP_GZ"
|
DISABLE_MAP_GZ = "disable_map_gz"
|
||||||
# if set, an alternative path to put generated .map files
|
# if set, an alternative path to put generated .map files, relative to project directory
|
||||||
MAP_DIR = "TASMOTA_MAP_DIR"
|
MAP_DIR = "map_dir"
|
||||||
|
|
||||||
|
# === END AVAILABLE OVERRIDES ===
|
||||||
|
|
||||||
|
|
||||||
|
# This is the default output directory
|
||||||
OUTPUT_DIR = pathlib.Path("build_output")
|
OUTPUT_DIR = pathlib.Path("build_output")
|
||||||
|
|
||||||
|
|
||||||
|
@ -26,7 +50,7 @@ def get_final_bin_path(env) -> pathlib.Path:
|
||||||
"""Path to the final destination for the .bin
|
"""Path to the final destination for the .bin
|
||||||
|
|
||||||
If the parent directory does not exist, it will be created"""
|
If the parent directory does not exist, it will be created"""
|
||||||
firmware_dir = get_override_path(BIN_DIR)
|
firmware_dir = get_override_path(BIN_DIR, env)
|
||||||
firmware_dir.mkdir(parents=True, exist_ok=True)
|
firmware_dir.mkdir(parents=True, exist_ok=True)
|
||||||
return firmware_dir / "{}.bin".format(get_variant(env))
|
return firmware_dir / "{}.bin".format(get_variant(env))
|
||||||
|
|
||||||
|
@ -35,7 +59,7 @@ def get_final_map_path(env) -> pathlib.Path:
|
||||||
"""Path to the final destination for the .map file
|
"""Path to the final destination for the .map file
|
||||||
|
|
||||||
If the parent directory does not exist, it will be created"""
|
If the parent directory does not exist, it will be created"""
|
||||||
map_dir = get_override_path(MAP_DIR)
|
map_dir = get_override_path(MAP_DIR, env)
|
||||||
map_dir.mkdir(parents=True, exist_ok=True)
|
map_dir.mkdir(parents=True, exist_ok=True)
|
||||||
return map_dir / "{}.map".format(get_variant(env))
|
return map_dir / "{}.map".format(get_variant(env))
|
||||||
|
|
||||||
|
@ -62,13 +86,23 @@ def get_source_map_path(env) -> pathlib.Path:
|
||||||
raise FileNotFoundError
|
raise FileNotFoundError
|
||||||
|
|
||||||
|
|
||||||
def get_override_path(pathtype) -> pathlib.Path:
|
def get_tasmota_override_option(name: str, env):
|
||||||
|
"""Gets a set override option from a .ini or env variable, None if no match"""
|
||||||
|
config = env.GetProjectConfig()
|
||||||
|
override = config.get("tasmota", name.lower(), None)
|
||||||
|
if override is not None:
|
||||||
|
return override
|
||||||
|
# Return env if available
|
||||||
|
return os.environ.get("TASMOTA_" + name.upper())
|
||||||
|
|
||||||
|
|
||||||
|
def get_override_path(pathtype: str, env) -> pathlib.Path:
|
||||||
"""
|
"""
|
||||||
Returns a path to a givens override path if set, otherwise OUTPUT_DIR is used
|
Returns a path to a givens override path if set, otherwise OUTPUT_DIR is used
|
||||||
|
|
||||||
pathtype must be either MAP_DIR or BIN_DIR.
|
pathtype must be either MAP_DIR or BIN_DIR.
|
||||||
"""
|
"""
|
||||||
override = os.environ.get(pathtype)
|
override = get_tasmota_override_option(pathtype, env)
|
||||||
if override:
|
if override:
|
||||||
return pathlib.Path(override)
|
return pathlib.Path(override)
|
||||||
if pathtype == BIN_DIR:
|
if pathtype == BIN_DIR:
|
||||||
|
@ -78,9 +112,9 @@ def get_override_path(pathtype) -> pathlib.Path:
|
||||||
raise ValueError
|
raise ValueError
|
||||||
|
|
||||||
|
|
||||||
def is_env_set(name: str):
|
def is_env_set(name: str, env):
|
||||||
"""True if the enviornment variable <name> is set to `1`"""
|
"""True if the enviornment variable <name> is set to `1`"""
|
||||||
val = os.environ.get(name.upper())
|
val = get_tasmota_override_option(name, env)
|
||||||
if val:
|
if val:
|
||||||
val = val.strip()
|
val = val.strip()
|
||||||
return val == "1"
|
return val == "1"
|
||||||
|
|
Loading…
Reference in New Issue