Update BOM dialog help

This commit is contained in:
Graham Keeth 2022-11-03 22:49:20 +00:00 committed by Seth Hillbrand
parent bd4c2df3ba
commit 6f3e969529
5 changed files with 59 additions and 237 deletions

View File

@ -456,7 +456,7 @@ void DIALOG_BOM::OnHelp( wxCommandEvent& event )
return; return;
} }
m_helpWindow = new HTML_MESSAGE_BOX( nullptr, _( "Bill of Material Generation Help" ) ); m_helpWindow = new HTML_MESSAGE_BOX( nullptr, _( "Bill of Materials Generation Help" ) );
m_helpWindow->SetDialogSizeInDU( 500, 350 ); m_helpWindow->SetDialogSizeInDU( 500, 350 );
wxString html_txt; wxString html_txt;

View File

@ -48,7 +48,7 @@
<property name="size">-1,-1</property> <property name="size">-1,-1</property>
<property name="style">wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER</property> <property name="style">wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER</property>
<property name="subclass">DIALOG_SHIM; dialog_shim.h</property> <property name="subclass">DIALOG_SHIM; dialog_shim.h</property>
<property name="title">Bill of Material</property> <property name="title">Bill of Materials</property>
<property name="tooltip"></property> <property name="tooltip"></property>
<property name="window_extra_style"></property> <property name="window_extra_style"></property>
<property name="window_name"></property> <property name="window_name"></property>

View File

@ -78,7 +78,7 @@ class DIALOG_BOM_BASE : public DIALOG_SHIM
public: public:
DIALOG_BOM_BASE( wxWindow* parent, wxWindowID id = wxID_ANY, const wxString& title = _("Bill of Material"), const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( -1,-1 ), long style = wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER ); DIALOG_BOM_BASE( wxWindow* parent, wxWindowID id = wxID_ANY, const wxString& title = _("Bill of Materials"), const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize( -1,-1 ), long style = wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER );
~DIALOG_BOM_BASE(); ~DIALOG_BOM_BASE();
}; };

View File

@ -1,143 +1,54 @@
# 1 - Full documentation # 1. Summary
The Eeschema documentation (*eeschema.html*) describes this intermediate netlist and gives examples(chapter ***creating customized netlists and bom files***). The Bill of Materials tool creates a BOM which lists all of the components in the design.
# 2 - The intermediate Netlist File The tool uses an external script to generate a BOM in the desired output format. Choosing a different script changes how the BOM is formatted.
BOM files (and netlist files) can be created from an *Intermediate netlist file* created by Eeschema. Generating a BOM is described in more detail in the Schematic Editor manual.
This file uses XML syntax and is called the intermediate netlist. The intermediate netlist includes a large amount of data about your board and because of this, it can be used with post-processing to create a BOM or other reports. # 2. Usage
Depending on the output (BOM or netlist), different subsets of the complete Intermediate Netlist file will be used in the post-processing. Select a generator script in the **BOM generator scripts** list. Details for the selected generator are shown on the right of the dialog.
# 3 - Conversion to a new format Clicking the **Generate** button creates a BOM file with the selected generator.
By applying a post-processing filter to the Intermediate netlist file you can generate foreign netlist files as well as BOM files. Because this conversion is a text to text transformation, this post-processing filter can be written using *Python*, *XSLT*, or any other tool capable of taking XML as input. The default settings present several generator script options, although some additional scripts are installed with KiCad and can be added to the list with the **+** button.
XSLT itself is a XML language suitable for XML transformations. There is a free program called `xsltproc` that you can download and install. The `xsltproc` program can be used to read the Intermediate XML netlist input file, apply a style-sheet to transform the input, and save the results in an output file. Use of `xsltproc` requires a style-sheet file using XSLT conventions. The full conversion process is handled by Eeschema, after it is configured once to run `xsltproc` in a specific way. **Note:** On Windows, there is an additional option **Show console window**. When this option is unchecked, BOM generators run in a hidden console window and any output is redirected and printed in the dialog. When this option is checked, BOM generators run in a visisble console window.
A Python script is somewhat more easy to create. # 3. Custom generators and command lines
# 4 - Initialization of the dialog window Internally, KiCad creates an intermediate netlist file in XML format that contains information about all of the components in the design. A BOM generator script converts the intermediate netlist file to the desired output format. KiCad runs the BOM generator scripts according to the command line entered at the bottom of the BOM dialog.
You should add a new plugin (a script) in the plugin list by clicking on the Add Plugin button. The command line format accepts parameters for filenames. Each formatting parameter is replaced with a project-specific path or filename. The supported formatting parameters are:
## 4.1 - Plugin Configuration Parameters * `%I`: absolute path and filename of the intermediate netlist file, which is the input to the BOM generator
* `%O`: absolute path and filename of the output BOM file (without file extension)
* `%B`: base filename of the output BOM file (without file extension)
* `%P`: absolute path of the project directory, without trailing slash
The Eeschema plug-in configuration dialog requires the following information: **Note:** the `%O` output file parameter does not include a file extension. KiCad will attempt to add an appropriate extension to the command line automatically, but an extension may need to be added by hand.
* The title: for instance, the name of the netlist format. Python is the recommended tool for BOM generator scripts, but other tools can also be used.
* The command line to launch the converter (usually a script).
***Note (Windows only):*** ## Example command lines for Python scripts
*By default, the command line runs with hidden console window and output is redirected to "Plugin info" field. To show the window of the running command, set the checkbox "Show console window".*
Once you click on the generate button the following will happen: The command line format for a Python script is of the form:
1. Eeschema creates an intermediate netlist file \*.xml, for instance `test.xml`.
2. Eeschema runs the script from the command line to create the final output file.
## 4.2 - Generate netlist files with the command line
Assuming we are using the program `xsltproc.exe` to apply the sheet style to the intermediate file, `xsltproc.exe` is executed with the following command.
```
xsltproc.exe -o <output filename> <style-sheet filename> <input XML file to convert>
```
On Windows the command line is the following.
```
f:/kicad/bin/xsltproc.exe -o "%O" f:/kicad/bin/plugins/myconverter.xsl "%I"
```
On Linux the command becomes as following.
```
xsltproc -o "%O" /usr/local/kicad/bin/plugins/myconverter .xsl "%I"
```
where `myconverter.xsl` is the style-sheet that you are applying.
Do not forget the double quotes around the file names, this allows them to have spaces after the substitution by Eeschema.
If a Python script is used, the command line is something like (depending on the Python script):
```
python f:/kicad/bin/plugins/bom-in-python/myconverter.py "%I" "%O"
```
or
```
python /usr/local/kicad/bin/plugins/bom-in-python/myconverter .xsl "%I" "%O"
```
The command line format accepts parameters for filenames. The supported formatting parameters are:
* `%B`: base filename of selected output file, minus path and extension.
* `%P`: project directory, without name and without trailing '/'.
* `%I`: complete filename and path of the temporary input file
(the intermediate net file).
* `%O`: complete filename and path (but without extension) of the user
chosen output file.
`%I` will be replaced by the actual intermediate file name (usually the full root sheet filename with extension ".xml").
`%O` will be replaced by the actual output file name (the full root sheet filename minus extension).
`%B` will be replaced by the actual output short file name (the short root sheet filename minus extension).
`%P` will be replaced by the actual current project path.
## 4.3 - Command line format:
### 4.3.1 - Remark:
Most of time, the created file must have an extension, depending on its type.
Therefore you have to add to the option ***%O*** the right file extension.
For instance:
* **%O.csv** to create a .csv file (comma separated value file).
* **%O.htm** to create a .html file.
* **%O.bom** to create a .bom file.
### 4.3.2 Example for xsltproc:
The command line format for xsltproc is the following:
```
<path of xsltproc> xsltproc <xsltproc parameters>
```
On Windows:
```
f:/kicad/bin/xsltproc.exe -o "%O.bom" f:/kicad/bin/plugins/netlist_form_pads-pcb.xsl "%I"
```
On Linux:
```
xsltproc -o "%O.bom" /usr/local/kicad/bin/plugins/netlist_form_pads-pcb.xsl "%I"
```
The above examples assume `xsltproc` is installed on your PC under Windows and xsl files located in `<path_to_kicad>/kicad/bin/plugins/`.
### 4.3.3 Example for Python scripts:
Assuming python is installed on your PC, and python scripts are located in
`<path_to_kicad>/kicad/bin/plugins/bom-in-python/`,
the command line format for python is something like:
``` ```
python <script file name> <input filename> <output filename> python <script file name> <input filename> <output filename>
``` ```
On Windows: On Windows, if the desired generator script for a CSV BOM is `C:\Users\username\kicad\my_python_script.py`, the command line would be:
``` ```
python.exe f:/kicad/bin/plugins/bom-in-python/my_python_script.py "%I" "%O.html" python.exe C:\Users\username\kicad\my_python_script.py "%I" "%O.csv"
``` ```
On Linux: On Linux, if the desired generator script for a CSV BOM is `/home/username/kicad/my_python_script.py`, the command line would be:
``` ```
python /usr/local/kicad/bin/plugins/bom-in-python/my_python_script.py "%I" "%O.csv" python /home/username/kicad/my_python_script.py "%I" "%O.csv"
``` ```
Double quotes (`"`) around the arguments are recommended in case filenames contain spaces or special characters.

View File

@ -1,145 +1,56 @@
// Do not edit this file, it is autogenerated by CMake from the .md file // Do not edit this file, it is autogenerated by CMake from the .md file
_HKI( "# 1 - Full documentation\n" _HKI( "# 1. Summary\n"
"\n" "\n"
"The Eeschema documentation (*eeschema.html*) describes this intermediate netlist and gives examples(chapter ***creating customized netlists and bom files***).\n" "The Bill of Materials tool creates a BOM which lists all of the components in the design.\n"
"\n" "\n"
"# 2 - The intermediate Netlist File\n" "The tool uses an external script to generate a BOM in the desired output format. Choosing a different script changes how the BOM is formatted.\n"
"\n" "\n"
"BOM files (and netlist files) can be created from an *Intermediate netlist file* created by Eeschema.\n" "Generating a BOM is described in more detail in the Schematic Editor manual.\n"
"\n" "\n"
"This file uses XML syntax and is called the intermediate netlist. The intermediate netlist includes a large amount of data about your board and because of this, it can be used with post-processing to create a BOM or other reports.\n" "# 2. Usage\n"
"\n" "\n"
"Depending on the output (BOM or netlist), different subsets of the complete Intermediate Netlist file will be used in the post-processing.\n" "Select a generator script in the **BOM generator scripts** list. Details for the selected generator are shown on the right of the dialog.\n"
"\n" "\n"
"# 3 - Conversion to a new format\n" "Clicking the **Generate** button creates a BOM file with the selected generator.\n"
"\n" "\n"
"By applying a post-processing filter to the Intermediate netlist file you can generate foreign netlist files as well as BOM files. Because this conversion is a text to text transformation, this post-processing filter can be written using *Python*, *XSLT*, or any other tool capable of taking XML as input.\n" "The default settings present several generator script options, although some additional scripts are installed with KiCad and can be added to the list with the **+** button.\n"
"\n" "\n"
"XSLT itself is a XML language suitable for XML transformations. There is a free program called `xsltproc` that you can download and install. The `xsltproc` program can be used to read the Intermediate XML netlist input file, apply a style-sheet to transform the input, and save the results in an output file. Use of `xsltproc` requires a style-sheet file using XSLT conventions. The full conversion process is handled by Eeschema, after it is configured once to run `xsltproc` in a specific way.\n" "**Note:** On Windows, there is an additional option **Show console window**. When this option is unchecked, BOM generators run in a hidden console window and any output is redirected and printed in the dialog. When this option is checked, BOM generators run in a visisble console window.\n"
"\n" "\n"
"A Python script is somewhat more easy to create.\n" "# 3. Custom generators and command lines\n"
"\n" "\n"
"# 4 - Initialization of the dialog window\n" "Internally, KiCad creates an intermediate netlist file in XML format that contains information about all of the components in the design. A BOM generator script converts the intermediate netlist file to the desired output format. KiCad runs the BOM generator scripts according to the command line entered at the bottom of the BOM dialog.\n"
"\n" "\n"
"You should add a new plugin (a script) in the plugin list by clicking on the Add Plugin button.\n" "The command line format accepts parameters for filenames. Each formatting parameter is replaced with a project-specific path or filename. The supported formatting parameters are:\n"
"\n" "\n"
"## 4.1 - Plugin Configuration Parameters\n" " * `%I`: absolute path and filename of the intermediate netlist file, which is the input to the BOM generator\n"
" * `%O`: absolute path and filename of the output BOM file (without file extension)\n"
" * `%B`: base filename of the output BOM file (without file extension)\n"
" * `%P`: absolute path of the project directory, without trailing slash\n"
"\n" "\n"
"The Eeschema plug-in configuration dialog requires the following information:\n" "**Note:** the `%O` output file parameter does not include a file extension. KiCad will attempt to add an appropriate extension to the command line automatically, but an extension may need to be added by hand.\n"
"\n" "\n"
" * The title: for instance, the name of the netlist format.\n" "Python is the recommended tool for BOM generator scripts, but other tools can also be used.\n"
" * The command line to launch the converter (usually a script).\n"
"\n" "\n"
"***Note (Windows only):***\n" "## Example command lines for Python scripts\n"
"*By default, the command line runs with hidden console window and output is redirected to \"Plugin info\" field. To show the window of the running command, set the checkbox \"Show console window\".*\n"
"\n" "\n"
"Once you click on the generate button the following will happen:\n" "The command line format for a Python script is of the form:\n"
"\n"
"1. Eeschema creates an intermediate netlist file \\*.xml, for instance `test.xml`.\n"
"2. Eeschema runs the script from the command line to create the final output file.\n"
"\n"
"## 4.2 - Generate netlist files with the command line\n"
"\n"
"Assuming we are using the program `xsltproc.exe` to apply the sheet style to the intermediate file, `xsltproc.exe` is executed with the following command.\n"
"\n"
"```\n"
"xsltproc.exe -o <output filename> <style-sheet filename> <input XML file to convert>\n"
"```\n"
"\n"
"On Windows the command line is the following.\n"
"\n"
"```\n"
"f:/kicad/bin/xsltproc.exe -o \"%O\" f:/kicad/bin/plugins/myconverter.xsl \"%I\"\n"
"```\n"
"\n"
"On Linux the command becomes as following.\n"
"\n"
"```\n"
"xsltproc -o \"%O\" /usr/local/kicad/bin/plugins/myconverter .xsl \"%I\"\n"
"```\n"
"where `myconverter.xsl` is the style-sheet that you are applying.\n"
"\n"
"Do not forget the double quotes around the file names, this allows them to have spaces after the substitution by Eeschema.\n"
"\n"
"If a Python script is used, the command line is something like (depending on the Python script):\n"
"\n"
"```\n"
"python f:/kicad/bin/plugins/bom-in-python/myconverter.py \"%I\" \"%O\"\n"
"```\n"
"\n"
"or\n"
"\n"
"```\n"
"python /usr/local/kicad/bin/plugins/bom-in-python/myconverter .xsl \"%I\" \"%O\"\n"
"```\n"
"\n"
"The command line format accepts parameters for filenames. The supported formatting parameters are:\n"
"\n"
" * `%B`: base filename of selected output file, minus path and extension.\n"
" * `%P`: project directory, without name and without trailing '/'.\n"
" * `%I`: complete filename and path of the temporary input file\n"
"(the intermediate net file).\n"
" * `%O`: complete filename and path (but without extension) of the user\n"
"chosen output file.\n"
"\n"
"`%I` will be replaced by the actual intermediate file name (usually the full root sheet filename with extension \".xml\").\n"
"`%O` will be replaced by the actual output file name (the full root sheet filename minus extension).\n"
"`%B` will be replaced by the actual output short file name (the short root sheet filename minus extension).\n"
"`%P` will be replaced by the actual current project path.\n"
"\n"
"## 4.3 - Command line format:\n"
"\n"
"### 4.3.1 - Remark:\n"
"\n"
"Most of time, the created file must have an extension, depending on its type.\n"
"Therefore you have to add to the option ***%O*** the right file extension.\n"
"\n"
"For instance:\n"
"\n"
" * **%O.csv** to create a .csv file (comma separated value file).\n"
" * **%O.htm** to create a .html file.\n"
" * **%O.bom** to create a .bom file.\n"
"\n"
"### 4.3.2 Example for xsltproc:\n"
"\n"
"The command line format for xsltproc is the following:\n"
"\n"
"```\n"
"<path of xsltproc> xsltproc <xsltproc parameters>\n"
"```\n"
"\n"
"On Windows:\n"
"```\n"
"f:/kicad/bin/xsltproc.exe -o \"%O.bom\" f:/kicad/bin/plugins/netlist_form_pads-pcb.xsl \"%I\"\n"
"```\n"
"\n"
"On Linux:\n"
"```\n"
"xsltproc -o \"%O.bom\" /usr/local/kicad/bin/plugins/netlist_form_pads-pcb.xsl \"%I\"\n"
"```\n"
"\n"
"The above examples assume `xsltproc` is installed on your PC under Windows and xsl files located in `<path_to_kicad>/kicad/bin/plugins/`.\n"
"\n"
"\n"
"### 4.3.3 Example for Python scripts:\n"
"\n"
"Assuming python is installed on your PC, and python scripts are located in\n"
"\n"
" `<path_to_kicad>/kicad/bin/plugins/bom-in-python/`,\n"
"\n"
"the command line format for python is something like:\n"
"\n" "\n"
"```\n" "```\n"
"python <script file name> <input filename> <output filename>\n" "python <script file name> <input filename> <output filename>\n"
"```\n" "```\n"
"\n" "\n"
"On Windows:\n" "On Windows, if the desired generator script for a CSV BOM is `C:\\Users\\username\\kicad\\my_python_script.py`, the command line would be:\n"
"\n"
"```\n" "```\n"
"python.exe f:/kicad/bin/plugins/bom-in-python/my_python_script.py \"%I\" \"%O.html\"\n" "python.exe C:\\Users\\username\\kicad\\my_python_script.py \"%I\" \"%O.csv\"\n"
"```\n" "```\n"
"\n" "\n"
"On Linux:\n" "On Linux, if the desired generator script for a CSV BOM is `/home/username/kicad/my_python_script.py`, the command line would be:\n"
"\n"
"```\n" "```\n"
"python /usr/local/kicad/bin/plugins/bom-in-python/my_python_script.py \"%I\" \"%O.csv\"\n" "python /home/username/kicad/my_python_script.py \"%I\" \"%O.csv\"\n"
"```\n" "```\n"
"\n"
"Double quotes (`\"`) around the arguments are recommended in case filenames contain spaces or special characters.\n"
"" ); "" );