-
-
Notifications
You must be signed in to change notification settings - Fork 93
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Sphinx integration #57
Comments
This feature would definitely be useful and I would welcome it. However, currently, it is out of my time scope. I will be glad to help, consult, however, I am not sure if I am able to do much coding on this feature in the near future. |
https://github.com/nobodywasishere/sphinx-pcbdraw |
Nice! I will test it later. About KiCAD dependency - you have to either install it in CI or run the build, e.g., KiKit Docker image |
Ah I'm running into #52, and I've tried a lot of stuff and it's not working. I can't use the KiKit docker image directly as I'm also using a sphinx docker image for building, and so I either have to install kikit/kicad on the sphinx docker image, or install sphinx in the kikit docker image. I've tried the former here. Any recommendations? |
I looked at your action specification and I miss the actual Sphinx invocation. What exactly fails? Als, the action seems to pass with no error (though, it does not invoke Sphinx) |
I got it working. I ended up installing everything into the VM itself rather than using Docker. Now time for iterative improvements! |
I think there should be a For the pcbdraw directive, I think it should look something like this: .. pcbdraw:: path/to/pcb.kicad_pcb
:style: path/to/style.json # select a path/to/style.json
# or selects a builtin style if not a proper path
:placeholder: # place red squares in place of missing components
:remap: path/to/remap.json # use path/to/remap.json to remap components
:no-drillholes: # don't make drillholes transparent
:back: # draw the back of the board
:mirror: # mirror board on x-axis
:highlight: comma, separated, list # highlight these components
:filter: comma, separated, list # only show these components
:hidden: comma, separated, list # don't show these components There should also be some global configurations for sphinx_pcbdraw_libs = ["lib/folder/one", "lib/folder/two"] # library folders to include for generation
sphinx_pcbdraw_style = "path/to/style.json" # default style path or builtin
sphinx_pcbdraw_remap = "path/to/remap.json" # default for remapping components
sphinx_pcbdraw_hidden = ["component1", "component2"] # list of components to hide from all designs Thoughts? |
Well, I think PcbDraw would benefit from a rewrite from scratch. I have it somewhere on my roadmap once KiCAD 6 will be released. There is the filter option: Line 716 in 3b96105
|
Made some updates, adding the directive options and adding another directive for creating a table of the list of components. See the github repo and the website. There's probably a better way of doing this stuff (I'm still getting a handle on Sphinx) but this should work. I could probably help with a PcbDraw rewrite whenever you start it. Writing it as a shared library / class with a command-line wrapper would make it so sphinx-pcbdraw could use it directly instead of having to call subprocess as well. |
kicad is a hard requirement right? no way around it? |
Technically, you could package kicad as a Python package, but that'd be a bit hacky 😅 |
KiCAD is a hard requirement as we avoid interpreting the KiCAD files directly and we use KiCAD to interpret it. In this way, the implementation is much simpler and also, always correct (regarding added KiCAD features, etc.) |
my first thought lol that said, maybe only the pcbnew component and the python binding is possible? id hate to do it but if it works it works |
A lot of us use sphinx for documentation, it would be cool if we add a direct integration to embed renders, ala populate. I am not sure if that should live here or in a separate repo. I do have interest in helping out with that but the amount of time I will be able to put in will depend on my workload with other projects. For now I am just opening to see if there is interest and to get initial feedback.
The text was updated successfully, but these errors were encountered: