-update XNODE* NETLIST_EXPORT_TOOL::makeGenericDesignHeader() so that the net file now outputs project information.
For example: - Company name - Project title - issue date - Revision - Comment 1 to 4 - updated bom2csv.xsl plugin to take advatage of the extra project information that the net file now outputs. Overall this improvement will make it easier to automatically make controlled and traceable documents.
This commit is contained in:
parent
07db7c8d29
commit
8a916a610a
|
@ -47,6 +47,7 @@
|
||||||
#include <xnode.h> // also nests: <wx/xml/xml.h>
|
#include <xnode.h> // also nests: <wx/xml/xml.h>
|
||||||
#include <build_version.h>
|
#include <build_version.h>
|
||||||
#include <set>
|
#include <set>
|
||||||
|
#include <sch_base_frame.h>
|
||||||
|
|
||||||
#define INTERMEDIATE_NETLIST_EXT wxT("xml")
|
#define INTERMEDIATE_NETLIST_EXT wxT("xml")
|
||||||
|
|
||||||
|
@ -652,16 +653,35 @@ static XNODE* node( const wxString& aName, const wxString& aTextualContent = wxE
|
||||||
|
|
||||||
XNODE* NETLIST_EXPORT_TOOL::makeGenericDesignHeader()
|
XNODE* NETLIST_EXPORT_TOOL::makeGenericDesignHeader()
|
||||||
{
|
{
|
||||||
|
SCH_SCREEN* screen;
|
||||||
|
SCH_SCREENS ScreenList;
|
||||||
|
screen = ScreenList.GetFirst();
|
||||||
XNODE* xdesign = node( wxT("design") );
|
XNODE* xdesign = node( wxT("design") );
|
||||||
|
|
||||||
// the root sheet is a special sheet, call it source
|
// the root sheet is a special sheet, call it source
|
||||||
xdesign->AddChild( node( wxT( "source" ), g_RootSheet->GetScreen()->GetFileName() ) );
|
xdesign->AddChild( node( wxT( "source" ), g_RootSheet->GetScreen()->GetFileName() ) );
|
||||||
|
|
||||||
xdesign->AddChild( node( wxT( "date" ), DateAndTime() ) );
|
xdesign->AddChild( node( wxT( "generatedDate" ), DateAndTime() ) );
|
||||||
|
|
||||||
// which Eeschema tool
|
// which Eeschema tool
|
||||||
xdesign->AddChild( node( wxT( "tool" ), wxT( "Eeschema " ) + GetBuildVersion() ) );
|
xdesign->AddChild( node( wxT( "tool" ), wxT( "Eeschema " ) + GetBuildVersion() ) );
|
||||||
|
|
||||||
|
// export project information
|
||||||
|
if( screen != NULL )
|
||||||
|
{
|
||||||
|
|
||||||
|
TITLE_BLOCK tb2 = screen->GetTitleBlock();
|
||||||
|
|
||||||
|
xdesign->AddChild( node( wxT( "title" ), tb2.GetTitle() ));
|
||||||
|
xdesign->AddChild( node( wxT( "company" ), tb2.GetCompany()));
|
||||||
|
xdesign->AddChild( node( wxT( "revision" ), tb2.GetRevision()));
|
||||||
|
xdesign->AddChild( node( wxT( "issueDate" ), tb2.GetDate()));
|
||||||
|
xdesign->AddChild( node( wxT( "comment1" ), tb2.GetComment1()));
|
||||||
|
xdesign->AddChild( node( wxT( "comment2" ), tb2.GetComment2()));
|
||||||
|
xdesign->AddChild( node( wxT( "comment3" ), tb2.GetComment3()));
|
||||||
|
xdesign->AddChild( node( wxT( "comment4" ), tb2.GetComment4()));
|
||||||
|
}
|
||||||
|
|
||||||
/* @todo might do a list of schematic pages
|
/* @todo might do a list of schematic pages
|
||||||
|
|
||||||
<page name="">
|
<page name="">
|
||||||
|
|
|
@ -4,11 +4,8 @@
|
||||||
|
|
||||||
Functionality:
|
Functionality:
|
||||||
Generation of csv table with table head of all existing field names
|
Generation of csv table with table head of all existing field names
|
||||||
and correct assigned cell entries
|
and correct assigned cell entries.
|
||||||
|
|
||||||
How to use this is explained in eeschema.pdf chapter 14. You enter a command line into the
|
|
||||||
netlist exporter using a new (custom) tab in the netlist export dialog. The command is
|
|
||||||
similar to
|
|
||||||
on Windows:
|
on Windows:
|
||||||
xsltproc -o "%O.csv" "C:\Program Files (x86)\KiCad\bin\plugins\bom2csv.xsl" "%I"
|
xsltproc -o "%O.csv" "C:\Program Files (x86)\KiCad\bin\plugins\bom2csv.xsl" "%I"
|
||||||
on Linux:
|
on Linux:
|
||||||
|
@ -21,10 +18,22 @@
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
@package
|
@package
|
||||||
Generate a Tab delimited list (csv file type).
|
Generate a command seperated file (.csv). One component per line
|
||||||
One component per line
|
|
||||||
Fields are
|
Ouput Example:
|
||||||
Ref,Value, Footprint, Datasheet, Field5, Field4, price
|
Kicad Rev: working director and file source
|
||||||
|
Generated Date: date this file was generated
|
||||||
|
Document Title: the project tile
|
||||||
|
Company: the project company
|
||||||
|
Revision: the project revision
|
||||||
|
Issue Date: project issue date
|
||||||
|
Comment: This is comment 1
|
||||||
|
Comment: This is comment 2
|
||||||
|
Comment: This is comment 3
|
||||||
|
Comment: This is comment 4
|
||||||
|
|
||||||
|
Reference, Value, Fields[n], Library, Library Ref
|
||||||
|
U1, PIC32MX, Fields[n], KicadLib, PIC
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<!DOCTYPE xsl:stylesheet [
|
<!DOCTYPE xsl:stylesheet [
|
||||||
|
@ -40,14 +49,50 @@
|
||||||
|
|
||||||
<!-- main part -->
|
<!-- main part -->
|
||||||
<xsl:template match="/export">
|
<xsl:template match="/export">
|
||||||
<xsl:text>Reference, Value, Footprint, Datasheet</xsl:text>
|
|
||||||
|
|
||||||
<!-- find all existing table head entries and list each one once -->
|
<xsl:text>Source: </xsl:text><xsl:value-of select="design/source"/><xsl:text>&nl;</xsl:text>
|
||||||
<xsl:for-each select="components/comp/fields/field[generate-id(.) = generate-id(key('headentr',@name)[1])]">
|
<xsl:text>Kicad Rev: </xsl:text><xsl:value-of select="design/tool"/><xsl:text>&nl;</xsl:text>
|
||||||
<xsl:text>, </xsl:text>
|
<xsl:text>Generated Date: </xsl:text><xsl:value-of select="design/generatedDate"/><xsl:text>&nl;</xsl:text>
|
||||||
<xsl:value-of select="@name"/>
|
<xsl:text>&nl;</xsl:text>
|
||||||
</xsl:for-each>
|
<xsl:text>Document Title: </xsl:text><xsl:value-of select="design/title"/><xsl:text>&nl;</xsl:text>
|
||||||
<xsl:text>&nl;</xsl:text>
|
<xsl:text>Company: </xsl:text><xsl:value-of select="design/company"/><xsl:text>&nl;</xsl:text>
|
||||||
|
<xsl:text>Revision: </xsl:text><xsl:value-of select="design/revision"/><xsl:text>&nl;</xsl:text>
|
||||||
|
<xsl:text>Issue Date: </xsl:text><xsl:value-of select="design/issueDate"/><xsl:text>&nl;</xsl:text>
|
||||||
|
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="design/comment1 !=''">
|
||||||
|
<xsl:text>Comment: </xsl:text><xsl:value-of select="design/comment1"/><xsl:text>&nl;</xsl:text>
|
||||||
|
</xsl:when>
|
||||||
|
</xsl:choose>
|
||||||
|
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="design/comment2 !=''">
|
||||||
|
<xsl:text>Comment: </xsl:text><xsl:value-of select="design/comment2"/><xsl:text>&nl;</xsl:text>
|
||||||
|
</xsl:when>
|
||||||
|
</xsl:choose>
|
||||||
|
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="design/comment3 !=''">
|
||||||
|
<xsl:text>Comment: </xsl:text><xsl:value-of select="design/comment3"/><xsl:text>&nl;</xsl:text>
|
||||||
|
</xsl:when>
|
||||||
|
</xsl:choose>
|
||||||
|
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="design/comment4 !=''">
|
||||||
|
<xsl:text>Comment: </xsl:text><xsl:value-of select="design/comment4"/><xsl:text>&nl;</xsl:text>
|
||||||
|
</xsl:when>
|
||||||
|
</xsl:choose>
|
||||||
|
|
||||||
|
<xsl:text>&nl;</xsl:text>
|
||||||
|
|
||||||
|
<!-- Output table header -->
|
||||||
|
<xsl:text>Reference, Value, </xsl:text>
|
||||||
|
<xsl:for-each select="components/comp/fields/field[generate-id(.) = generate-id(key('headentr',@name)[1])]">
|
||||||
|
<xsl:value-of select="@name"/>
|
||||||
|
<xsl:text>, </xsl:text>
|
||||||
|
</xsl:for-each>
|
||||||
|
<xsl:text>Library, Library Ref</xsl:text>
|
||||||
|
<xsl:text>&nl;</xsl:text>
|
||||||
|
|
||||||
<!-- all table entries -->
|
<!-- all table entries -->
|
||||||
<xsl:apply-templates select="components/comp"/>
|
<xsl:apply-templates select="components/comp"/>
|
||||||
|
@ -57,12 +102,17 @@
|
||||||
<xsl:template match="components/comp">
|
<xsl:template match="components/comp">
|
||||||
<xsl:value-of select="@ref"/><xsl:text>,</xsl:text>
|
<xsl:value-of select="@ref"/><xsl:text>,</xsl:text>
|
||||||
<xsl:value-of select="value"/><xsl:text>,</xsl:text>
|
<xsl:value-of select="value"/><xsl:text>,</xsl:text>
|
||||||
<xsl:value-of select="footprint"/><xsl:text>,</xsl:text>
|
|
||||||
<xsl:value-of select="datasheet"/>
|
|
||||||
<xsl:apply-templates select="fields"/>
|
<xsl:apply-templates select="fields"/>
|
||||||
|
<xsl:apply-templates select="libsource"/>
|
||||||
<xsl:text>&nl;</xsl:text>
|
<xsl:text>&nl;</xsl:text>
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
|
<!-- the library selection -->
|
||||||
|
<xsl:template match="libsource">
|
||||||
|
<xsl:value-of select="@lib"/><xsl:text>,</xsl:text>
|
||||||
|
<xsl:value-of select="@part"/>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
<!-- table entries with dynamic table head -->
|
<!-- table entries with dynamic table head -->
|
||||||
<xsl:template match="fields">
|
<xsl:template match="fields">
|
||||||
|
|
||||||
|
@ -72,7 +122,6 @@
|
||||||
<!-- for all existing head entries -->
|
<!-- for all existing head entries -->
|
||||||
<xsl:for-each select="/export/components/comp/fields/field[generate-id(.) = generate-id(key('headentr',@name)[1])]">
|
<xsl:for-each select="/export/components/comp/fields/field[generate-id(.) = generate-id(key('headentr',@name)[1])]">
|
||||||
<xsl:variable name="allnames" select="@name"/>
|
<xsl:variable name="allnames" select="@name"/>
|
||||||
<xsl:text>,</xsl:text>
|
|
||||||
|
|
||||||
<!-- for all field entries in the remembered fields section -->
|
<!-- for all field entries in the remembered fields section -->
|
||||||
<xsl:for-each select="$fieldvar">
|
<xsl:for-each select="$fieldvar">
|
||||||
|
@ -87,6 +136,7 @@
|
||||||
Every non-blank entry is assigned to its proper column.
|
Every non-blank entry is assigned to its proper column.
|
||||||
-->
|
-->
|
||||||
</xsl:for-each>
|
</xsl:for-each>
|
||||||
|
<xsl:text>,</xsl:text>
|
||||||
</xsl:for-each>
|
</xsl:for-each>
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue