start to implement release/patch
This commit is contained in:
106
scripts/release/com.py
Executable file
106
scripts/release/com.py
Executable file
@@ -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] + "\"")
|
||||
0
scripts/release/commits.txt
Normal file
0
scripts/release/commits.txt
Normal file
61
scripts/release/patch.py
Normal file → Executable file
61
scripts/release/patch.py
Normal file → Executable file
@@ -7,3 +7,64 @@
|
||||
# - <branch-list>: branches where the commit should be applied. * can be used as wildchar
|
||||
# - p: push the changes to <brach-list>
|
||||
# - 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")
|
||||
|
||||
|
||||
Reference in New Issue
Block a user