automated release process stuff
This commit is contained in:
parent
d3f739bb7f
commit
db604e8abb
14
templates/jlcpcb_template/.bumpversion.cfg
Normal file
14
templates/jlcpcb_template/.bumpversion.cfg
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
[bumpversion]
|
||||||
|
current_version = 0.0
|
||||||
|
serialize = {major}.{minor}
|
||||||
|
parse = (?P<major>\d+).(?P<minor>\d+)
|
||||||
|
commit = True
|
||||||
|
tag = True
|
||||||
|
|
||||||
|
[bumpversion:glob:mellifera/*.kicad_pcb]
|
||||||
|
search = (property "PCB_REVISION" "{current_version}")
|
||||||
|
replace = (property "PCB_REVISION" "{new_version}")
|
||||||
|
|
||||||
|
[bumpversion:glob:mellifera/*.kicad_pro]
|
||||||
|
search = "PCB_REVISION": "{current_version}"
|
||||||
|
replace = "PCB_REVISION": "{new_version}"
|
6
templates/jlcpcb_template/.gitignore
vendored
6
templates/jlcpcb_template/.gitignore
vendored
|
@ -1,2 +1,6 @@
|
||||||
|
# kicad backup/cache files
|
||||||
*-backups
|
*-backups
|
||||||
*.bak
|
*.bak
|
||||||
|
|
||||||
|
# prerelease outputs directory
|
||||||
|
outputs
|
|
@ -1,6 +1,6 @@
|
||||||
{
|
{
|
||||||
"board": {
|
"board": {
|
||||||
"active_layer": 44,
|
"active_layer": 37,
|
||||||
"active_layer_preset": "All Layers",
|
"active_layer_preset": "All Layers",
|
||||||
"auto_track_width": true,
|
"auto_track_width": true,
|
||||||
"hidden_netclasses": [],
|
"hidden_netclasses": [],
|
||||||
|
|
155
templates/jlcpcb_template/release.py
Normal file
155
templates/jlcpcb_template/release.py
Normal file
|
@ -0,0 +1,155 @@
|
||||||
|
# %% Imports
|
||||||
|
import shutil
|
||||||
|
import subprocess
|
||||||
|
import zipfile
|
||||||
|
from pathlib import Path
|
||||||
|
|
||||||
|
# %% Find the relevant files
|
||||||
|
projects = list(Path(__file__).parent.glob("*.kicad_pro"))
|
||||||
|
if len(projects) == 1:
|
||||||
|
root_project = projects[0].resolve()
|
||||||
|
else:
|
||||||
|
raise NotImplementedError("Need to determine which project is the root one (when multiple exist for sim)")
|
||||||
|
|
||||||
|
project_name = root_project.stem
|
||||||
|
|
||||||
|
dir_out = root_project.parent / "outputs"
|
||||||
|
if dir_out.exists():
|
||||||
|
shutil.rmtree(str(dir_out))
|
||||||
|
dir_out.mkdir(parents=True)
|
||||||
|
print(f"Writing outputs to {dir_out}")
|
||||||
|
|
||||||
|
# %% Verify state of repository
|
||||||
|
# TODO: check if repo is committed and pushed or if we're in CI
|
||||||
|
|
||||||
|
# %% Check Kicad version
|
||||||
|
kicad_version = subprocess.run(["kicad-cli", "version"], capture_output=True, check=True).stdout.decode()
|
||||||
|
major, minor, patch = kicad_version.split(".")
|
||||||
|
if int(major) < 7:
|
||||||
|
raise ValueError(f"Requires minimum Kicad version 7.0.0 buf found {kicad_version}")
|
||||||
|
|
||||||
|
# %% General documentation PDFs
|
||||||
|
subprocess.run(
|
||||||
|
[
|
||||||
|
"kicad-cli",
|
||||||
|
"sch",
|
||||||
|
"export",
|
||||||
|
"pdf",
|
||||||
|
str(root_project.with_suffix(".kicad_sch")),
|
||||||
|
"-o",
|
||||||
|
str(dir_out / f"{project_name}_schematic.pdf"),
|
||||||
|
],
|
||||||
|
check=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
subprocess.run(
|
||||||
|
[
|
||||||
|
"kicad-cli",
|
||||||
|
"pcb",
|
||||||
|
"export",
|
||||||
|
"pdf",
|
||||||
|
str(root_project.with_suffix(".kicad_pcb")),
|
||||||
|
"-o",
|
||||||
|
str(dir_out / f"{project_name}_fabrication_drawing.pdf"),
|
||||||
|
"--include-border-title",
|
||||||
|
"--layers",
|
||||||
|
",".join(["Edge.Cuts", "F.Cu", "F.Mask", "F.Silkscreen", "F.Fab"]),
|
||||||
|
],
|
||||||
|
check=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
subprocess.run(
|
||||||
|
[
|
||||||
|
"kicad-cli",
|
||||||
|
"pcb",
|
||||||
|
"export",
|
||||||
|
"step",
|
||||||
|
str(root_project.with_suffix(".kicad_pcb")),
|
||||||
|
"-o",
|
||||||
|
str(dir_out / f"{project_name}.step"),
|
||||||
|
"--subst-models",
|
||||||
|
"--no-virtual", # TODO: decide if I want virtual models. I might just generate both
|
||||||
|
],
|
||||||
|
check=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
# %% Fabrication Files
|
||||||
|
dir_gerber = dir_out / f"{project_name}_gerbers"
|
||||||
|
dir_gerber.mkdir(exist_ok=True)
|
||||||
|
|
||||||
|
subprocess.run(
|
||||||
|
[
|
||||||
|
"kicad-cli",
|
||||||
|
"pcb",
|
||||||
|
"export",
|
||||||
|
"gerbers",
|
||||||
|
str(root_project.with_suffix(".kicad_pcb")),
|
||||||
|
"-o",
|
||||||
|
str(dir_gerber),
|
||||||
|
],
|
||||||
|
check=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
subprocess.run(
|
||||||
|
[
|
||||||
|
"kicad-cli",
|
||||||
|
"pcb",
|
||||||
|
"export",
|
||||||
|
"drill",
|
||||||
|
str(root_project.with_suffix(".kicad_pcb")),
|
||||||
|
"--separate-files",
|
||||||
|
"--generate-map", # not necessary but kinda nice since I can't nicely make a drill table in the main pdf
|
||||||
|
# "-o", # -0 flag is not working so I'm just using cwd instead
|
||||||
|
# str(dir_gerber),
|
||||||
|
],
|
||||||
|
cwd=str(dir_gerber.resolve()),
|
||||||
|
check=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
# TODO: add version strings to every single filename
|
||||||
|
|
||||||
|
# %% Zip up the gerbers
|
||||||
|
with zipfile.ZipFile(dir_gerber.with_suffix(".zip"), "w") as z:
|
||||||
|
for f in dir_gerber.glob("*"):
|
||||||
|
z.write(f, f.name)
|
||||||
|
|
||||||
|
# %% Assembly files
|
||||||
|
subprocess.run(
|
||||||
|
[
|
||||||
|
"kicad-cli",
|
||||||
|
"pcb",
|
||||||
|
"export",
|
||||||
|
"pdf",
|
||||||
|
str(root_project.with_suffix(".kicad_pcb")),
|
||||||
|
"-o",
|
||||||
|
str(dir_out / f"{project_name}_assembly_drawing.pdf"),
|
||||||
|
"--include-border-title",
|
||||||
|
"--layers",
|
||||||
|
",".join(["Edge.Cuts", "F.Mask", "F.Silkscreen", "F.Fab"]),
|
||||||
|
],
|
||||||
|
check=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
subprocess.run(
|
||||||
|
[
|
||||||
|
"kicad-cli",
|
||||||
|
"sch",
|
||||||
|
"export",
|
||||||
|
"python-bom",
|
||||||
|
str(root_project.with_suffix(".kicad_sch")),
|
||||||
|
"-o",
|
||||||
|
str(dir_out / f"{project_name}_bom.xml"),
|
||||||
|
],
|
||||||
|
check=True,
|
||||||
|
)
|
||||||
|
# TODO: post-process XML BOM into something more useful or skip XML altogether and just make an interactive HTML BOM
|
||||||
|
|
||||||
|
# subprocess.run(
|
||||||
|
# [
|
||||||
|
# "python3",
|
||||||
|
# "path/to/InteractiveHtmlBom/generate_interactive_bom.py", # TODO: locate this somewhere reasonable
|
||||||
|
# str(root_project.with_suffix(".kicad_pcb")),
|
||||||
|
# ],
|
||||||
|
# check=True,
|
||||||
|
# )
|
Loading…
Reference in New Issue
Block a user