Skip to content

New project

Let's pretend you want to create a hardware widget called "some widget". Rather than manually creating the project directory structures and the documentation, get cookiecutter to do all the work.

Run Cookiecutter

Now run cookiecutter against this repo:

cookiecutter https://github.com/madeinoz67/cookiecutter-kicad

You'll be prompted for some values. Provide them, then a project structure will be created for you.

Warning

After this point, change 'Fred Smith', 'fsmith', etc. to your own information.

Answer the prompts with your own desired options. For example:

Cloning into 'cookiecutter-kicad'...
remote: Counting objects: 550, done.
remote: Compressing objects: 100% (310/310), done.
remote: Total 550 (delta 283), reused 479 (delta 222)
Receiving objects: 100% (550/550), 127.66 KiB | 58 KiB/s, done.
Resolving deltas: 100% (283/283), done.
project_name [Project Name]: Some Widget
project_repo_name [repo-name]: some-widget
project_description [This is my Kicad Project]: A Hardware Widget
author_name [my_name]: Fred Smith
author_email [my_email@somewhere.com]: fsmith@nowhere.com
github_user [my_gihub_username]: fsmith
Select kicad_version:
1 - 8.x
2 - 6.x
3 - 5.x
Choose from 1, 2 [1]: 1
Select license:
1 - CC-A-SA
2 - CC-A
3 - MIT
4 - BSD
5 - OSHD
6 - TAPR
7 - CERN-OHL-P
Choose from 1, 2, 3, 4, 5, 6, 7 [1]:

Enter the new project and take a look around

cd some-widget/
ls -a

Install project dependencies

make install
<or>
poetry install
This will proceed to download and install all project the dependencies and create a local virtual python environment for just this project so your local environment wont be pollute or get module clashes

python modules can be added at any time to the project by using poetry:

poetry add python_module

Important

Always use poetry to install project python modules not pip.

you can enter the virtual environment from anywhere in your project directory by:

poetry shell

exit (to exit)

or if you want to run a command in the virtual environment:

poetry run some_command

Publishing Documentation to github pages

mkdocs needs to be initialised after the project has been initially pushed to github. This will create the 'gh-pages' branch to manage the documentation publishing for github pages.

from the project root directory run:

poetry run mkdocs gh-deploy

Then in the github repository settings, set the github pages source to the gh-pages branch in settings | pages | source - Source = Deploy from branch - Branch = gh-pages /root

Now the github actions will automatically publish the documentation to github pages on every release.

Update Repository Documentation URL (optional)

It's a good idea to update the repository documentation url to the github pages url in both the README.md and the github repository about page, this available on the landing page of your repository in top right hand corner. Click on the gear icon to update the project description and website url.

If you use a custom/personal KiCad library repository that can be linked into the project library folder, you can do so by:

  1. Add the link to the library repository as a git submodule
    git add submodule git@github.com:<<gitusername>>/<<library-repo>>.git hardware/library
    

Important

replace <<gitusername>> with your git username.

replace <<library-repo>> with the name of your KiCad library repository.

  1. Update the git submodule

    git submodule update --remote hardware/library
    

Open KiCad and open the project

  1. Open up your installed version of KiCAD
  2. "File | Open Project"
  3. Located new project directory and navigate to the 'hardware' directory
  4. Select the project file.
  5. press ok