diff --git a/scripts/release/com.py b/scripts/release/com.py new file mode 100755 index 0000000000..3756c5b513 --- /dev/null +++ b/scripts/release/com.py @@ -0,0 +1,106 @@ +#!/usr/bin/env python + +import sys +import os.path +from os import path +import os, fnmatch +import re +import subprocess +import com + +def cmd(c, ask_on_err = True): + print("\n" + c) + r = os.system(c) + if r: + print("### Error: " + str(r)) + if ask_on_err: + input("Press Enter to continue execution...") + +def define_set(fn, name, value): + print("In " + fn + " set " + name + " to " + value) + + new_content = "" + s = r'^ *# *define +' + str(name).rstrip() + ' +' + + f = open(fn, "r") + for i in f.read().splitlines(): + r = re.search(s, i) + if r: + d = i.split("define") + i = d[0] + "define " + name + " " + value + new_content += i + '\n' + + f.close() + + f = open(fn, "w") + f.write(new_content) + f.close() + +def ver_format(ver): + s = "v" + str(ver[0]) + "." + str(ver[1]) + "." + str(ver[2]) + if(ver[3] != ""): s = s + "-" + ver[3] + return s + +def get_lvgl_version(br): + print("Get LVGL's version") + + ver = [0, 0, 0, ""] + + com.cmd("git checkout " + br) + + f = open("./lvgl.h", "r") + + lastNum = re.compile(r'(?:[^\d]*(\d+)[^\d]*)+') + for i in f.read().splitlines(): + r = re.search(r'^#define LVGL_VERSION_MAJOR ', i) + if r: + m = lastNum.search(i) + if m: ver[0] = m.group(1) + + r = re.search(r'^#define LVGL_VERSION_MINOR ', i) + if r: + m = lastNum.search(i) + if m: ver[1] = m.group(1) + + r = re.search(r'^#define LVGL_VERSION_PATCH ', i) + if r: + m = lastNum.search(i) + if m: ver[2] = m.group(1) + + f.close() + + com.cmd("git checkout master") + return ver + +def push(c): + cmd("git push " + c) + +def update_version(ver): + ver_str = ver_format(ver) + ver_num = ver[0] + "." + ver[1] + "." + ver[2] + + templ = fnmatch.filter(os.listdir('.'), '*_templ*.h') + + if len(templ) > 0 and templ[0]: + print("Updating version in " + templ[0]) + cmd("sed -i -r 's/v[0-9]+\.[0-9]+\.[0-9]+.*/"+ "v" + ver_num + "/' " + templ[0]) + + if os.path.exists("library.json"): + print("Updating version in library.json") + cmd("sed -i -r 's/[0-9]+\.[0-9]+\.[0-9]+/"+ ver_num +"/' library.json") + + if path.exists("library.properties"): + print("Updating version in library.properties") + cmd("sed -i -r 's/version=[0-9]+\.[0-9]+\.[0-9]+/"+ "version=" + ver_num + "/' library.properties") + + if path.exists("conf.py"): + cmd("sed -i -r 's/v[0-9]+\.[0-9]+\.[0-9]+.*/" + ver_str + "/' conf.py") + + if path.exists("Kconfig"): + cmd("sed -i -r 's/v[0-9]+\.[0-9]+\.[0-9]+.*/" + ver_str + "/' Kconfig") + + if path.exists("lvgl.h"): + define_set("./lvgl.h", "LVGL_VERSION_MAJOR", str(ver[0])) + define_set("./lvgl.h", "LVGL_VERSION_MINOR", str(ver[1])) + define_set("./lvgl.h", "LVGL_VERSION_PATCH", str(ver[2])) + define_set("./lvgl.h", "LVGL_VERSION_INFO", "\"" + ver[3] + "\"") diff --git a/scripts/release/commits.txt b/scripts/release/commits.txt new file mode 100644 index 0000000000..e69de29bb2 diff --git a/scripts/release/patch.py b/scripts/release/patch.py old mode 100644 new mode 100755 index c3e1af2ca4..b021c1461f --- a/scripts/release/patch.py +++ b/scripts/release/patch.py @@ -7,3 +7,64 @@ # - : branches where the commit should be applied. * can be used as wildchar # - p: push the changes to # - t: increment version number and create a tag + + +import os, subprocess, com, re + +# tag = True + +def clone(repo): + com.cmd("git clone --recurse-submodules https://github.com/lvgl/" + repo) + os.chdir("./" + repo) + com.cmd("git checkout master") + com.cmd("git remote update origin --prune") + com.cmd("git pull origin --tags") + os.chdir("..") + +# Get the list of realted minor version branches + +#clone("lvgl") +os.chdir("lvgl") + +cmd = "git branch --remotes | grep origin/release/v8" +branches, error = subprocess.Popen(cmd, shell=True, executable="/bin/bash", stdout=subprocess.PIPE, stderr=subprocess.PIPE).communicate() + +branches = str(branches) +branches = branches.replace("b'", "") +branches = branches.replace("'", "") +branches = branches.replace("origin/", "") +branches = branches.replace(" ", " ") +branches = branches.replace("\\n", "") +branches = branches.split(" ") +branches = list(filter(len, branches)) + + +commits = [] +with open('commits.txt') as f: + for line in f: + commits.append(line) + +print(commits) + +for br in branches: + ver = com.get_lvgl_version(br) + ver_new = ver.copy() + ver_new[2] = str(int(ver_new[2]) + 1) + print("Updating branch '" + br + "' from '" + com.ver_format(ver) + "' to '" + com.ver_format(ver_new) + "'") + com.update_version(ver_new) + com.cmd("git tag -a " + com.ver_format(ver_new) + "-m \"Release " + com.ver_format(ver_new) + "\"") + + if push: + com.cmd("git push origin " + br + "--tags") + +com.cmd("git checkout master") +ver = com.get_lvgl_version("master") +ver = com.get_lvgl_version(br) +ver_new[2] = str(int(ver_new[2]) + 1) +t = com.ver_format(ver_new) + "-dev" +com.cmd("git tag -a " + t + "-m \"Start " + t + "\"") + + +if push: + com.cmd("git push origin master --tags") +