mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-26 22:22:16 +03:00
Оптимизируем код, добавляем partitions.bin и заставляем pio не удалять
This commit is contained in:
@@ -1,43 +1,36 @@
|
|||||||
# подготавливаем папку для локального сервера обновлений
|
# подготавливаем папку для локального сервера обновлений
|
||||||
# для этого компилируем проект и получаем бинарные файлы:
|
# для этого компилируем проект и получаем бинарные файлы:
|
||||||
# firmware.bin, littlefs.bin и ver.json
|
# firmware.bin, littlefs.bin, partitions.bin и ver.json
|
||||||
|
|
||||||
import shutil
|
import shutil
|
||||||
import configparser
|
import configparser
|
||||||
import os, json, sys, getopt
|
import os, json, sys, getopt
|
||||||
from pathlib import Path
|
from pathlib import Path
|
||||||
|
|
||||||
|
|
||||||
|
def copyFileIfExist(fileName, deviceName):
|
||||||
|
srcFilePath = ".pio/build/" + deviceName + "/" + fileName
|
||||||
|
dstFilePath = "iotm/" + deviceName + "/400/" + fileName
|
||||||
|
if Path(srcFilePath).is_file():
|
||||||
|
print("Ok...... \"" + srcFilePath + "\" на месте!")
|
||||||
|
Path(dstFilePath).parent.mkdir(parents=True, exist_ok=True)
|
||||||
|
shutil.copy(srcFilePath, dstFilePath)
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
print("Error...... \"" + srcFilePath + "\" НЕ существует!")
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
config = configparser.ConfigParser() # создаём объекта парсера INI
|
config = configparser.ConfigParser() # создаём объекта парсера INI
|
||||||
config.read("platformio.ini")
|
config.read("platformio.ini")
|
||||||
deviceName = config["platformio"]["default_envs"]
|
deviceName = config["platformio"]["default_envs"]
|
||||||
|
|
||||||
homeDir = os.path.expanduser('~')
|
homeDir = os.path.expanduser('~')
|
||||||
os.system(homeDir + "\.platformio\penv\Scripts\pio run")
|
os.system(homeDir + "\.platformio\penv\Scripts\pio run")
|
||||||
os.system(homeDir + "\.platformio\penv\Scripts\pio run -t buildfs")
|
os.system(homeDir + "\.platformio\penv\Scripts\pio run -t buildfs --disable-auto-clean")
|
||||||
|
|
||||||
firmwareSrcPath = ".pio/build/" + deviceName + "/firmware.bin"
|
if copyFileIfExist("firmware.bin", deviceName) and copyFileIfExist("littlefs.bin", deviceName) and copyFileIfExist("partitions.bin", deviceName):
|
||||||
littlefsSrcPath = ".pio/build/" + deviceName + "/littlefs.bin"
|
versionsJson = json.loads('{"' + deviceName + '": {"0": "400"}}')
|
||||||
|
with open("iotm/ver.json", "w", encoding='utf-8') as write_file:
|
||||||
if Path(firmwareSrcPath).is_file():
|
json.dump(versionsJson, write_file, ensure_ascii=False, indent=4, sort_keys=False)
|
||||||
print("Ok...... \"" + firmwareSrcPath + "\" Exist!")
|
print(f"\x1b[1;31;42m Сервер для обновления 'по воздуху' для " + deviceName + " подготовлен. Не забудьте установить расширение Live Server, запустить его и прописать в ESP IP вашего компьютера. Подробнее смотрите в WIKI: https://iotmanager.org/wiki.\x1b[0m")
|
||||||
firmwareDstPath = "iotm/" + deviceName + "/400/firmware.bin"
|
|
||||||
Path(firmwareDstPath).parent.mkdir(parents=True, exist_ok=True)
|
|
||||||
shutil.copy(firmwareSrcPath, firmwareDstPath)
|
|
||||||
|
|
||||||
if Path(littlefsSrcPath).is_file():
|
|
||||||
print("Ok...... \"" + littlefsSrcPath + "\" Exist!")
|
|
||||||
littlefsDstPath = "iotm/" + deviceName + "/400/littlefs.bin"
|
|
||||||
Path(littlefsDstPath).parent.mkdir(parents=True, exist_ok=True)
|
|
||||||
shutil.copy(littlefsSrcPath, littlefsDstPath)
|
|
||||||
|
|
||||||
versionsJson = json.loads('{"' + deviceName + '": {"0": "400"}}')
|
|
||||||
with open("iotm/ver.json", "w", encoding='utf-8') as write_file:
|
|
||||||
json.dump(versionsJson, write_file, ensure_ascii=False, indent=4, sort_keys=False)
|
|
||||||
|
|
||||||
print(f"\x1b[1;31;42m Сервер для обновления 'по воздуху' для " + deviceName + " подготовлен. Не забудьте установить расширение Live Server, запустить его и прописать в ESP IP вашего компьютера. Подробнее смотрите в WIKI: https://iotmanager.org/wiki.\x1b[0m")
|
|
||||||
|
|
||||||
else:
|
|
||||||
print("Error...... \"" + littlefsSrcPath + "\" Not exist!")
|
|
||||||
|
|
||||||
else:
|
|
||||||
print("Error...... \"" + firmwareSrcPath + "\" Not exist!")
|
|
||||||
Reference in New Issue
Block a user