Skip to content

Latest commit

 

History

History
108 lines (74 loc) · 5.97 KB

README.md

File metadata and controls

108 lines (74 loc) · 5.97 KB

KiBot CI/CD template repository for KiCad 6

This repository provides a ready-to-go CI/CD workflow for KiCad 6 with GitHub actions. Using KiCad5? See my other repo.

Features of this repository template

  1. Integration with GitHub releases to automatically produce documentation and fabrication files on every GitHub release, including automatic date and version stamping of schematics and PCBs.
  2. KiBot preflighting on every pull request (ERC/DRC checks disabled by default).
  3. External GitHub repo for custom components, including using 3D models from that repo during output generation.
  4. VSCode dev container and default build task for easy local testing of KiBot scripts.

Creating your GitHub repo and KiCad project

To create a KiCad project using this GitHub template:

  1. Hit the Use this template button then follow the steps from GitHub to create a copy of the repo. The repository name must exactly match the name of the KiCad project. Do not use spaces in either the repository or the project name.
  2. Clone the new repo locally.
  3. Go to File > New > Project... in KiCad.
  4. Name the project the exact same name as the GitHub repository name.
  5. Uncheck the Create a new directory for this project option. This is very important!
  6. Save the project into the top level of the folder for the GitHub repository.

Do not use spaces in the GitHub repository or KiCad project name. Use underscores or hyphens instead, for example TBM930_De-Ice_-_Panel or Collins-FMS-3000.

If you've done all the steps correctly the folder structure will look similar like this:

image

Notice that the folder name (which is also the GitHub repo name) and project name are exactly the same and there are no spaces.

Setting up date and version number replacement

The GitHub automation can automatically set the date and version number in the generated schematic and PCBs. Before using this make sure to set the timezone to your local timezone in the .github\workflows\includes\shared-settings.yml file.

The verison number for the release will be inserted anywhere ${VERSION} appears in the schematic or PCB design. Typical places to use this are in the Revision field of the schematic and board setup, and in silkscreen or copper layer text on the PCB.

The date for the release will be inserted anywhere ${DATE} appears in the schematic or PCB design. Typical places to use this are in the Date field of the schematic and board setup, and in silkscreen on the PCB.

JLCPCB BOM generation

This repo will automatically generate the necessary files for JLCPCB's SMT assembly service. To make it work add the LCSC part number to the MPN - JLCPCB field on each symbol. Chances are after generation at least one component will be rotated incorrectly. Blame JLCPCB, it sucks. To correct the rotation edit the .kibot/includes/JLCPCB-2layer.kibot.yaml file, modifying the rotations section as necessary.

Using an external GitHub repo for custom components

If you use a second GitHub repo to store your custom components the custom symbols and footprints will work fine with this automation without any extra effort. If you have custom 3D models you'll need to uncomment a few lines and point to your custom repo in one of the script files.

  1. In .github\workflows\documentation-only.yml uncomment the Checkout component step and update the repository value to reference your component repository.
  2. In .github\workflows\release.yml uncomment the Checkout component step and update the repository value to reference your component repository.
  3. In .kibot\includes\shared-settings.yaml uncomment the text variable KICAD6_USER_COMPONENTS_DIR and set its value to the name of your custom component repository folder. This is case sensitive!.
  4. In KiCad use ${KICAD6_USER_COMPONENTS_DIR} to reference the path to your custom components when assigning 3D models to footprints. It's a good idea to use the same variable to reference the symbol and footprint library as well.

An example custom component GitHub structure is available at https://github.com/neilenns/KiCad6-Components.

Documentation generated

The following documents are generated on every release build:

  • Schematic - PDF
  • BOM - Interactive HTML
  • PCB front copper and explanatory drawings layers - PDF
  • PCB back copper and explanatory drawings layers - PDF
  • 3D render - STEP
  • PCB front - JPEG
  • PCB back - JPEG

These documents can also be generated by manually running the KiBot - Generate documentation action on GitHub.

Fabrication files generated

The following fabrication files are generated on every release build:

  • JLCPCB gerbers and drill files, with BOM and placement files for SMT service
  • PCBWay gerbers and drill files

For JLCPCB BOM generation the symbols should be associated to the LCSC part number via a MPN - JLCPCB custom symbol field.

The fabrication files can also be generated by manually running the KiBot - Release action on GitHub.

Running builds locally

This repository template includes the files necessary to run in a VSCode dev container, which dramatically reduces the effort required to use KiBot on Windows machines.

Never used VSCode remote containers before on Windows? Here's how to get set up:

  1. From a PowerShell install WSL2 with this command: wsl --install
  2. Install Visual Studio Code and Docker Desktop(https://www.docker.com/products/docker-desktop)
  3. Install the Remote Containers extension for VSCode

When installing Docker Desktop you may be told you have to enable virtualization in your computer's BIOS. Setting that up is outside the scope of this readme but isn't hard. Just do a web search for your motherboard for how to enter the BIOS and what the exact name of the setting is, then turn it on.