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
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.
Link in personal KiCad library (optional)
If you use a custom/personal KiCad library repository that can be linked into the project library folder, you can do so by:
- 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.
-
Update the git submodule
git submodule update --remote hardware/library
Open KiCad and open the project
- Open up your installed version of KiCAD
- "File | Open Project"
- Located new project directory and navigate to the 'hardware' directory
- Select the project file.
- press ok