Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
K
kicad-source-mirror
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Commits
Open sidebar
Elphel
kicad-source-mirror
Commits
42f710a9
Commit
42f710a9
authored
Aug 04, 2010
by
Dick Hollenbeck
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
XML export work
parent
86a6c4de
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
556 additions
and
309 deletions
+556
-309
class_drawsheetpath.h
eeschema/class_drawsheetpath.h
+3
-2
class_libentry.h
eeschema/class_libentry.h
+6
-6
class_library.h
eeschema/class_library.h
+14
-4
netform.cpp
eeschema/netform.cpp
+533
-297
No files found.
eeschema/class_drawsheetpath.h
View file @
42f710a9
...
@@ -66,11 +66,12 @@ class SCH_MARKER;
...
@@ -66,11 +66,12 @@ class SCH_MARKER;
class
SCH_SHEET_PATH
class
SCH_SHEET_PATH
{
{
private
:
private
:
unsigned
m_numSheets
;
unsigned
m_numSheets
;
public
:
public
:
#define DSLSZ 32 // Max number of levels for a sheet path
#define DSLSZ 32 // Max number of levels for a sheet path
SCH_SHEET
*
m_sheets
[
DSLSZ
];
SCH_SHEET
*
m_sheets
[
DSLSZ
];
public
:
public
:
SCH_SHEET_PATH
();
SCH_SHEET_PATH
();
...
...
eeschema/class_libentry.h
View file @
42f710a9
...
@@ -71,32 +71,32 @@ public:
...
@@ -71,32 +71,32 @@ public:
virtual
void
SetName
(
const
wxString
&
aName
)
{
name
=
aName
;
}
virtual
void
SetName
(
const
wxString
&
aName
)
{
name
=
aName
;
}
bool
isComponent
()
{
return
type
==
ROOT
;
}
bool
isComponent
()
const
{
return
type
==
ROOT
;
}
bool
isAlias
()
{
return
type
==
ALIAS
;
}
bool
isAlias
()
const
{
return
type
==
ALIAS
;
}
int
GetType
()
{
return
type
;
}
int
GetType
()
const
{
return
type
;
}
void
SetDescription
(
const
wxString
&
aDescription
)
void
SetDescription
(
const
wxString
&
aDescription
)
{
{
description
=
aDescription
;
description
=
aDescription
;
}
}
wxString
GetDescription
()
{
return
description
;
}
wxString
GetDescription
()
const
{
return
description
;
}
void
SetKeyWords
(
const
wxString
&
aKeyWords
)
void
SetKeyWords
(
const
wxString
&
aKeyWords
)
{
{
keyWords
=
aKeyWords
;
keyWords
=
aKeyWords
;
}
}
wxString
GetKeyWords
()
{
return
keyWords
;
}
wxString
GetKeyWords
()
const
{
return
keyWords
;
}
void
SetDocFileName
(
const
wxString
&
aDocFileName
)
void
SetDocFileName
(
const
wxString
&
aDocFileName
)
{
{
docFileName
=
aDocFileName
;
docFileName
=
aDocFileName
;
}
}
wxString
GetDocFileName
()
{
return
docFileName
;
}
wxString
GetDocFileName
()
const
{
return
docFileName
;
}
/**
/**
* Write the entry document information to a FILE in "*.dcm" format.
* Write the entry document information to a FILE in "*.dcm" format.
...
...
eeschema/class_library.h
View file @
42f710a9
...
@@ -360,11 +360,21 @@ public:
...
@@ -360,11 +360,21 @@ public:
/**
/**
* Function GetLogicalName
* Function GetLogicalName
* returns the logical name of the library, which for now is the filename
* returns the logical name of the library.
* without path or extension.
* @return wxString - The logical name of this library.
* wxString - The logical library name.
*/
*/
wxString
GetLogicalName
()
{
return
fileName
.
GetName
();
}
wxString
GetLogicalName
()
{
/* for now is the filename without path or extension.
Technically the library should not know its logical name!
This will eventually come out of a pair of lookup tables using a
reverse lookup using the full name or library pointer as a key.
Search will be by project lookup table and then user lookup table if
not found.
*/
return
fileName
.
GetName
();
}
/**
/**
...
...
eeschema/netform.cpp
View file @
42f710a9
...
@@ -66,6 +66,8 @@ class UNIQUE_STRINGS
...
@@ -66,6 +66,8 @@ class UNIQUE_STRINGS
{
{
std
::
set
<
wxString
>
m_set
;
///< set of wxStrings already found
std
::
set
<
wxString
>
m_set
;
///< set of wxStrings already found
typedef
std
::
set
<
wxString
>::
iterator
us_iterator
;
public
:
public
:
/**
/**
* Function Clear
* Function Clear
...
@@ -83,11 +85,9 @@ public:
...
@@ -83,11 +85,9 @@ public:
bool
UNIQUE_STRINGS
::
Lookup
(
const
wxString
&
aString
)
bool
UNIQUE_STRINGS
::
Lookup
(
const
wxString
&
aString
)
{
{
bool
ret
=
(
m_set
.
find
(
aString
)
!=
m_set
.
end
()
);
std
::
pair
<
us_iterator
,
bool
>
pair
=
m_set
.
insert
(
aString
);
if
(
!
ret
)
m_set
.
insert
(
aString
);
return
ret
;
return
!
pair
.
second
;
}
}
...
@@ -104,6 +104,10 @@ class EXPORT_HELP
...
@@ -104,6 +104,10 @@ class EXPORT_HELP
/// Used for "multi parts per package" components, avoids processing a lib component more than once.
/// Used for "multi parts per package" components, avoids processing a lib component more than once.
UNIQUE_STRINGS
m_ReferencesAlreadyFound
;
UNIQUE_STRINGS
m_ReferencesAlreadyFound
;
std
::
set
<
LIB_COMPONENT
*>
m_LibParts
;
///< unique library parts used
std
::
set
<
CMP_LIBRARY
*>
m_Libraries
;
///< unique libraries used
/**
/**
* Function sprintPinNetName
* Function sprintPinNetName
...
@@ -125,41 +129,153 @@ class EXPORT_HELP
...
@@ -125,41 +129,153 @@ class EXPORT_HELP
* A suitable component is a "new" real component (power symbols are not
* A suitable component is a "new" real component (power symbols are not
* considered).
* considered).
*/
*/
SCH_COMPONENT
*
findNextComponentAndCreatPinList
(
EDA_BaseStruct
*
aItem
,
SCH_COMPONENT
*
findNextComponentAndCreatPinList
(
EDA_BaseStruct
*
aItem
,
SCH_SHEET_PATH
*
aSheetPath
);
SCH_SHEET_PATH
*
aSheetPath
);
SCH_COMPONENT
*
findNextComponent
(
EDA_BaseStruct
*
aItem
,
SCH_SHEET_PATH
*
aSheetPath
);
/**
* Function eraseDuplicatePins
* removes duplicate Pins fromt the pin list, m_SortedComponentPinList.
* (This is a list of pins found in the whole schematic, for a single
* component.) These duplicate pins were put in list because some pins (powers... )
* are found more than one time when we have a multiple parts per package
* component. For instance, a 74ls00 has 4 parts, and therefore the VCC pin
* and GND pin appears 4 times in the list.
* @param aPinList = a NETLIST_OBJECT_LIST that contains the list of pins for a
* given component.
* Note: this list *MUST* be sorted by pin number (.m_PinNum member value)
*/
void
eraseDuplicatePins
(
NETLIST_OBJECT_LIST
&
aPinList
);
/**
* Function addPintToComponentPinList
* adds a new pin description to the pin list m_SortedComponentPinList.
* A.a pin description is a pointer to the corresponding structure
* created by BuildNetList() in the table g_NetObjectslist.
*/
bool
addPinToComponentPinList
(
SCH_COMPONENT
*
Component
,
SCH_SHEET_PATH
*
sheet
,
LIB_PIN
*
PinEntry
);
/**
* Function findAllInstancesOfComponent
* is used for "multiple parts per package" components.
* <p>
* Search the entire design for all instances of \a aComponent based on
* matching reference designator, and for each part, add all its pins
* to the temporary sorted pin list.
*/
void
findAllInstancesOfComponent
(
SCH_COMPONENT
*
aComponent
,
LIB_COMPONENT
*
aEntry
,
SCH_SHEET_PATH
*
aSheetPath
);
/**
* Function writeGENERICListOfNets
* writes out nets (ranked by Netcode), and elements that are
* connected as part of that net.
*/
bool
writeGENERICListOfNets
(
FILE
*
f
,
NETLIST_OBJECT_LIST
&
aObjectsList
);
/**
* Function writeListOfNetsCADSTAR
* writes a net list (ranked by Netcode), and
* Pins connected to it
* Format:
*. ADD_TER RR2 6 "$ 42"
*. B U1 100
* 6 CA
*/
void
writeListOfNetsCADSTAR
(
FILE
*
f
,
NETLIST_OBJECT_LIST
&
aObjectsList
);
/**
* Function makeGenericDesignHeader
* fills out a project "design" header into an XML node.
* @return wxXmlNode* - the design header
*/
wxXmlNode
*
makeGenericDesignHeader
();
/**
* Function makeGenericLibParts
* fills out an XML node with the unique library parts and returns it.
*/
wxXmlNode
*
makeGenericLibParts
();
/**
* Function makeGenericListOfNets
* fills out an XML node with a list of nets and returns it.
*/
wxXmlNode
*
makeGenericListOfNets
();
/**
* Function makeGenericLibraries
* fills out an XML node with a list of used libraries and returns it.
* Must have called makeGenericLibParts() before this function.
*/
wxXmlNode
*
makeGenericLibraries
();
public
:
public
:
/**
* Function Write_GENERIC_NetList
* creates a generic netlist, now in XML.
* @return bool - true if there were no errors, else false.
*/
bool
Write_GENERIC_NetList
(
WinEDA_SchematicFrame
*
frame
,
const
wxString
&
aOutFileName
);
bool
Write_GENERIC_NetList
(
WinEDA_SchematicFrame
*
frame
,
const
wxString
&
aOutFileName
);
/**
/**
* Function WriteNetListPCBNEW
* Function WriteNetListPCBNEW
* generates a net list file (Format 2 improves ORCAD PCB)
* generates a net list file (Format 2 improves ORCAD PCB)
* = TRUE if with_pcbnew
*
* Format Pcbnew (OrcadPcb2 + reviews and lists of net)
* @param with_pcbnew if true, then format Pcbnew (OrcadPcb2 + reviews and lists of net),<p>
* = FALSE if with_pcbnew
* else output ORCADPCB2 strict format.
* Format ORCADPCB2 strict
*/
*/
bool
WriteNetListPCBNEW
(
WinEDA_SchematicFrame
*
frame
,
FILE
*
f
,
bool
WriteNetListPCBNEW
(
WinEDA_SchematicFrame
*
frame
,
FILE
*
f
,
bool
with_pcbnew
);
bool
with_pcbnew
);
/**
* Function WriteNetListCADSTAR
* generates a netlist file in CADSTAR Format.
* Header:
* HEA ..
* TIM .. 2004 07 29 16 22 17
* APA .. "Cadstar RINF Output - Version 6.0.2.3"
* INCH UNI .. 1000.0 in
* FULL TYP ..
*
* List of components:
* .. ADD_COM X1 "CNT D41612 (48pts CONTOUR TM)"
* .. ADD_COM U2 "74HCT245D" "74HCT245D"
*
* Connections:
* .. ADD_TER RR2 * 6 "$ 42"
* .. B U1 100
* 6 CA
*
* ADD_TER .. U2 * 6 "$ 59"
* .. B * U7 39
* U6 17
* U1 * 122
*
* .. ADD_TER P2 * 1 "$ 9"
* .. B * T3 1
*U1 * 14
*/
void
WriteNetListCADSTAR
(
WinEDA_SchematicFrame
*
frame
,
FILE
*
f
);
void
WriteNetListCADSTAR
(
WinEDA_SchematicFrame
*
frame
,
FILE
*
f
);
void
WriteListOfNetsCADSTAR
(
FILE
*
f
,
NETLIST_OBJECT_LIST
&
aObjectsList
);
void
WriteNetListPspice
(
WinEDA_SchematicFrame
*
frame
,
FILE
*
f
,
/**
* Function WriteNetListPspice
* generates a netlist file in PSPICE format.
* <p>
* All graphics text commentary by a [.-+] PSpice or [.-+] gnucap
* Are considered in placing orders in the netlist
* [.-] Or PSpice gnucap are beginning
* + + Gnucap and PSpice are ultimately NetList
* @param use_netnames if true, then nodes are identified by the netname,
* else by net number.
*/
bool
WriteNetListPspice
(
WinEDA_SchematicFrame
*
frame
,
FILE
*
f
,
bool
use_netnames
);
bool
use_netnames
);
bool
WriteGENERICListOfNetsTxt
(
FILE
*
f
,
NETLIST_OBJECT_LIST
&
aObjectsList
);
bool
WriteGENERICListOfNets
(
wxXmlNode
*
aNode
,
NETLIST_OBJECT_LIST
&
aObjectsList
);
bool
AddPinToComponentPinList
(
SCH_COMPONENT
*
Component
,
SCH_SHEET_PATH
*
sheet
,
LIB_PIN
*
PinEntry
);
void
FindAllInstancesOfComponent
(
SCH_COMPONENT
*
Component
,
LIB_COMPONENT
*
aEntry
,
SCH_SHEET_PATH
*
Sheet_in
);
void
EraseDuplicatePins
(
NETLIST_OBJECT_LIST
&
aPinList
);
};
};
...
@@ -176,9 +292,9 @@ public:
...
@@ -176,9 +292,9 @@ public:
bool
WinEDA_SchematicFrame
::
WriteNetListFile
(
int
aFormat
,
const
wxString
&
aFullFileName
,
bool
WinEDA_SchematicFrame
::
WriteNetListFile
(
int
aFormat
,
const
wxString
&
aFullFileName
,
bool
aUse_netnames
)
bool
aUse_netnames
)
{
{
bool
ret
=
true
;
bool
ret
=
true
;
FILE
*
f
=
NULL
;
FILE
*
f
=
NULL
;
EXPORT_HELP
helper
;
EXPORT_HELP
helper
;
if
(
aFormat
<
NET_TYPE_CUSTOM1
)
if
(
aFormat
<
NET_TYPE_CUSTOM1
)
{
{
...
@@ -195,12 +311,12 @@ bool WinEDA_SchematicFrame::WriteNetListFile( int aFormat, const wxString& aFull
...
@@ -195,12 +311,12 @@ bool WinEDA_SchematicFrame::WriteNetListFile( int aFormat, const wxString& aFull
switch
(
aFormat
)
switch
(
aFormat
)
{
{
case
NET_TYPE_PCBNEW
:
case
NET_TYPE_PCBNEW
:
ret
=
helper
.
WriteNetListPCBNEW
(
this
,
f
,
TRUE
);
ret
=
helper
.
WriteNetListPCBNEW
(
this
,
f
,
true
);
fclose
(
f
);
fclose
(
f
);
break
;
break
;
case
NET_TYPE_ORCADPCB2
:
case
NET_TYPE_ORCADPCB2
:
ret
=
helper
.
WriteNetListPCBNEW
(
this
,
f
,
FALSE
);
ret
=
helper
.
WriteNetListPCBNEW
(
this
,
f
,
false
);
fclose
(
f
);
fclose
(
f
);
break
;
break
;
...
@@ -210,7 +326,7 @@ bool WinEDA_SchematicFrame::WriteNetListFile( int aFormat, const wxString& aFull
...
@@ -210,7 +326,7 @@ bool WinEDA_SchematicFrame::WriteNetListFile( int aFormat, const wxString& aFull
break
;
break
;
case
NET_TYPE_SPICE
:
case
NET_TYPE_SPICE
:
helper
.
WriteNetListPspice
(
this
,
f
,
aUse_netnames
);
ret
=
helper
.
WriteNetListPspice
(
this
,
f
,
aUse_netnames
);
fclose
(
f
);
fclose
(
f
);
break
;
break
;
...
@@ -251,13 +367,11 @@ bool WinEDA_SchematicFrame::WriteNetListFile( int aFormat, const wxString& aFull
...
@@ -251,13 +367,11 @@ bool WinEDA_SchematicFrame::WriteNetListFile( int aFormat, const wxString& aFull
}
}
/*
/// Comparison routine for sorting by pin numbers.
* Comparison routine for sorting by pin numbers.
static
bool
sortPinsByNum
(
NETLIST_OBJECT
*
aPin1
,
NETLIST_OBJECT
*
aPin2
)
*/
static
bool
sortPinsByNum
(
NETLIST_OBJECT
*
Pin1
,
NETLIST_OBJECT
*
Pin2
)
{
{
// return "lhs < rhs"
// return "lhs < rhs"
return
RefDesStringCompare
(
Pin1
->
GetPinNumText
(),
Pin2
->
GetPinNumText
()
)
<
0
;
return
RefDesStringCompare
(
aPin1
->
GetPinNumText
(),
a
Pin2
->
GetPinNumText
()
)
<
0
;
}
}
...
@@ -301,8 +415,55 @@ void EXPORT_HELP::sprintPinNetName( wxString* aResult,
...
@@ -301,8 +415,55 @@ void EXPORT_HELP::sprintPinNetName( wxString* aResult,
}
}
SCH_COMPONENT
*
EXPORT_HELP
::
findNextComponentAndCreatPinList
(
EDA_BaseStruct
*
aItem
,
SCH_COMPONENT
*
EXPORT_HELP
::
findNextComponent
(
EDA_BaseStruct
*
aItem
,
SCH_SHEET_PATH
*
aSheetPath
)
SCH_SHEET_PATH
*
aSheetPath
)
{
wxString
ref
;
// continue searching from the middle of a linked list (the draw list)
for
(
;
aItem
;
aItem
=
aItem
->
Next
()
)
{
if
(
aItem
->
Type
()
!=
TYPE_SCH_COMPONENT
)
continue
;
// found next component
SCH_COMPONENT
*
comp
=
(
SCH_COMPONENT
*
)
aItem
;
// Power symbols and other components which have the reference starting
// with "#" are not included in netlist (pseudo or virtual components)
ref
=
comp
->
GetRef
(
aSheetPath
);
if
(
ref
[
0
]
==
wxChar
(
'#'
)
)
continue
;
// if( Component->m_FlagControlMulti == 1 )
// continue; /* yes */
// removed because with multiple instances of one schematic
// (several sheets pointing to 1 screen), this will be erroneously be
// toggled.
LIB_COMPONENT
*
entry
=
CMP_LIBRARY
::
FindLibraryComponent
(
comp
->
m_ChipName
);
if
(
!
entry
)
continue
;
// If component is a "multi parts per package" type
if
(
entry
->
GetPartCount
()
>
1
)
{
// test if this reference has already been processed, and if so skip
if
(
m_ReferencesAlreadyFound
.
Lookup
(
ref
)
)
continue
;
}
// record the usage of this library component entry.
m_LibParts
.
insert
(
entry
);
// rejects non-unique pointers
return
comp
;
}
return
NULL
;
}
SCH_COMPONENT
*
EXPORT_HELP
::
findNextComponentAndCreatPinList
(
EDA_BaseStruct
*
aItem
,
SCH_SHEET_PATH
*
aSheetPath
)
{
{
wxString
ref
;
wxString
ref
;
...
@@ -336,13 +497,14 @@ SCH_COMPONENT* EXPORT_HELP::findNextComponentAndCreatPinList( EDA_BaseStruct* aI
...
@@ -336,13 +497,14 @@ SCH_COMPONENT* EXPORT_HELP::findNextComponentAndCreatPinList( EDA_BaseStruct* aI
// If component is a "multi parts per package" type
// If component is a "multi parts per package" type
if
(
entry
->
GetPartCount
()
>
1
)
if
(
entry
->
GetPartCount
()
>
1
)
{
{
// test if
already visit
ed, and if so skip
// test if
this reference has already been process
ed, and if so skip
if
(
m_ReferencesAlreadyFound
.
Lookup
(
ref
)
)
if
(
m_ReferencesAlreadyFound
.
Lookup
(
ref
)
)
continue
;
continue
;
// Collect all parts and pins for this first occurance of reference.
// Collect all pins for this reference designator by searching
// the entire design for other parts with the same reference designator.
// This is only done once, it would be too expensive otherwise.
// This is only done once, it would be too expensive otherwise.
F
indAllInstancesOfComponent
(
comp
,
entry
,
aSheetPath
);
f
indAllInstancesOfComponent
(
comp
,
entry
,
aSheetPath
);
}
}
else
// entry->GetPartCount() <= 1 means one part per package
else
// entry->GetPartCount() <= 1 means one part per package
...
@@ -357,7 +519,7 @@ SCH_COMPONENT* EXPORT_HELP::findNextComponentAndCreatPinList( EDA_BaseStruct* aI
...
@@ -357,7 +519,7 @@ SCH_COMPONENT* EXPORT_HELP::findNextComponentAndCreatPinList( EDA_BaseStruct* aI
wxASSERT
(
pin
->
Type
()
==
COMPONENT_PIN_DRAW_TYPE
);
wxASSERT
(
pin
->
Type
()
==
COMPONENT_PIN_DRAW_TYPE
);
A
ddPinToComponentPinList
(
comp
,
aSheetPath
,
pin
);
a
ddPinToComponentPinList
(
comp
,
aSheetPath
,
pin
);
}
}
}
}
...
@@ -366,7 +528,7 @@ SCH_COMPONENT* EXPORT_HELP::findNextComponentAndCreatPinList( EDA_BaseStruct* aI
...
@@ -366,7 +528,7 @@ SCH_COMPONENT* EXPORT_HELP::findNextComponentAndCreatPinList( EDA_BaseStruct* aI
m_SortedComponentPinList
.
end
(),
sortPinsByNum
);
m_SortedComponentPinList
.
end
(),
sortPinsByNum
);
// Remove duplicate Pins in m_SortedComponentPinList
// Remove duplicate Pins in m_SortedComponentPinList
E
raseDuplicatePins
(
m_SortedComponentPinList
);
e
raseDuplicatePins
(
m_SortedComponentPinList
);
return
comp
;
return
comp
;
}
}
...
@@ -386,23 +548,251 @@ static wxXmlNode* Node( const wxString& aName, const wxString& aTextualContent =
...
@@ -386,23 +548,251 @@ static wxXmlNode* Node( const wxString& aName, const wxString& aTextualContent =
{
{
wxXmlNode
*
n
=
new
wxXmlNode
(
0
,
wxXML_ELEMENT_NODE
,
aName
);
wxXmlNode
*
n
=
new
wxXmlNode
(
0
,
wxXML_ELEMENT_NODE
,
aName
);
if
(
aTextualContent
.
Len
()
>
0
)
// excludes wxEmptyString, the
default textual content
if
(
aTextualContent
.
Len
()
>
0
)
// excludes wxEmptyString, the
parameter's default value
n
->
AddChild
(
new
wxXmlNode
(
0
,
wxXML_TEXT_NODE
,
wxEmptyString
,
aTextualContent
)
);
n
->
AddChild
(
new
wxXmlNode
(
0
,
wxXML_TEXT_NODE
,
wxEmptyString
,
aTextualContent
)
);
return
n
;
return
n
;
}
}
/**
wxXmlNode
*
EXPORT_HELP
::
makeGenericDesignHeader
()
* Function Write_GENERIC_NetList
{
* creates a generic netlist, now in XML.
wxXmlNode
*
xdesign
=
Node
(
wxT
(
"design"
)
);
* @return bool - true if there were no errors, else false.
char
date
[
128
];
*/
DateAndTime
(
date
);
// the root sheet is a special sheet, call it source
xdesign
->
AddChild
(
Node
(
wxT
(
"source"
),
g_RootSheet
->
m_AssociatedScreen
->
m_FileName
)
);
xdesign
->
AddChild
(
Node
(
wxT
(
"date"
),
CONV_FROM_UTF8
(
date
))
);
// which eeschema tool
xdesign
->
AddChild
(
Node
(
wxT
(
"tool"
),
wxGetApp
().
GetAppName
()
+
wxChar
(
' '
)
+
GetBuildVersion
()
)
);
/* @todo might do a list of schematic pages
<page name="">
<title/>
<revision/>
<company/>
<comments>
<comment>blah</comment> <!-- comment1 -->
<comment>blah</comment> <!-- comment2 -->
</comments>
<pagesize/>
</page>
and a sheet hierarchy report here
<sheets>
<sheet name="sheetname1" page="pagenameA">
<sheet name="sheetname2" page="pagenameB"/>
</sheet>
</sheets>
*/
return
xdesign
;
}
wxXmlNode
*
EXPORT_HELP
::
makeGenericLibraries
()
{
wxXmlNode
*
xlibs
=
Node
(
wxT
(
"libraries"
)
);
// auto_ptr
for
(
std
::
set
<
CMP_LIBRARY
*>::
iterator
it
=
m_Libraries
.
begin
();
it
!=
m_Libraries
.
end
();
++
it
)
{
wxXmlNode
*
xlibrary
;
xlibs
->
AddChild
(
xlibrary
=
Node
(
wxT
(
"library"
)
)
);
xlibrary
->
AddProperty
(
wxT
(
"logical"
),
(
*
it
)
->
GetLogicalName
()
);
xlibrary
->
AddChild
(
Node
(
wxT
(
"uri"
),
(
*
it
)
->
GetFullFileName
()
)
);
// @todo: add more fun stuff here
}
return
xlibs
;
}
wxXmlNode
*
EXPORT_HELP
::
makeGenericLibParts
()
{
wxXmlNode
*
xlibparts
=
Node
(
wxT
(
"libparts"
)
);
// auto_ptr
wxString
sLibpart
=
wxT
(
"libpart"
);
wxString
sLib
=
wxT
(
"lib"
);
wxString
sPart
=
wxT
(
"part"
);
wxString
sPins
=
wxT
(
"pins"
);
wxString
sPin
=
wxT
(
"pin"
);
wxString
sNum
=
wxT
(
"num"
);
wxString
sName
=
wxT
(
"name"
);
wxString
sField
=
wxT
(
"field"
);
wxString
sFields
=
wxT
(
"fields"
);
wxString
sDescr
=
wxT
(
"description"
);
wxString
sDocs
=
wxT
(
"docs"
);
LIB_PIN_LIST
pinList
;
LIB_FIELD_LIST
fieldList
;
m_Libraries
.
clear
();
for
(
std
::
set
<
LIB_COMPONENT
*>::
iterator
it
=
m_LibParts
.
begin
();
it
!=
m_LibParts
.
end
();
++
it
)
{
CMP_LIBRARY
*
library
=
(
*
it
)
->
GetLibrary
();
m_Libraries
.
insert
(
library
);
// inserts component's library iff unique
wxXmlNode
*
xlibpart
;
xlibparts
->
AddChild
(
xlibpart
=
Node
(
sLibpart
)
);
xlibpart
->
AddProperty
(
sLib
,
library
->
GetLogicalName
()
);
xlibpart
->
AddProperty
(
sPart
,
(
*
it
)
->
GetName
()
);
//----- show the important properties -------------------------
if
(
!
(
*
it
)
->
GetDescription
().
IsEmpty
()
)
xlibpart
->
AddChild
(
Node
(
sDescr
,
(
*
it
)
->
GetDescription
()
)
);
if
(
!
(
*
it
)
->
GetDocFileName
().
IsEmpty
()
)
xlibpart
->
AddChild
(
Node
(
sDocs
,
(
*
it
)
->
GetDocFileName
()
)
);
// @todo show the footprints here.
// (*it)->m_FootprintList
//----- show the fields here ----------------------------------
fieldList
.
clear
();
(
*
it
)
->
GetFields
(
fieldList
);
wxXmlNode
*
xfields
;
xlibpart
->
AddChild
(
xfields
=
Node
(
sFields
)
);
for
(
unsigned
i
=
0
;
i
<
fieldList
.
size
();
++
i
)
{
if
(
!
fieldList
[
i
].
m_Text
.
IsEmpty
()
)
{
wxXmlNode
*
xfield
;
xfields
->
AddChild
(
xfield
=
Node
(
sField
,
fieldList
[
i
].
m_Text
)
);
xfield
->
AddProperty
(
sName
,
fieldList
[
i
].
m_Name
);
}
}
//----- show the pins here ------------------------------------
pinList
.
clear
();
(
*
it
)
->
GetPins
(
pinList
,
0
,
0
);
// sort the pin list here?
if
(
pinList
.
size
()
)
{
wxXmlNode
*
pins
;
xlibpart
->
AddChild
(
pins
=
Node
(
sPins
)
);
for
(
unsigned
i
=
0
;
i
<
pinList
.
size
();
++
i
)
{
wxXmlNode
*
pin
;
pins
->
AddChild
(
pin
=
Node
(
sPin
)
);
pin
->
AddProperty
(
sNum
,
pinList
[
i
]
->
GetNumber
()
);
// caution: construction work site here, drive slowly
}
}
}
return
xlibparts
;
}
wxXmlNode
*
EXPORT_HELP
::
makeGenericListOfNets
()
{
wxXmlNode
*
xnets
=
Node
(
wxT
(
"nets"
)
);
// auto_ptr if exceptions ever get used.
wxString
netCodeTxt
;
wxString
netName
;
wxString
ref
;
wxString
sNet
=
wxT
(
"net"
);
wxString
sName
=
wxT
(
"name"
);
wxString
sCode
=
wxT
(
"code"
);
wxString
sRef
=
wxT
(
"ref"
);
wxString
sPin
=
wxT
(
"pin"
);
wxString
sNode
=
wxT
(
"node"
);
wxString
sFmtd
=
wxT
(
"%d"
);
wxXmlNode
*
xnet
=
0
;
int
netCode
;
int
lastNetCode
=
-
1
;
int
sameNetcodeCount
=
0
;
/* output:
<net code="123" name="/cfcard.sch/WAIT#">
<node ref="R23" pin="1"/>
<node ref="U18" pin="12"/>
</net>
*/
m_LibParts
.
clear
();
// must call this function before using m_LibParts.
for
(
unsigned
ii
=
0
;
ii
<
g_NetObjectslist
.
size
();
ii
++
)
{
NETLIST_OBJECT
*
nitem
=
g_NetObjectslist
[
ii
];
SCH_COMPONENT
*
comp
;
// New net found, write net id;
if
(
(
netCode
=
nitem
->
GetNet
()
)
!=
lastNetCode
)
{
sameNetcodeCount
=
0
;
// item count for this net
netName
.
Empty
();
// Find a label for this net, if it exists.
NETLIST_OBJECT
*
netref
=
nitem
->
m_NetNameCandidate
;
if
(
netref
)
{
if
(
netref
->
m_Type
!=
NET_PINLABEL
&&
netref
->
m_Type
!=
NET_GLOBLABEL
)
{
// usual net name, prefix it by the sheet path
netName
=
netref
->
m_SheetList
.
PathHumanReadable
();
}
netName
+=
netref
->
m_Label
;
}
lastNetCode
=
netCode
;
}
if
(
nitem
->
m_Type
!=
NET_PIN
)
continue
;
comp
=
(
SCH_COMPONENT
*
)
nitem
->
m_Link
;
// Get the reference for the net name and the main parent component
ref
=
comp
->
GetRef
(
&
nitem
->
m_SheetList
);
if
(
ref
[
0
]
==
wxChar
(
'#'
)
)
continue
;
if
(
++
sameNetcodeCount
==
1
)
{
xnets
->
AddChild
(
xnet
=
Node
(
sNet
)
);
netCodeTxt
.
Printf
(
sFmtd
,
netCode
);
xnet
->
AddProperty
(
sCode
,
netCodeTxt
);
xnet
->
AddProperty
(
sName
,
netName
);
}
wxXmlNode
*
xnode
;
xnet
->
AddChild
(
xnode
=
Node
(
sNode
)
);
xnode
->
AddProperty
(
sRef
,
ref
);
xnode
->
AddProperty
(
sPin
,
nitem
->
GetPinNumText
()
);
}
return
xnets
;
}
bool
EXPORT_HELP
::
Write_GENERIC_NetList
(
WinEDA_SchematicFrame
*
frame
,
const
wxString
&
aOutFileName
)
bool
EXPORT_HELP
::
Write_GENERIC_NetList
(
WinEDA_SchematicFrame
*
frame
,
const
wxString
&
aOutFileName
)
{
{
#if 1
#if 1
// output the XML format netlist.
// output the XML format netlist.
wxXmlDocument
xdoc
;
wxXmlDocument
xdoc
;
// tree markers or walkers
// tree markers or walkers
wxXmlNode
*
xroot
;
// root node
wxXmlNode
*
xroot
;
// root node
wxXmlNode
*
xcomps
;
// start of components
wxXmlNode
*
xcomps
;
// start of components
...
@@ -415,6 +805,7 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
...
@@ -415,6 +805,7 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
wxString
timeStamp
;
wxString
timeStamp
;
wxString
logicalLibName
;
wxString
logicalLibName
;
// these are actually constructor invocations, not assignments as it appears:
// these are actually constructor invocations, not assignments as it appears:
const
wxString
sFields
=
wxT
(
"fields"
);
const
wxString
sFields
=
wxT
(
"fields"
);
const
wxString
sField
=
wxT
(
"field"
);
const
wxString
sField
=
wxT
(
"field"
);
...
@@ -436,22 +827,27 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
...
@@ -436,22 +827,27 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
const
wxString
sPart
=
wxT
(
"part"
);
const
wxString
sPart
=
wxT
(
"part"
);
const
wxString
sNames
=
wxT
(
"names"
);
const
wxString
sNames
=
wxT
(
"names"
);
m_ReferencesAlreadyFound
.
Clear
();
m_ReferencesAlreadyFound
.
Clear
();
xdoc
.
SetRoot
(
xroot
=
Node
(
wxT
(
"netlist"
)
)
);
xdoc
.
SetRoot
(
xroot
=
Node
(
wxT
(
"netlist"
)
)
);
xroot
->
AddProperty
(
wxT
(
"version"
),
wxT
(
"B"
)
);
xroot
->
AddProperty
(
wxT
(
"version"
),
wxT
(
"C"
)
);
// add the "design" header
xroot
->
AddChild
(
makeGenericDesignHeader
()
);
xroot
->
AddChild
(
xcomps
=
Node
(
wxT
(
"components"
)
)
);
xroot
->
AddChild
(
xcomps
=
Node
(
wxT
(
"components"
)
)
);
SCH_SHEET_LIST
sheetList
;
SCH_SHEET_LIST
sheetList
;
// output is xml, so there is no reason to remove spaces from the field values.
// Output is xml, so there is no reason to remove spaces from the field values.
// And XML element names need not be translated to various languages.
for
(
SCH_SHEET_PATH
*
path
=
sheetList
.
GetFirst
();
path
;
path
=
sheetList
.
GetNext
()
)
for
(
SCH_SHEET_PATH
*
path
=
sheetList
.
GetFirst
();
path
;
path
=
sheetList
.
GetNext
()
)
{
{
for
(
EDA_BaseStruct
*
schItem
=
path
->
LastDrawList
();
schItem
;
schItem
=
schItem
->
Next
()
)
for
(
EDA_BaseStruct
*
schItem
=
path
->
LastDrawList
();
schItem
;
schItem
=
schItem
->
Next
()
)
{
{
SCH_COMPONENT
*
comp
=
findNextComponent
AndCreatPinList
(
schItem
,
path
);
SCH_COMPONENT
*
comp
=
findNextComponent
(
schItem
,
path
);
if
(
!
comp
)
if
(
!
comp
)
break
;
// No component left
break
;
// No component left
...
@@ -505,7 +901,7 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
...
@@ -505,7 +901,7 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
// is merely the library name minus path and extension.
// is merely the library name minus path and extension.
LIB_COMPONENT
*
entry
=
CMP_LIBRARY
::
FindLibraryComponent
(
comp
->
m_ChipName
);
LIB_COMPONENT
*
entry
=
CMP_LIBRARY
::
FindLibraryComponent
(
comp
->
m_ChipName
);
if
(
entry
)
if
(
entry
)
xlibsource
->
AddProperty
(
sLib
,
entry
->
GetLibrary
()
->
GetLogicalName
()
);
xlibsource
->
AddProperty
(
sLib
,
entry
->
GetLibrary
()
->
GetLogicalName
()
);
xlibsource
->
AddProperty
(
sPart
,
comp
->
m_ChipName
);
xlibsource
->
AddProperty
(
sPart
,
comp
->
m_ChipName
);
wxXmlNode
*
xsheetpath
;
wxXmlNode
*
xsheetpath
;
...
@@ -518,16 +914,16 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
...
@@ -518,16 +914,16 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
}
}
}
}
// @todo generate the nested <libpart> s
xroot
->
AddChild
(
makeGenericLibParts
()
);
xroot
->
AddChild
(
Node
(
wxT
(
"libparts"
)
)
);
wxXmlNode
*
xnets
;
// must follow makeGenericLibParts()
xroot
->
AddChild
(
xnets
=
Node
(
wxT
(
"nets"
)
)
);
xroot
->
AddChild
(
makeGenericLibraries
()
);
WriteGENERICListOfNets
(
xnets
,
g_NetObjectslist
);
xroot
->
AddChild
(
makeGenericListOfNets
()
);
return
xdoc
.
Save
(
aOutFileName
,
2
/* indent bug, today was ignored by wxXml lib */
);
return
xdoc
.
Save
(
aOutFileName
,
2
/* indent bug, today was ignored by wxXml lib */
);
#else // ouput the well established/old net list format which was not XML.
#else // ouput the well established/old
generic
net list format which was not XML.
wxString
field
;
wxString
field
;
wxString
footprint
;
wxString
footprint
;
...
@@ -592,7 +988,7 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
...
@@ -592,7 +988,7 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
if
(
!
Pin
)
if
(
!
Pin
)
continue
;
continue
;
netname
=
ReturnPinNetName
(
Pin
,
wxT
(
"$-%.6d"
)
);
sprintPinNetName
(
&
netname
,
wxT
(
"$-%.6d"
),
Pin
);
if
(
netname
.
IsEmpty
()
)
if
(
netname
.
IsEmpty
()
)
netname
=
wxT
(
"?"
);
netname
=
wxT
(
"?"
);
...
@@ -608,7 +1004,7 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
...
@@ -608,7 +1004,7 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
ret
|=
fprintf
(
out
,
"
\n
$BeginNets
\n
"
);
ret
|=
fprintf
(
out
,
"
\n
$BeginNets
\n
"
);
if
(
!
WriteGENERICListOfNetsTxt
(
out
,
g_NetObjectslist
)
)
if
(
!
writeGENERICListOfNets
(
out
,
g_NetObjectslist
)
)
ret
=
-
1
;
ret
=
-
1
;
ret
|=
fprintf
(
out
,
"$EndNets
\n
"
);
ret
|=
fprintf
(
out
,
"$EndNets
\n
"
);
...
@@ -621,25 +1017,14 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
...
@@ -621,25 +1017,14 @@ bool EXPORT_HELP::Write_GENERIC_NetList( WinEDA_SchematicFrame* frame, const wxS
}
}
/* Routine generation of the netlist file (Format PSPICE)
bool
EXPORT_HELP
::
WriteNetListPspice
(
WinEDA_SchematicFrame
*
frame
,
FILE
*
f
,
bool
use_netnames
)
* = TRUE if use_netnames
* Nodes are identified by the netname
* If the nodes are identified by the netnumber
*
* All graphics text commentary by a [.-+] PSpice or [.-+] gnucap
* Are considered in placing orders in the netlist
* [.-] Or PSpice gnucap are beginning
* + + Gnucap and PSpice are ultimately NetList
*/
void
EXPORT_HELP
::
WriteNetListPspice
(
WinEDA_SchematicFrame
*
frame
,
FILE
*
f
,
bool
use_netnames
)
{
{
int
ret
=
0
;
char
Line
[
1024
];
char
Line
[
1024
];
SCH_SHEET_PATH
*
sheet
;
EDA_BaseStruct
*
DrawList
;
SCH_COMPONENT
*
Component
;
int
nbitems
;
int
nbitems
;
wxString
text
;
wxString
text
;
wxArrayString
SpiceCommandAtBeginFile
,
SpiceCommandAtEndFile
;
wxArrayString
spiceCommandAtBeginFile
;
wxArrayString
spiceCommandAtEndFile
;
wxString
msg
;
wxString
msg
;
wxString
netName
;
wxString
netName
;
...
@@ -647,31 +1032,28 @@ void EXPORT_HELP::WriteNetListPspice( WinEDA_SchematicFrame* frame, FILE* f, boo
...
@@ -647,31 +1032,28 @@ void EXPORT_HELP::WriteNetListPspice( WinEDA_SchematicFrame* frame, FILE* f, boo
wxChar
bufnum
[
BUFYPOS_LEN
+
1
];
wxChar
bufnum
[
BUFYPOS_LEN
+
1
];
DateAndTime
(
Line
);
DateAndTime
(
Line
);
fprintf
(
f
,
"* %s (Spice format) creation date: %s
\n\n
"
,
ret
|=
fprintf
(
f
,
"* %s (Spice format) creation date: %s
\n\n
"
,
NETLIST_HEAD_STRING
,
NETLIST_HEAD_STRING
,
Line
);
Line
);
// Create text list starting by [.-]pspice , or [.-]gnucap (simulator
/* Create text list starting by [.-]pspice , or [.-]gnucap (simulator
// commands) and create text list starting by [+]pspice , or [+]gnucap
* commands) and create text list starting by [+]pspice , or [+]gnucap
// (simulator commands)
* (simulator commands) */
bufnum
[
BUFYPOS_LEN
]
=
0
;
bufnum
[
BUFYPOS_LEN
]
=
0
;
SCH_SHEET_LIST
S
heetList
;
SCH_SHEET_LIST
s
heetList
;
for
(
sheet
=
SheetList
.
GetFirst
();
for
(
SCH_SHEET_PATH
*
sheet
=
sheetList
.
GetFirst
();
sheet
;
sheet
=
sheetList
.
GetNext
()
)
sheet
!=
NULL
;
sheet
=
SheetList
.
GetNext
()
)
{
{
for
(
DrawList
=
sheet
->
LastDrawList
();
for
(
EDA_BaseStruct
*
item
=
sheet
->
LastDrawList
();
item
;
item
=
item
->
Next
()
)
DrawList
!=
NULL
;
DrawList
=
DrawList
->
Next
()
)
{
{
wxChar
ident
;
wxChar
ident
;
if
(
DrawList
->
Type
()
!=
TYPE_SCH_TEXT
)
if
(
item
->
Type
()
!=
TYPE_SCH_TEXT
)
continue
;
continue
;
#define DRAWTEXT ( (SCH_TEXT*) DrawList )
SCH_TEXT
*
drawText
=
(
SCH_TEXT
*
)
item
;
text
=
DRAWTEXT
->
m_Text
;
if
(
text
.
IsEmpty
()
)
text
=
drawText
->
m_Text
;
if
(
text
.
IsEmpty
()
)
continue
;
continue
;
ident
=
text
.
GetChar
(
0
);
ident
=
text
.
GetChar
(
0
);
...
@@ -683,105 +1065,109 @@ void EXPORT_HELP::WriteNetListPspice( WinEDA_SchematicFrame* frame, FILE* f, boo
...
@@ -683,105 +1065,109 @@ void EXPORT_HELP::WriteNetListPspice( WinEDA_SchematicFrame* frame, FILE* f, boo
text
.
MakeLower
();
text
.
MakeLower
();
if
(
(
text
==
wxT
(
"pspice"
)
)
||
(
text
==
wxT
(
"gnucap"
)
)
)
if
(
(
text
==
wxT
(
"pspice"
)
)
||
(
text
==
wxT
(
"gnucap"
)
)
)
{
{
/
*
Put the Y position as an ascii string, for sort by vertical
/
/
Put the Y position as an ascii string, for sort by vertical
* position, using usual sort string by alphabetic value */
// position, using usual sort string by alphabetic value
int
ypos
=
DRAWTEXT
->
m_Pos
.
y
;
int
ypos
=
drawText
->
m_Pos
.
y
;
for
(
int
ii
=
0
;
ii
<
BUFYPOS_LEN
;
ii
++
)
for
(
int
ii
=
0
;
ii
<
BUFYPOS_LEN
;
ii
++
)
{
{
bufnum
[
BUFYPOS_LEN
-
1
-
bufnum
[
BUFYPOS_LEN
-
1
-
ii
]
=
(
ypos
&
63
)
+
' '
;
ypos
>>=
6
;
ii
]
=
(
ypos
&
63
)
+
' '
;
ypos
>>=
6
;
}
}
text
=
DRAWTEXT
->
m_Text
.
AfterFirst
(
' '
);
text
=
drawText
->
m_Text
.
AfterFirst
(
' '
);
// First BUFYPOS_LEN char are the Y position.
// First BUFYPOS_LEN char are the Y position.
msg
.
Printf
(
wxT
(
"%s %s"
),
bufnum
,
text
.
GetData
()
);
msg
.
Printf
(
wxT
(
"%s %s"
),
bufnum
,
text
.
GetData
()
);
if
(
ident
==
'+'
)
if
(
ident
==
'+'
)
S
piceCommandAtEndFile
.
Add
(
msg
);
s
piceCommandAtEndFile
.
Add
(
msg
);
else
else
S
piceCommandAtBeginFile
.
Add
(
msg
);
s
piceCommandAtBeginFile
.
Add
(
msg
);
}
}
}
}
}
}
/
*
Print texts starting by [.-]pspice , ou [.-]gnucap (of course, without
/
/
Print texts starting by [.-]pspice , ou [.-]gnucap (of course, without
* the Y position string)*/
// the Y position string)
nbitems
=
S
piceCommandAtBeginFile
.
GetCount
();
nbitems
=
s
piceCommandAtBeginFile
.
GetCount
();
if
(
nbitems
)
if
(
nbitems
)
{
{
S
piceCommandAtBeginFile
.
Sort
();
s
piceCommandAtBeginFile
.
Sort
();
for
(
int
ii
=
0
;
ii
<
nbitems
;
ii
++
)
for
(
int
ii
=
0
;
ii
<
nbitems
;
ii
++
)
{
{
S
piceCommandAtBeginFile
[
ii
].
Remove
(
0
,
BUFYPOS_LEN
);
s
piceCommandAtBeginFile
[
ii
].
Remove
(
0
,
BUFYPOS_LEN
);
SpiceCommandAtBeginFile
[
ii
].
Trim
(
TRUE
);
spiceCommandAtBeginFile
[
ii
].
Trim
(
true
);
SpiceCommandAtBeginFile
[
ii
].
Trim
(
FALSE
);
spiceCommandAtBeginFile
[
ii
].
Trim
(
false
);
fprintf
(
f
,
"%s
\n
"
,
CONV_TO_UTF8
(
S
piceCommandAtBeginFile
[
ii
]
)
);
ret
|=
fprintf
(
f
,
"%s
\n
"
,
CONV_TO_UTF8
(
s
piceCommandAtBeginFile
[
ii
]
)
);
}
}
}
}
fprintf
(
f
,
"
\n
"
);
ret
|=
fprintf
(
f
,
"
\n
"
);
// Create component list
// Create component list
m_ReferencesAlreadyFound
.
Clear
();
m_ReferencesAlreadyFound
.
Clear
();
for
(
sheet
=
SheetList
.
GetFirst
();
sheet
!=
NULL
;
sheet
=
S
heetList
.
GetNext
()
)
for
(
SCH_SHEET_PATH
*
sheet
=
sheetList
.
GetFirst
();
sheet
;
sheet
=
s
heetList
.
GetNext
()
)
{
{
for
(
DrawList
=
sheet
->
LastDrawList
();
DrawList
!=
NULL
;
DrawList
=
DrawList
->
Next
()
)
for
(
EDA_BaseStruct
*
item
=
sheet
->
LastDrawList
();
item
;
item
=
item
->
Next
()
)
{
{
DrawList
=
Component
=
findNextComponentAndCreatPinList
(
DrawList
,
sheet
);
SCH_COMPONENT
*
comp
=
findNextComponentAndCreatPinList
(
item
,
sheet
);
if
(
Component
==
NULL
)
if
(
!
comp
)
break
;
break
;
fprintf
(
f
,
"%s "
,
CONV_TO_UTF8
(
Component
->
GetRef
(
sheet
)
)
);
item
=
comp
;
ret
|=
fprintf
(
f
,
"%s "
,
CONV_TO_UTF8
(
comp
->
GetRef
(
sheet
)
)
);
// Write pin list:
// Write pin list:
for
(
unsigned
ii
=
0
;
ii
<
m_SortedComponentPinList
.
size
();
ii
++
)
for
(
unsigned
ii
=
0
;
ii
<
m_SortedComponentPinList
.
size
();
ii
++
)
{
{
NETLIST_OBJECT
*
P
in
=
m_SortedComponentPinList
[
ii
];
NETLIST_OBJECT
*
p
in
=
m_SortedComponentPinList
[
ii
];
if
(
!
P
in
)
if
(
!
p
in
)
continue
;
continue
;
sprintPinNetName
(
&
netName
,
wxT
(
"N-%.6d"
),
P
in
);
sprintPinNetName
(
&
netName
,
wxT
(
"N-%.6d"
),
p
in
);
if
(
netName
.
IsEmpty
()
)
if
(
netName
.
IsEmpty
()
)
netName
=
wxT
(
"?"
);
netName
=
wxT
(
"?"
);
if
(
use_netnames
)
if
(
use_netnames
)
fprintf
(
f
,
" %s"
,
CONV_TO_UTF8
(
netName
)
);
ret
|=
fprintf
(
f
,
" %s"
,
CONV_TO_UTF8
(
netName
)
);
else
// Use number for net names (with net number = 0 for
// "GND"
else
// Use number for net names (net number = 0 for "GND")
{
{
// NetName = "0" is "GND" net for Spice
// NetName = "0" is "GND" net for Spice
if
(
netName
==
wxT
(
"0"
)
||
netName
==
wxT
(
"GND"
)
)
if
(
netName
==
wxT
(
"0"
)
||
netName
==
wxT
(
"GND"
)
)
fprintf
(
f
,
" 0"
);
ret
|=
fprintf
(
f
,
" 0"
);
else
else
fprintf
(
f
,
" %d"
,
P
in
->
GetNet
()
);
ret
|=
fprintf
(
f
,
" %d"
,
p
in
->
GetNet
()
);
}
}
}
}
fprintf
(
f
,
" %s
\n
"
,
ret
|=
fprintf
(
f
,
" %s
\n
"
,
CONV_TO_UTF8
(
Component
->
GetField
(
VALUE
)
->
m_Text
)
);
CONV_TO_UTF8
(
comp
->
GetField
(
VALUE
)
->
m_Text
)
);
}
}
}
}
m_SortedComponentPinList
.
clear
();
m_SortedComponentPinList
.
clear
();
/
* Print texts starting by [+]pspice , ou [+]gnucap */
/
/ Print texts starting with [+]pspice or [+]gnucap
nbitems
=
S
piceCommandAtEndFile
.
GetCount
();
nbitems
=
s
piceCommandAtEndFile
.
GetCount
();
if
(
nbitems
)
if
(
nbitems
)
{
{
fprintf
(
f
,
"
\n
"
);
ret
|=
fprintf
(
f
,
"
\n
"
);
S
piceCommandAtEndFile
.
Sort
();
s
piceCommandAtEndFile
.
Sort
();
for
(
int
ii
=
0
;
ii
<
nbitems
;
ii
++
)
for
(
int
ii
=
0
;
ii
<
nbitems
;
ii
++
)
{
{
S
piceCommandAtEndFile
[
ii
].
Remove
(
0
,
+
BUFYPOS_LEN
);
s
piceCommandAtEndFile
[
ii
].
Remove
(
0
,
+
BUFYPOS_LEN
);
SpiceCommandAtEndFile
[
ii
].
Trim
(
TRUE
);
spiceCommandAtEndFile
[
ii
].
Trim
(
true
);
SpiceCommandAtEndFile
[
ii
].
Trim
(
FALSE
);
spiceCommandAtEndFile
[
ii
].
Trim
(
false
);
fprintf
(
f
,
"%s
\n
"
,
CONV_TO_UTF8
(
S
piceCommandAtEndFile
[
ii
]
)
);
ret
|=
fprintf
(
f
,
"%s
\n
"
,
CONV_TO_UTF8
(
s
piceCommandAtEndFile
[
ii
]
)
);
}
}
}
}
fprintf
(
f
,
"
\n
.end
\n
"
);
ret
|=
fprintf
(
f
,
"
\n
.end
\n
"
);
return
ret
>=
0
;
}
}
...
@@ -922,7 +1308,7 @@ bool EXPORT_HELP::WriteNetListPCBNEW( WinEDA_SchematicFrame* frame, FILE* f, boo
...
@@ -922,7 +1308,7 @@ bool EXPORT_HELP::WriteNetListPCBNEW( WinEDA_SchematicFrame* frame, FILE* f, boo
{
{
ret
|=
fprintf
(
f
,
"{ Pin List by Nets
\n
"
);
ret
|=
fprintf
(
f
,
"{ Pin List by Nets
\n
"
);
if
(
!
WriteGENERICListOfNetsTxt
(
f
,
g_NetObjectslist
)
)
if
(
!
writeGENERICListOfNets
(
f
,
g_NetObjectslist
)
)
ret
=
-
1
;
ret
=
-
1
;
ret
|=
fprintf
(
f
,
"}
\n
"
);
ret
|=
fprintf
(
f
,
"}
\n
"
);
...
@@ -933,12 +1319,7 @@ bool EXPORT_HELP::WriteNetListPCBNEW( WinEDA_SchematicFrame* frame, FILE* f, boo
...
@@ -933,12 +1319,7 @@ bool EXPORT_HELP::WriteNetListPCBNEW( WinEDA_SchematicFrame* frame, FILE* f, boo
}
}
/*
bool
EXPORT_HELP
::
addPinToComponentPinList
(
SCH_COMPONENT
*
aComponent
,
* Add a new pin description in the pin list m_SortedComponentPinList
* a pin description is a pointer to the corresponding structure
* created by BuildNetList() in the table g_NetObjectslist
*/
bool
EXPORT_HELP
::
AddPinToComponentPinList
(
SCH_COMPONENT
*
aComponent
,
SCH_SHEET_PATH
*
aSheetPath
,
LIB_PIN
*
aPin
)
SCH_SHEET_PATH
*
aSheetPath
,
LIB_PIN
*
aPin
)
{
{
// Search the PIN description for Pin in g_NetObjectslist
// Search the PIN description for Pin in g_NetObjectslist
...
@@ -964,7 +1345,7 @@ bool EXPORT_HELP::AddPinToComponentPinList( SCH_COMPONENT* aComponent,
...
@@ -964,7 +1345,7 @@ bool EXPORT_HELP::AddPinToComponentPinList( SCH_COMPONENT* aComponent,
if
(
m_SortedComponentPinList
.
size
()
>=
MAXPIN
)
if
(
m_SortedComponentPinList
.
size
()
>=
MAXPIN
)
{
{
// Log message for Internal error
// Log message for Internal error
DisplayError
(
NULL
,
wxT
(
"
A
ddPinToComponentPinList err: MAXPIN reached"
)
);
DisplayError
(
NULL
,
wxT
(
"
a
ddPinToComponentPinList err: MAXPIN reached"
)
);
}
}
return
true
;
// we're done, we appended.
return
true
;
// we're done, we appended.
...
@@ -974,21 +1355,7 @@ bool EXPORT_HELP::AddPinToComponentPinList( SCH_COMPONENT* aComponent,
...
@@ -974,21 +1355,7 @@ bool EXPORT_HELP::AddPinToComponentPinList( SCH_COMPONENT* aComponent,
}
}
/** Function EraseDuplicatePins
void
EXPORT_HELP
::
eraseDuplicatePins
(
NETLIST_OBJECT_LIST
&
aPinList
)
* Function to remove duplicate Pins in the TabPin pin list
* (This is a list of pins found in the whole schematic, for a given
* component)
* These duplicate pins were put in list because some pins (powers... )
* are found more than one time when we have a multiple parts per package
* component
* for instance, a 74ls00 has 4 parts, and therefore the VCC pin and GND pin
* appears 4 times
* in the list.
* @param aPinList = a NETLIST_OBJECT_LIST that contains the list of pins for a
* given component.
* Note: this list *MUST* be sorted by pin number (.m_PinNum member value)
*/
void
EXPORT_HELP
::
EraseDuplicatePins
(
NETLIST_OBJECT_LIST
&
aPinList
)
{
{
if
(
aPinList
.
size
()
==
0
)
// Trivial case: component with no pin
if
(
aPinList
.
size
()
==
0
)
// Trivial case: component with no pin
return
;
return
;
...
@@ -1035,15 +1402,7 @@ void EXPORT_HELP::EraseDuplicatePins( NETLIST_OBJECT_LIST& aPinList )
...
@@ -1035,15 +1402,7 @@ void EXPORT_HELP::EraseDuplicatePins( NETLIST_OBJECT_LIST& aPinList )
}
}
/**
void
EXPORT_HELP
::
findAllInstancesOfComponent
(
SCH_COMPONENT
*
aComponent
,
* Function FindAllInstancesOfComponent
* is used for "multiple parts per package" components.
*
* Search all instances of Component_in,
* Calls AddPinToComponentPinList() to and pins founds to the current
* component pin list
*/
void
EXPORT_HELP
::
FindAllInstancesOfComponent
(
SCH_COMPONENT
*
aComponent
,
LIB_COMPONENT
*
aEntry
,
LIB_COMPONENT
*
aEntry
,
SCH_SHEET_PATH
*
aSheetPath
)
SCH_SHEET_PATH
*
aSheetPath
)
{
{
...
@@ -1054,42 +1413,38 @@ void EXPORT_HELP::FindAllInstancesOfComponent( SCH_COMPONENT* aComponent,
...
@@ -1054,42 +1413,38 @@ void EXPORT_HELP::FindAllInstancesOfComponent( SCH_COMPONENT* aComponent,
for
(
SCH_SHEET_PATH
*
sheet
=
sheetList
.
GetFirst
();
sheet
;
sheet
=
sheetList
.
GetNext
()
)
for
(
SCH_SHEET_PATH
*
sheet
=
sheetList
.
GetFirst
();
sheet
;
sheet
=
sheetList
.
GetNext
()
)
{
{
for
(
EDA_BaseStruct
*
schItem
=
sheet
->
LastDrawList
();
schItem
;
schItem
=
schI
tem
->
Next
()
)
for
(
EDA_BaseStruct
*
item
=
sheet
->
LastDrawList
();
item
;
item
=
i
tem
->
Next
()
)
{
{
if
(
schI
tem
->
Type
()
!=
TYPE_SCH_COMPONENT
)
if
(
i
tem
->
Type
()
!=
TYPE_SCH_COMPONENT
)
continue
;
continue
;
SCH_COMPONENT
*
comp2
=
(
SCH_COMPONENT
*
)
schI
tem
;
SCH_COMPONENT
*
comp2
=
(
SCH_COMPONENT
*
)
i
tem
;
ref2
=
comp2
->
GetRef
(
sheet
);
ref2
=
comp2
->
GetRef
(
sheet
);
if
(
ref2
.
CmpNoCase
(
ref
)
!=
0
)
if
(
ref2
.
CmpNoCase
(
ref
)
!=
0
)
continue
;
continue
;
if
(
aEntry
==
NULL
)
int
unit2
=
comp2
->
GetUnitSelection
(
aSheetPath
);
// slow
continue
;
for
(
LIB_PIN
*
pin
=
aEntry
->
GetNextPin
();
pin
;
pin
=
aEntry
->
GetNextPin
(
pin
)
)
for
(
LIB_PIN
*
pin
=
aEntry
->
GetNextPin
();
pin
;
pin
=
aEntry
->
GetNextPin
(
pin
)
)
{
{
wxASSERT
(
pin
->
Type
()
==
COMPONENT_PIN_DRAW_TYPE
);
wxASSERT
(
pin
->
Type
()
==
COMPONENT_PIN_DRAW_TYPE
);
if
(
pin
->
m_Unit
&&
pin
->
m_Unit
!=
comp2
->
GetUnitSelection
(
aSheetPath
)
)
if
(
pin
->
m_Unit
&&
pin
->
m_Unit
!=
unit2
)
continue
;
continue
;
if
(
pin
->
m_Convert
&&
pin
->
m_Convert
!=
comp2
->
m_Convert
)
if
(
pin
->
m_Convert
&&
pin
->
m_Convert
!=
comp2
->
m_Convert
)
continue
;
continue
;
// A suitable pin is found: add it to the current list
// A suitable pin is found: add it to the current list
A
ddPinToComponentPinList
(
comp2
,
sheet
,
pin
);
a
ddPinToComponentPinList
(
comp2
,
sheet
,
pin
);
}
}
}
}
}
}
}
}
/* Written in the file / net list (ranked by Netcode), and elements that are
bool
EXPORT_HELP
::
writeGENERICListOfNets
(
FILE
*
f
,
NETLIST_OBJECT_LIST
&
aObjectsList
)
* connected
*/
bool
EXPORT_HELP
::
WriteGENERICListOfNetsTxt
(
FILE
*
f
,
NETLIST_OBJECT_LIST
&
aObjectsList
)
{
{
int
ret
=
0
;
int
ret
=
0
;
int
netCode
;
int
netCode
;
...
@@ -1175,121 +1530,10 @@ bool EXPORT_HELP::WriteGENERICListOfNetsTxt( FILE* f, NETLIST_OBJECT_LIST& aObje
...
@@ -1175,121 +1530,10 @@ bool EXPORT_HELP::WriteGENERICListOfNetsTxt( FILE* f, NETLIST_OBJECT_LIST& aObje
}
}
/**
* Function WriteGENERICListOfNets
* saves a netlist in xml format.
*/
bool
EXPORT_HELP
::
WriteGENERICListOfNets
(
wxXmlNode
*
aNode
,
NETLIST_OBJECT_LIST
&
aObjectsList
)
{
wxString
netCodeTxt
;
wxString
netName
;
wxString
ref
;
wxString
sNet
=
wxT
(
"net"
);
wxString
sName
=
wxT
(
"name"
);
wxString
sCode
=
wxT
(
"code"
);
wxString
sRef
=
wxT
(
"ref"
);
wxString
sPin
=
wxT
(
"pin"
);
wxString
sNode
=
wxT
(
"node"
);
wxString
sFmtd
=
wxT
(
"%d"
);
wxXmlNode
*
xnet
=
0
;
int
netCode
;
int
lastNetCode
=
-
1
;
int
sameNetcodeCount
=
0
;
/* output:
<net code="123" name="/cfcard.sch/WAIT#">
<node ref="R23" pin="1"/>
<node ref="U18" pin="12"/>
</net>
*/
for
(
unsigned
ii
=
0
;
ii
<
aObjectsList
.
size
();
ii
++
)
{
SCH_COMPONENT
*
comp
;
// New net found, write net id;
if
(
(
netCode
=
aObjectsList
[
ii
]
->
GetNet
()
)
!=
lastNetCode
)
{
sameNetcodeCount
=
0
;
// item count for this net
netName
.
Empty
();
// Find a label for this net, if it exists.
NETLIST_OBJECT
*
netref
=
aObjectsList
[
ii
]
->
m_NetNameCandidate
;
if
(
netref
)
{
if
(
netref
->
m_Type
!=
NET_PINLABEL
&&
netref
->
m_Type
!=
NET_GLOBLABEL
)
{
// usual net name, prefix it by the sheet path
netName
=
netref
->
m_SheetList
.
PathHumanReadable
();
}
netName
+=
netref
->
m_Label
;
}
lastNetCode
=
netCode
;
}
if
(
aObjectsList
[
ii
]
->
m_Type
!=
NET_PIN
)
continue
;
comp
=
(
SCH_COMPONENT
*
)
aObjectsList
[
ii
]
->
m_Link
;
// Get the reference for the net name and the main parent component
ref
=
comp
->
GetRef
(
&
aObjectsList
[
ii
]
->
m_SheetList
);
if
(
ref
[
0
]
==
wxChar
(
'#'
)
)
continue
;
if
(
++
sameNetcodeCount
==
1
)
{
aNode
->
AddChild
(
xnet
=
Node
(
sNet
)
);
netCodeTxt
.
Printf
(
sFmtd
,
netCode
);
xnet
->
AddProperty
(
sCode
,
netCodeTxt
);
xnet
->
AddProperty
(
sName
,
netName
);
}
wxXmlNode
*
xnode
;
xnet
->
AddChild
(
xnode
=
Node
(
sNode
)
);
xnode
->
AddProperty
(
sRef
,
ref
);
xnode
->
AddProperty
(
sPin
,
LIB_PIN
::
ReturnPinStringNum
(
aObjectsList
[
ii
]
->
m_PinNum
)
);
}
return
true
;
}
/* Generate CADSTAR net list. */
/* Generate CADSTAR net list. */
wxString
StartLine
(
wxT
(
"."
)
);
wxString
StartLine
(
wxT
(
"."
)
);
/* Routine generation of the netlist file (CADSTAR Format)
* Header:
* HEA ..
* TIM .. 2004 07 29 16 22 17
* APA .. "Cadstar RINF Output - Version 6.0.2.3"
* INCH UNI .. 1000.0 in
* FULL TYP ..
*
* List of components:
* .. ADD_COM X1 "CNT D41612 (48pts CONTOUR TM)"
* .. ADD_COM U2 "74HCT245D" "74HCT245D"
*
* Connections:
* .. ADD_TER RR2 * 6 "$ 42"
* .. B U1 100
* 6 CA
*
* ADD_TER .. U2 * 6 "$ 59"
* .. B * U7 39
* U6 17
* U1 * 122
*
* .. ADD_TER P2 * 1 "$ 9"
* .. B * T3 1
*U1 * 14
*/
void
EXPORT_HELP
::
WriteNetListCADSTAR
(
WinEDA_SchematicFrame
*
frame
,
FILE
*
f
)
void
EXPORT_HELP
::
WriteNetListCADSTAR
(
WinEDA_SchematicFrame
*
frame
,
FILE
*
f
)
{
{
wxString
StartCmpDesc
=
StartLine
+
wxT
(
"ADD_COM"
);
wxString
StartCmpDesc
=
StartLine
+
wxT
(
"ADD_COM"
);
...
@@ -1347,21 +1591,13 @@ void EXPORT_HELP::WriteNetListCADSTAR( WinEDA_SchematicFrame* frame, FILE* f )
...
@@ -1347,21 +1591,13 @@ void EXPORT_HELP::WriteNetListCADSTAR( WinEDA_SchematicFrame* frame, FILE* f )
m_SortedComponentPinList
.
clear
();
m_SortedComponentPinList
.
clear
();
W
riteListOfNetsCADSTAR
(
f
,
g_NetObjectslist
);
w
riteListOfNetsCADSTAR
(
f
,
g_NetObjectslist
);
fprintf
(
f
,
"
\n
%sEND
\n
"
,
CONV_TO_UTF8
(
StartLine
)
);
fprintf
(
f
,
"
\n
%sEND
\n
"
,
CONV_TO_UTF8
(
StartLine
)
);
}
}
/*
void
EXPORT_HELP
::
writeListOfNetsCADSTAR
(
FILE
*
f
,
NETLIST_OBJECT_LIST
&
aObjectsList
)
* Written in the file / net list (ranked by Netcode), and
* Pins connected to it
* Format:
*. ADD_TER RR2 6 "$ 42"
*. B U1 100
* 6 CA
*/
void
EXPORT_HELP
::
WriteListOfNetsCADSTAR
(
FILE
*
f
,
NETLIST_OBJECT_LIST
&
aObjectsList
)
{
{
wxString
InitNetDesc
=
StartLine
+
wxT
(
"ADD_TER"
);
wxString
InitNetDesc
=
StartLine
+
wxT
(
"ADD_TER"
);
wxString
StartNetDesc
=
StartLine
+
wxT
(
"TER"
);
wxString
StartNetDesc
=
StartLine
+
wxT
(
"TER"
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment