Merge new generic netlist work, code cleaning, and BOM fixes
This commit is contained in:
commit
8d777fc6d9
|
@ -4,6 +4,20 @@ KiCad ChangeLog 2010
|
||||||
Please add newer entries at the top, list the date and your name with
|
Please add newer entries at the top, list the date and your name with
|
||||||
email address.
|
email address.
|
||||||
|
|
||||||
|
2010-Jul-30 UPDATE Dick Hollenbeck <dick@softplc.com>
|
||||||
|
================================================================================
|
||||||
|
++eeschema:
|
||||||
|
* Now link with XML support within wxWidgets.
|
||||||
|
* Start of export the generic netlist in XML. Still need to rework the chain
|
||||||
|
loaded netlist plugin.
|
||||||
|
* OBJ_CMP_TO_LIST class now uses a std::string to hold the 8 bit string m_Ref,
|
||||||
|
but hides this behind accessors which provide for both Unicode and 8 bit
|
||||||
|
set and get functions.
|
||||||
|
* build_BOM.cpp retains the selected filename on subsequent runs as a default.
|
||||||
|
* Code cleaning, especially in build_BOM.cpp.
|
||||||
|
* Will work tomorrow also.
|
||||||
|
|
||||||
|
|
||||||
2010-jul-27, UPDATE Jean-Pierre Charras <jean-pierre.charras@gipsa-lab.inpg.fr>
|
2010-jul-27, UPDATE Jean-Pierre Charras <jean-pierre.charras@gipsa-lab.inpg.fr>
|
||||||
================================================================================
|
================================================================================
|
||||||
++all:
|
++all:
|
||||||
|
|
|
@ -134,9 +134,9 @@ check_find_package_result(OPENGL_FOUND "OpenGL")
|
||||||
|
|
||||||
# On Apple only wxwidgets 2.9 or higher doesn't need to find aui part of base
|
# On Apple only wxwidgets 2.9 or higher doesn't need to find aui part of base
|
||||||
if(APPLE)
|
if(APPLE)
|
||||||
find_package(wxWidgets COMPONENTS gl adv html core net base QUIET)
|
find_package(wxWidgets COMPONENTS gl adv html core net base xml QUIET)
|
||||||
else(APPLE)
|
else(APPLE)
|
||||||
find_package(wxWidgets COMPONENTS gl aui adv html core net base QUIET)
|
find_package(wxWidgets COMPONENTS gl aui adv html core net base xml QUIET)
|
||||||
endif(APPLE)
|
endif(APPLE)
|
||||||
check_find_package_result(wxWidgets_FOUND "wxWidgets")
|
check_find_package_result(wxWidgets_FOUND "wxWidgets")
|
||||||
|
|
||||||
|
|
|
@ -381,8 +381,7 @@ int AddComponentsInSheetToList( std::vector <OBJ_CMP_TO_LIST>& aComponentsList,
|
||||||
if( DrawLibItem->GetRef( aSheet ).IsEmpty() )
|
if( DrawLibItem->GetRef( aSheet ).IsEmpty() )
|
||||||
DrawLibItem->SetRef( aSheet, wxT( "DefRef?" ) );
|
DrawLibItem->SetRef( aSheet, wxT( "DefRef?" ) );
|
||||||
|
|
||||||
strncpy( new_object.m_Reference,
|
new_object.SetRef( DrawLibItem->GetRef( aSheet ) );
|
||||||
CONV_TO_UTF8( DrawLibItem->GetRef( aSheet ) ), 32 );
|
|
||||||
|
|
||||||
new_object.m_NumRef = -1;
|
new_object.m_NumRef = -1;
|
||||||
|
|
||||||
|
@ -409,6 +408,7 @@ static void ReAnnotateComponents( std::vector <OBJ_CMP_TO_LIST>& aComponentsList
|
||||||
/* update the reference numbers */
|
/* update the reference numbers */
|
||||||
for( unsigned ii = 0; ii < aComponentsList.size(); ii++ )
|
for( unsigned ii = 0; ii < aComponentsList.size(); ii++ )
|
||||||
{
|
{
|
||||||
|
#if 0
|
||||||
char* Text = aComponentsList[ii].m_Reference;
|
char* Text = aComponentsList[ii].m_Reference;
|
||||||
SCH_COMPONENT* component = aComponentsList[ii].m_RootCmp;
|
SCH_COMPONENT* component = aComponentsList[ii].m_RootCmp;
|
||||||
|
|
||||||
|
@ -419,8 +419,23 @@ static void ReAnnotateComponents( std::vector <OBJ_CMP_TO_LIST>& aComponentsList
|
||||||
|
|
||||||
component->SetRef( &(aComponentsList[ii].m_SheetPath),
|
component->SetRef( &(aComponentsList[ii].m_SheetPath),
|
||||||
CONV_FROM_UTF8( Text ) );
|
CONV_FROM_UTF8( Text ) );
|
||||||
|
#else
|
||||||
|
|
||||||
|
wxString ref = aComponentsList[ii].GetRef();
|
||||||
|
SCH_COMPONENT* component = aComponentsList[ii].m_RootCmp;
|
||||||
|
|
||||||
|
if( aComponentsList[ii].m_NumRef < 0 )
|
||||||
|
ref += wxChar( '?' );
|
||||||
|
else
|
||||||
|
ref << aComponentsList[ii].m_NumRef;
|
||||||
|
|
||||||
|
aComponentsList[ii].SetRef( ref );
|
||||||
|
|
||||||
|
component->SetRef( &aComponentsList[ii].m_SheetPath, ref );
|
||||||
|
#endif
|
||||||
|
|
||||||
component->m_Multi = aComponentsList[ii].m_Unit;
|
component->m_Multi = aComponentsList[ii].m_Unit;
|
||||||
component->SetUnitSelection( &(aComponentsList[ii].m_SheetPath),
|
component->SetUnitSelection( &aComponentsList[ii].m_SheetPath,
|
||||||
aComponentsList[ii].m_Unit );
|
aComponentsList[ii].m_Unit );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -437,42 +452,58 @@ static void ReAnnotateComponents( std::vector <OBJ_CMP_TO_LIST>& aComponentsList
|
||||||
*/
|
*/
|
||||||
void BreakReference( std::vector <OBJ_CMP_TO_LIST>& aComponentsList )
|
void BreakReference( std::vector <OBJ_CMP_TO_LIST>& aComponentsList )
|
||||||
{
|
{
|
||||||
char* Text;
|
std::string refText; // construct once outside loop
|
||||||
|
|
||||||
for( unsigned ii = 0; ii < aComponentsList.size(); ii++ )
|
for( unsigned ii = 0; ii < aComponentsList.size(); ii++ )
|
||||||
{
|
{
|
||||||
aComponentsList[ii].m_NumRef = -1;
|
aComponentsList[ii].m_NumRef = -1;
|
||||||
Text = aComponentsList[ii].m_Reference;
|
|
||||||
int ll = strlen( Text ) - 1;
|
refText = aComponentsList[ii].GetRefStr();
|
||||||
if( Text[ll] == '?' )
|
|
||||||
|
int ll = refText.length() - 1;
|
||||||
|
|
||||||
|
if( refText[ll] == '?' )
|
||||||
|
{
|
||||||
|
aComponentsList[ii].m_IsNew = true;
|
||||||
|
|
||||||
|
if( !aComponentsList[ii].IsPartsLocked() )
|
||||||
|
aComponentsList[ii].m_Unit = 0x7FFFFFFF;
|
||||||
|
|
||||||
|
refText.erase(ll); // delete last char
|
||||||
|
|
||||||
|
aComponentsList[ii].SetRefStr( refText );
|
||||||
|
}
|
||||||
|
|
||||||
|
else if( isdigit( refText[ll] ) == 0 )
|
||||||
{
|
{
|
||||||
aComponentsList[ii].m_IsNew = true;
|
aComponentsList[ii].m_IsNew = true;
|
||||||
if( !aComponentsList[ii].IsPartsLocked() )
|
if( !aComponentsList[ii].IsPartsLocked() )
|
||||||
aComponentsList[ii].m_Unit = 0x7FFFFFFF;
|
aComponentsList[ii].m_Unit = 0x7FFFFFFF;
|
||||||
Text[ll] = 0;
|
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if( isdigit( Text[ll] ) == 0 )
|
else
|
||||||
{
|
{
|
||||||
aComponentsList[ii].m_IsNew = true;
|
|
||||||
if( !aComponentsList[ii].IsPartsLocked() )
|
|
||||||
aComponentsList[ii].m_Unit = 0x7FFFFFFF;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
while( ll >= 0 )
|
while( ll >= 0 )
|
||||||
{
|
{
|
||||||
if( (Text[ll] <= ' ' ) || isdigit( Text[ll] ) )
|
if( (refText[ll] <= ' ' ) || isdigit( refText[ll] ) )
|
||||||
ll--;
|
ll--;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if( isdigit( Text[ll + 1] ) )
|
if( isdigit( refText[ll + 1] ) )
|
||||||
aComponentsList[ii].m_NumRef = atoi( &Text[ll + 1] );
|
{
|
||||||
Text[ll + 1] = 0;
|
// nul terminated C string into cp
|
||||||
|
const char* cp = refText.c_str() + ll + 1;
|
||||||
|
|
||||||
|
aComponentsList[ii].m_NumRef = atoi( cp );
|
||||||
|
}
|
||||||
|
|
||||||
|
refText.erase( ll+1 ); // delete from ll+1 to end
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
aComponentsList[ii].SetRefStr( refText );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -490,7 +521,7 @@ static void ComputeReferenceNumber( std::vector <OBJ_CMP_TO_LIST>& aComponentsLi
|
||||||
*/
|
*/
|
||||||
for( unsigned ii = 0; ii < aComponentsList.size(); ii++ )
|
for( unsigned ii = 0; ii < aComponentsList.size(); ii++ )
|
||||||
{
|
{
|
||||||
if( aComponentsList[ii].m_Reference[0] == '#' )
|
if( aComponentsList[ii].GetRefStr()[0] == '#' )
|
||||||
{
|
{
|
||||||
aComponentsList[ii].m_IsNew = true;
|
aComponentsList[ii].m_IsNew = true;
|
||||||
aComponentsList[ii].m_NumRef = 0;
|
aComponentsList[ii].m_NumRef = 0;
|
||||||
|
@ -716,9 +747,9 @@ int WinEDA_SchematicFrame::CheckAnnotate( wxArrayString* aMessageList,
|
||||||
else
|
else
|
||||||
Buff = wxT( "?" );
|
Buff = wxT( "?" );
|
||||||
|
|
||||||
cmpref = CONV_FROM_UTF8( ComponentsList[ii].m_Reference );
|
cmpref = ComponentsList[ii].GetRef();
|
||||||
msg.Printf( _( "item not annotated: %s%s" ),
|
msg.Printf( _( "item not annotated: %s%s" ),
|
||||||
cmpref.GetData(), Buff.GetData() );
|
GetChars( cmpref ), GetChars( Buff ) );
|
||||||
|
|
||||||
if( ( ComponentsList[ii].m_Unit > 0 )
|
if( ( ComponentsList[ii].m_Unit > 0 )
|
||||||
&& ( ComponentsList[ii].m_Unit < 0x7FFFFFFF ) )
|
&& ( ComponentsList[ii].m_Unit < 0x7FFFFFFF ) )
|
||||||
|
@ -748,9 +779,10 @@ int WinEDA_SchematicFrame::CheckAnnotate( wxArrayString* aMessageList,
|
||||||
else
|
else
|
||||||
Buff = wxT( "?" );
|
Buff = wxT( "?" );
|
||||||
|
|
||||||
cmpref = CONV_FROM_UTF8( ComponentsList[ii].m_Reference );
|
cmpref = ComponentsList[ii].GetRef();
|
||||||
msg.Printf( _( "Error item %s%s" ), cmpref.GetData(),
|
|
||||||
Buff.GetData() );
|
msg.Printf( _( "Error item %s%s" ), GetChars( cmpref ),
|
||||||
|
GetChars( Buff ) );
|
||||||
|
|
||||||
Buff.Printf( _( " unit %d and no more than %d parts" ),
|
Buff.Printf( _( " unit %d and no more than %d parts" ),
|
||||||
ComponentsList[ii].m_Unit,
|
ComponentsList[ii].m_Unit,
|
||||||
|
@ -789,9 +821,10 @@ int WinEDA_SchematicFrame::CheckAnnotate( wxArrayString* aMessageList,
|
||||||
else
|
else
|
||||||
Buff = wxT( "?" );
|
Buff = wxT( "?" );
|
||||||
|
|
||||||
cmpref = CONV_FROM_UTF8( ComponentsList[ii].m_Reference );
|
cmpref = ComponentsList[ii].GetRef();
|
||||||
|
|
||||||
msg.Printf( _( "Multiple item %s%s" ),
|
msg.Printf( _( "Multiple item %s%s" ),
|
||||||
cmpref.GetData(), Buff.GetData() );
|
GetChars( cmpref ), GetChars( Buff ) );
|
||||||
|
|
||||||
if( ( ComponentsList[ii].m_Unit > 0 )
|
if( ( ComponentsList[ii].m_Unit > 0 )
|
||||||
&& ( ComponentsList[ii].m_Unit < 0x7FFFFFFF ) )
|
&& ( ComponentsList[ii].m_Unit < 0x7FFFFFFF ) )
|
||||||
|
@ -819,9 +852,9 @@ int WinEDA_SchematicFrame::CheckAnnotate( wxArrayString* aMessageList,
|
||||||
else
|
else
|
||||||
Buff = wxT( "?" );
|
Buff = wxT( "?" );
|
||||||
|
|
||||||
cmpref = CONV_FROM_UTF8( ComponentsList[ii].m_Reference );
|
cmpref = ComponentsList[ii].GetRef();
|
||||||
msg.Printf( _( "Multiple item %s%s" ),
|
msg.Printf( _( "Multiple item %s%s" ),
|
||||||
cmpref.GetData(), Buff.GetData() );
|
GetChars( cmpref ), GetChars( Buff ) );
|
||||||
|
|
||||||
if( ( ComponentsList[ii].m_Unit > 0 )
|
if( ( ComponentsList[ii].m_Unit > 0 )
|
||||||
&& ( ComponentsList[ii].m_Unit < 0x7FFFFFFF ) )
|
&& ( ComponentsList[ii].m_Unit < 0x7FFFFFFF ) )
|
||||||
|
@ -846,16 +879,17 @@ int WinEDA_SchematicFrame::CheckAnnotate( wxArrayString* aMessageList,
|
||||||
int next = ii + 1;
|
int next = ii + 1;
|
||||||
if( ComponentsList[ii].CompareValue( ComponentsList[next] ) != 0 )
|
if( ComponentsList[ii].CompareValue( ComponentsList[next] ) != 0 )
|
||||||
{
|
{
|
||||||
wxString nextcmpref;
|
wxString nextcmpref = ComponentsList[next].GetRef();
|
||||||
cmpref = CONV_FROM_UTF8( ComponentsList[ii].m_Reference );
|
|
||||||
nextcmpref = CONV_FROM_UTF8( ComponentsList[next].m_Reference );
|
cmpref = ComponentsList[ii].GetRef();
|
||||||
|
|
||||||
#if defined(KICAD_GOST)
|
#if defined(KICAD_GOST)
|
||||||
msg.Printf( _( "Diff values for %s%d.%c (%s) and %s%d.%c (%s)" ),
|
msg.Printf( _( "Diff values for %s%d.%c (%s) and %s%d.%c (%s)" ),
|
||||||
cmpref.GetData(),
|
cmpref.GetData(),
|
||||||
ComponentsList[ii].m_NumRef,
|
ComponentsList[ii].m_NumRef,
|
||||||
ComponentsList[ii].m_Unit + '1' - 1,
|
ComponentsList[ii].m_Unit + '1' - 1,
|
||||||
ComponentsList[ii].m_Value->GetData(),
|
GetChars( *ComponentsList[ii].m_Value ),
|
||||||
nextcmpref.GetData(),
|
GetChars( nextcmpref ),
|
||||||
ComponentsList[next].m_NumRef,
|
ComponentsList[next].m_NumRef,
|
||||||
ComponentsList[next].m_Unit + '1' - 1,
|
ComponentsList[next].m_Unit + '1' - 1,
|
||||||
ComponentsList[next].m_Value->GetData() );
|
ComponentsList[next].m_Value->GetData() );
|
||||||
|
@ -864,11 +898,11 @@ int WinEDA_SchematicFrame::CheckAnnotate( wxArrayString* aMessageList,
|
||||||
cmpref.GetData(),
|
cmpref.GetData(),
|
||||||
ComponentsList[ii].m_NumRef,
|
ComponentsList[ii].m_NumRef,
|
||||||
ComponentsList[ii].m_Unit + 'A' - 1,
|
ComponentsList[ii].m_Unit + 'A' - 1,
|
||||||
ComponentsList[ii].m_Value->GetData(),
|
GetChars( *ComponentsList[ii].m_Value ),
|
||||||
nextcmpref.GetData(),
|
GetChars( nextcmpref ),
|
||||||
ComponentsList[next].m_NumRef,
|
ComponentsList[next].m_NumRef,
|
||||||
ComponentsList[next].m_Unit + 'A' - 1,
|
ComponentsList[next].m_Unit + 'A' - 1,
|
||||||
ComponentsList[next].m_Value->GetData() );
|
GetChars( *ComponentsList[next].m_Value ) );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if( aMessageList )
|
if( aMessageList )
|
||||||
|
@ -897,15 +931,19 @@ int WinEDA_SchematicFrame::CheckAnnotate( wxArrayString* aMessageList,
|
||||||
/* Same time stamp found. */
|
/* Same time stamp found. */
|
||||||
wxString nextcmpref;
|
wxString nextcmpref;
|
||||||
wxString full_path;
|
wxString full_path;
|
||||||
|
|
||||||
full_path.Printf( wxT( "%s%8.8X" ),
|
full_path.Printf( wxT( "%s%8.8X" ),
|
||||||
ComponentsList[ii].m_SheetPath.Path().GetData(),
|
GetChars( ComponentsList[ii].m_SheetPath.Path() ),
|
||||||
ComponentsList[ii].m_TimeStamp );
|
ComponentsList[ii].m_TimeStamp );
|
||||||
cmpref = CONV_FROM_UTF8( ComponentsList[ii].m_Reference );
|
|
||||||
nextcmpref = CONV_FROM_UTF8( ComponentsList[ii + 1].m_Reference );
|
cmpref = ComponentsList[ii].GetRef();
|
||||||
|
nextcmpref = ComponentsList[ii + 1].GetRef();
|
||||||
|
|
||||||
msg.Printf( _( "duplicate time stamp (%s) for %s%d and %s%d" ),
|
msg.Printf( _( "duplicate time stamp (%s) for %s%d and %s%d" ),
|
||||||
full_path.GetData(),
|
GetChars( full_path ),
|
||||||
cmpref.GetData(), ComponentsList[ii].m_NumRef,
|
GetChars( cmpref ), ComponentsList[ii].m_NumRef,
|
||||||
nextcmpref.GetData(), ComponentsList[ii + 1].m_NumRef );
|
GetChars( nextcmpref ), ComponentsList[ii + 1].m_NumRef );
|
||||||
|
|
||||||
if( aMessageList )
|
if( aMessageList )
|
||||||
{
|
{
|
||||||
aMessageList->Add( msg + wxT( "\n" ));
|
aMessageList->Add( msg + wxT( "\n" ));
|
||||||
|
|
|
@ -32,7 +32,10 @@
|
||||||
* the return value for an error.
|
* the return value for an error.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* object used in build BOM to handle the list of labels in schematic
|
|
||||||
|
/**
|
||||||
|
* Class LABEL_OBJECT
|
||||||
|
* is used in build BOM to handle the list of labels in schematic
|
||||||
* because in a complex hierarchy, a label is used more than once,
|
* because in a complex hierarchy, a label is used more than once,
|
||||||
* and had more than one sheet path, so we must create a flat list of labels
|
* and had more than one sheet path, so we must create a flat list of labels
|
||||||
*/
|
*/
|
||||||
|
@ -53,14 +56,9 @@ public: LABEL_OBJECT()
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
// Filename extension for BOM list
|
|
||||||
static const wxString BomFileExtension( wxT( "lst" ) );
|
|
||||||
static const wxString CsvFileExtension( wxT( "csv" ) );
|
|
||||||
#define BomFileWildcard _( "Bill of Materials file (*.lst)|*.lst" )
|
|
||||||
|
|
||||||
|
|
||||||
static void BuildComponentsListFromSchematic(
|
static void BuildComponentsListFromSchematic(
|
||||||
std::vector <OBJ_CMP_TO_LIST>& aList );
|
std::vector <OBJ_CMP_TO_LIST>& aList );
|
||||||
|
|
||||||
static void GenListeGLabels( std::vector <LABEL_OBJECT>& aList );
|
static void GenListeGLabels( std::vector <LABEL_OBJECT>& aList );
|
||||||
static bool SortComponentsByReference( const OBJ_CMP_TO_LIST& obj1,
|
static bool SortComponentsByReference( const OBJ_CMP_TO_LIST& obj1,
|
||||||
const OBJ_CMP_TO_LIST& obj2 );
|
const OBJ_CMP_TO_LIST& obj2 );
|
||||||
|
@ -73,14 +71,14 @@ static bool SortLabelsBySheet( const LABEL_OBJECT& obj1,
|
||||||
static void DeleteSubCmp( std::vector <OBJ_CMP_TO_LIST>& aList );
|
static void DeleteSubCmp( std::vector <OBJ_CMP_TO_LIST>& aList );
|
||||||
static int PrintListeGLabel( FILE* f, std::vector <LABEL_OBJECT>& aList );
|
static int PrintListeGLabel( FILE* f, std::vector <LABEL_OBJECT>& aList );
|
||||||
|
|
||||||
int RefDesStringCompare( const char* obj1, const char* obj2 );
|
int RefDesStringCompare( const wxString& lhs, const wxString& rhs );
|
||||||
int SplitString( wxString strToSplit,
|
int SplitString( wxString strToSplit,
|
||||||
wxString* strBeginning,
|
wxString* strBeginning,
|
||||||
wxString* strDigits,
|
wxString* strDigits,
|
||||||
wxString* strEnd );
|
wxString* strEnd );
|
||||||
|
|
||||||
|
|
||||||
/* separator used in bom export to spreadsheet */
|
// separator used in bom export to spreadsheet
|
||||||
static char s_ExportSeparatorSymbol;
|
static char s_ExportSeparatorSymbol;
|
||||||
|
|
||||||
|
|
||||||
|
@ -89,27 +87,53 @@ void DIALOG_BUILD_BOM::Create_BOM_Lists( int aTypeFile,
|
||||||
char aExportSeparatorSymbol,
|
char aExportSeparatorSymbol,
|
||||||
bool aRunBrowser )
|
bool aRunBrowser )
|
||||||
{
|
{
|
||||||
wxFileName fn;
|
wxString wildcard;
|
||||||
|
|
||||||
|
static wxFileName fn;
|
||||||
|
|
||||||
|
wxFileName current = g_RootSheet->m_AssociatedScreen->m_FileName;
|
||||||
|
|
||||||
s_ExportSeparatorSymbol = aExportSeparatorSymbol;
|
s_ExportSeparatorSymbol = aExportSeparatorSymbol;
|
||||||
|
|
||||||
m_ListFileName = g_RootSheet->m_AssociatedScreen->m_FileName;
|
if( !fn.HasName() || fn.GetName()==NAMELESS_PROJECT )
|
||||||
fn = m_ListFileName;
|
{
|
||||||
if( aTypeFile == 2 )
|
fn.SetName( current.GetName() );
|
||||||
fn.SetExt( CsvFileExtension );
|
}
|
||||||
else
|
// else use a previous run's name, because fn was set before and user
|
||||||
fn.SetExt( BomFileExtension );
|
// is probably just iteratively refining the BOM.
|
||||||
|
|
||||||
wxFileDialog dlg( this, _( "Bill of Materials" ), fn.GetPath(),
|
if( fn.GetPath().IsEmpty() )
|
||||||
fn.GetFullName(), BomFileWildcard,
|
{
|
||||||
|
fn.SetPath( current.GetPath() );
|
||||||
|
}
|
||||||
|
// else use a previous run's path, because fn was set before and user
|
||||||
|
// is probably just iteratively refining the BOM.
|
||||||
|
|
||||||
|
wxString bomDesc = _( "Bill of Materials" ); // translate once, use twice.
|
||||||
|
|
||||||
|
if( aTypeFile == 0 )
|
||||||
|
{
|
||||||
|
fn.SetExt( wxT( "lst" ) );
|
||||||
|
wildcard = bomDesc + wxT( " (*.lst)|*.lst" );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
fn.SetExt( wxT( "csv" ) );
|
||||||
|
wildcard = bomDesc + wxT( " (*.csv)|*.csv" );
|
||||||
|
}
|
||||||
|
|
||||||
|
wxFileDialog dlg( this, bomDesc, fn.GetPath(),
|
||||||
|
fn.GetFullName(), wildcard,
|
||||||
wxFD_SAVE | wxFD_OVERWRITE_PROMPT );
|
wxFD_SAVE | wxFD_OVERWRITE_PROMPT );
|
||||||
|
|
||||||
if( dlg.ShowModal() == wxID_CANCEL )
|
if( dlg.ShowModal() == wxID_CANCEL )
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
fn = dlg.GetPath(); // remember path+filename+ext for subsequent runs.
|
||||||
|
|
||||||
m_ListFileName = dlg.GetPath();
|
m_ListFileName = dlg.GetPath();
|
||||||
|
|
||||||
/* Close dialog, then show the list (if so requested) */
|
// Close dialog, then show the list (if so requested)
|
||||||
|
|
||||||
switch( aTypeFile )
|
switch( aTypeFile )
|
||||||
{
|
{
|
||||||
|
@ -148,6 +172,7 @@ bool DIALOG_BUILD_BOM::IsFieldChecked(int aFieldId)
|
||||||
{
|
{
|
||||||
if( m_AddAllFields->IsChecked() && (aFieldId>= FIELD1) )
|
if( m_AddAllFields->IsChecked() && (aFieldId>= FIELD1) )
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
switch ( aFieldId )
|
switch ( aFieldId )
|
||||||
{
|
{
|
||||||
case FIELD1:
|
case FIELD1:
|
||||||
|
@ -173,11 +198,7 @@ bool DIALOG_BUILD_BOM::IsFieldChecked(int aFieldId)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Print a list of components, in a form which can be imported by a spreadsheet
|
|
||||||
* form is:
|
|
||||||
* cmp value; number of components; <footprint>; <field1>; ...; list of references having the same value
|
|
||||||
*/
|
|
||||||
void DIALOG_BUILD_BOM::CreatePartsList( const wxString& aFullFileName, bool aIncludeSubComponents )
|
void DIALOG_BUILD_BOM::CreatePartsList( const wxString& aFullFileName, bool aIncludeSubComponents )
|
||||||
{
|
{
|
||||||
FILE* f;
|
FILE* f;
|
||||||
|
@ -192,16 +213,17 @@ void DIALOG_BUILD_BOM::CreatePartsList( const wxString& aFullFileName, bool aInc
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector <OBJ_CMP_TO_LIST> cmplist;
|
std::vector <OBJ_CMP_TO_LIST> cmplist;
|
||||||
|
|
||||||
BuildComponentsListFromSchematic( cmplist );
|
BuildComponentsListFromSchematic( cmplist );
|
||||||
|
|
||||||
/* sort component list by ref and remove sub components*/
|
// sort component list by ref and remove sub components
|
||||||
if( !aIncludeSubComponents )
|
if( !aIncludeSubComponents )
|
||||||
{
|
{
|
||||||
sort( cmplist.begin(), cmplist.end(), SortComponentsByReference );
|
sort( cmplist.begin(), cmplist.end(), SortComponentsByReference );
|
||||||
DeleteSubCmp( cmplist );
|
DeleteSubCmp( cmplist );
|
||||||
}
|
}
|
||||||
|
|
||||||
/* sort component list by value*/
|
// sort component list by value
|
||||||
sort( cmplist.begin(), cmplist.end(), SortComponentsByValue );
|
sort( cmplist.begin(), cmplist.end(), SortComponentsByValue );
|
||||||
PrintComponentsListByPart( f, cmplist,aIncludeSubComponents );
|
PrintComponentsListByPart( f, cmplist,aIncludeSubComponents );
|
||||||
|
|
||||||
|
@ -231,13 +253,13 @@ void DIALOG_BUILD_BOM::CreateExportList( const wxString& aFullFileName,
|
||||||
std::vector <OBJ_CMP_TO_LIST> cmplist;
|
std::vector <OBJ_CMP_TO_LIST> cmplist;
|
||||||
BuildComponentsListFromSchematic( cmplist );
|
BuildComponentsListFromSchematic( cmplist );
|
||||||
|
|
||||||
/* sort component list */
|
// sort component list
|
||||||
sort( cmplist.begin(), cmplist.end(), SortComponentsByReference );
|
sort( cmplist.begin(), cmplist.end(), SortComponentsByReference );
|
||||||
|
|
||||||
if( !aIncludeSubComponents )
|
if( !aIncludeSubComponents )
|
||||||
DeleteSubCmp( cmplist );
|
DeleteSubCmp( cmplist );
|
||||||
|
|
||||||
/* create the file */
|
// create the file
|
||||||
PrintComponentsListByRef( f, cmplist, TRUE, aIncludeSubComponents );
|
PrintComponentsListByRef( f, cmplist, TRUE, aIncludeSubComponents );
|
||||||
|
|
||||||
fclose( f );
|
fclose( f );
|
||||||
|
@ -270,13 +292,15 @@ void DIALOG_BUILD_BOM::GenereListeOfItems( const wxString& aFullFileName,
|
||||||
itemCount = cmplist.size();
|
itemCount = cmplist.size();
|
||||||
if( itemCount )
|
if( itemCount )
|
||||||
{
|
{
|
||||||
/* creates the list file */
|
// creates the list file
|
||||||
DateAndTime( Line );
|
DateAndTime( Line );
|
||||||
|
|
||||||
wxString Title = wxGetApp().GetAppName() + wxT( " " ) +
|
wxString Title = wxGetApp().GetAppName() + wxT( " " ) +
|
||||||
GetBuildVersion();
|
GetBuildVersion();
|
||||||
|
|
||||||
fprintf( f, "%s >> Creation date: %s\n", CONV_TO_UTF8( Title ), Line );
|
fprintf( f, "%s >> Creation date: %s\n", CONV_TO_UTF8( Title ), Line );
|
||||||
|
|
||||||
/* sort component list */
|
// sort component list
|
||||||
sort( cmplist.begin(), cmplist.end(), SortComponentsByReference );
|
sort( cmplist.begin(), cmplist.end(), SortComponentsByReference );
|
||||||
|
|
||||||
if( !aIncludeSubComponents )
|
if( !aIncludeSubComponents )
|
||||||
|
@ -296,16 +320,19 @@ void DIALOG_BUILD_BOM::GenereListeOfItems( const wxString& aFullFileName,
|
||||||
/* Create list of global labels and pins sheets */
|
/* Create list of global labels and pins sheets */
|
||||||
/*************************************************/
|
/*************************************************/
|
||||||
std::vector <LABEL_OBJECT> listOfLabels;
|
std::vector <LABEL_OBJECT> listOfLabels;
|
||||||
|
|
||||||
GenListeGLabels( listOfLabels );
|
GenListeGLabels( listOfLabels );
|
||||||
if( ( itemCount = listOfLabels.size() ) > 0 )
|
if( ( itemCount = listOfLabels.size() ) > 0 )
|
||||||
{
|
{
|
||||||
if( m_GenListLabelsbySheet->GetValue() )
|
if( m_GenListLabelsbySheet->GetValue() )
|
||||||
{
|
{
|
||||||
sort( listOfLabels.begin(), listOfLabels.end(), SortLabelsBySheet );
|
sort( listOfLabels.begin(), listOfLabels.end(), SortLabelsBySheet );
|
||||||
|
|
||||||
msg.Printf( _(
|
msg.Printf( _(
|
||||||
"\n#Global, Hierarchical Labels and PinSheets \
|
"\n#Global, Hierarchical Labels and PinSheets "
|
||||||
( order = Sheet Number ) count = %d\n" ),
|
"( order = Sheet Number ) count = %d\n" ),
|
||||||
itemCount );
|
itemCount );
|
||||||
|
|
||||||
fprintf( f, "%s", CONV_TO_UTF8( msg ) );
|
fprintf( f, "%s", CONV_TO_UTF8( msg ) );
|
||||||
PrintListeGLabel( f, listOfLabels );
|
PrintListeGLabel( f, listOfLabels );
|
||||||
}
|
}
|
||||||
|
@ -315,9 +342,10 @@ void DIALOG_BUILD_BOM::GenereListeOfItems( const wxString& aFullFileName,
|
||||||
sort( listOfLabels.begin(), listOfLabels.end(), SortLabelsByValue );
|
sort( listOfLabels.begin(), listOfLabels.end(), SortLabelsByValue );
|
||||||
|
|
||||||
msg.Printf( _(
|
msg.Printf( _(
|
||||||
"\n#Global, Hierarchical Labels and PinSheets ( \
|
"\n#Global, Hierarchical Labels and PinSheets ( "
|
||||||
order = Alphab. ) count = %d\n\n" ),
|
"order = Alphab. ) count = %d\n\n" ),
|
||||||
itemCount );
|
itemCount );
|
||||||
|
|
||||||
fprintf( f, "%s", CONV_TO_UTF8( msg ) );
|
fprintf( f, "%s", CONV_TO_UTF8( msg ) );
|
||||||
PrintListeGLabel( f, listOfLabels );
|
PrintListeGLabel( f, listOfLabels );
|
||||||
}
|
}
|
||||||
|
@ -329,47 +357,43 @@ order = Alphab. ) count = %d\n\n"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Creates the list of components found in the whole schematic
|
/**
|
||||||
|
* Function BuildComponentsListFromSchematic
|
||||||
|
* creates the list of components found in the whole schematic.
|
||||||
*
|
*
|
||||||
* if List == null, just returns the count. if not, fills the list.
|
* Goes through the 'sheets', not the screens, so that we account for
|
||||||
* goes through the sheets, not the screens, so that we account for
|
|
||||||
* multiple instances of a given screen.
|
* multiple instances of a given screen.
|
||||||
* Also Initialize m_Father as pointer of the SCH_SCREEN parent
|
|
||||||
*/
|
*/
|
||||||
void BuildComponentsListFromSchematic( std::vector <OBJ_CMP_TO_LIST>& aList )
|
void BuildComponentsListFromSchematic( std::vector <OBJ_CMP_TO_LIST>& aList )
|
||||||
{
|
{
|
||||||
EDA_BaseStruct* SchItem;
|
// Build the sheet list (which is not screen a screen list)
|
||||||
SCH_COMPONENT* DrawLibItem;
|
SCH_SHEET_LIST sheetList; // uses a global
|
||||||
SCH_SHEET_PATH* sheetPath;
|
|
||||||
|
|
||||||
/* Build the sheet (not screen) list */
|
for( SCH_SHEET_PATH* path = sheetList.GetFirst(); path; path = sheetList.GetNext() )
|
||||||
SCH_SHEET_LIST SheetList;
|
|
||||||
|
|
||||||
for( sheetPath = SheetList.GetFirst(); sheetPath != NULL; sheetPath = SheetList.GetNext() )
|
|
||||||
{
|
{
|
||||||
for( SchItem = sheetPath->LastDrawList(); SchItem; SchItem = SchItem->Next() )
|
for( EDA_BaseStruct* schItem = path->LastDrawList(); schItem; schItem = schItem->Next() )
|
||||||
{
|
{
|
||||||
if( SchItem->Type() != TYPE_SCH_COMPONENT )
|
if( schItem->Type() != TYPE_SCH_COMPONENT )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
DrawLibItem = (SCH_COMPONENT*) SchItem;
|
SCH_COMPONENT* comp = (SCH_COMPONENT*) schItem;
|
||||||
DrawLibItem->SetParent( sheetPath->LastScreen() );
|
|
||||||
|
comp->SetParent( path->LastScreen() );
|
||||||
|
|
||||||
OBJ_CMP_TO_LIST item;
|
OBJ_CMP_TO_LIST item;
|
||||||
item.m_RootCmp = DrawLibItem;
|
|
||||||
item.m_SheetPath = *sheetPath;
|
|
||||||
item.m_Unit = DrawLibItem->GetUnitSelection( sheetPath );
|
|
||||||
|
|
||||||
strncpy( item.m_Reference,
|
item.m_RootCmp = comp;
|
||||||
CONV_TO_UTF8( DrawLibItem->GetRef( sheetPath ) ),
|
item.m_SheetPath = *path;
|
||||||
sizeof( item.m_Reference ) );
|
item.m_Unit = comp->GetUnitSelection( path );
|
||||||
|
|
||||||
// Ensure always null terminate m_Ref.
|
item.SetRef( comp->GetRef( path ) );
|
||||||
item.m_Reference[sizeof( item.m_Reference ) - 1 ] = 0;
|
|
||||||
// Skip pseudo components:
|
// skip pseudo components, which have a reference starting
|
||||||
// pseudo components have a reference starting by #. Mainly power symbols
|
// with #, mainly power symbols
|
||||||
if( item.m_Reference[0] == '#' )
|
if( item.GetRefStr()[0] == '#' )
|
||||||
continue;
|
continue;
|
||||||
// Real component found, push it in list
|
|
||||||
|
// Real component found, keep it
|
||||||
aList.push_back( item );
|
aList.push_back( item );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -380,40 +404,37 @@ void BuildComponentsListFromSchematic( std::vector <OBJ_CMP_TO_LIST>& aList )
|
||||||
*/
|
*/
|
||||||
static void GenListeGLabels( std::vector <LABEL_OBJECT>& aList )
|
static void GenListeGLabels( std::vector <LABEL_OBJECT>& aList )
|
||||||
{
|
{
|
||||||
SCH_ITEM* DrawList;
|
// Build the sheet list
|
||||||
SCH_SHEET_PATH* sheetPath;
|
SCH_SHEET_LIST sheetList;
|
||||||
|
|
||||||
/* Build the sheet list */
|
LABEL_OBJECT lable;
|
||||||
SCH_SHEET_LIST SheetList;
|
|
||||||
|
|
||||||
LABEL_OBJECT labet_object;
|
for( SCH_SHEET_PATH* path = sheetList.GetFirst(); path; path = sheetList.GetNext() )
|
||||||
|
|
||||||
for( sheetPath = SheetList.GetFirst(); sheetPath != NULL; sheetPath = SheetList.GetNext() )
|
|
||||||
{
|
{
|
||||||
DrawList = (SCH_ITEM*) sheetPath->LastDrawList();
|
SCH_ITEM* schItem = (SCH_ITEM*) path->LastDrawList();
|
||||||
|
|
||||||
while( DrawList )
|
while( schItem )
|
||||||
{
|
{
|
||||||
switch( DrawList->Type() )
|
switch( schItem->Type() )
|
||||||
{
|
{
|
||||||
case TYPE_SCH_HIERLABEL:
|
case TYPE_SCH_HIERLABEL:
|
||||||
case TYPE_SCH_GLOBALLABEL:
|
case TYPE_SCH_GLOBALLABEL:
|
||||||
labet_object.m_LabelType = DrawList->Type();
|
lable.m_LabelType = schItem->Type();
|
||||||
labet_object.m_SheetPath = *sheetPath;
|
lable.m_SheetPath = *path;
|
||||||
labet_object.m_Label = DrawList;
|
lable.m_Label = schItem;
|
||||||
aList.push_back( labet_object );
|
aList.push_back( lable );
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case DRAW_SHEET_STRUCT_TYPE:
|
case DRAW_SHEET_STRUCT_TYPE:
|
||||||
{
|
{
|
||||||
SCH_SHEET* sheet = (SCH_SHEET*) DrawList;
|
SCH_SHEET* sheet = (SCH_SHEET*) schItem;
|
||||||
|
|
||||||
BOOST_FOREACH( SCH_SHEET_PIN sheetLabel, sheet->GetSheetPins() )
|
BOOST_FOREACH( SCH_SHEET_PIN sheetLabel, sheet->GetSheetPins() )
|
||||||
{
|
{
|
||||||
labet_object.m_LabelType = DRAW_HIERARCHICAL_PIN_SHEET_STRUCT_TYPE;
|
lable.m_LabelType = DRAW_HIERARCHICAL_PIN_SHEET_STRUCT_TYPE;
|
||||||
labet_object.m_SheetPath = *sheetPath;
|
lable.m_SheetPath = *path;
|
||||||
labet_object.m_Label = &sheetLabel;
|
lable.m_Label = &sheetLabel;
|
||||||
aList.push_back( labet_object );
|
aList.push_back( lable );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -422,7 +443,7 @@ static void GenListeGLabels( std::vector <LABEL_OBJECT>& aList )
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
DrawList = DrawList->Next();
|
schItem = schItem->Next();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -446,7 +467,7 @@ bool SortComponentsByValue( const OBJ_CMP_TO_LIST& obj1,
|
||||||
|
|
||||||
if( ii == 0 )
|
if( ii == 0 )
|
||||||
{
|
{
|
||||||
ii = RefDesStringCompare( obj1.m_Reference, obj2.m_Reference );
|
ii = RefDesStringCompare( obj1.GetRef(), obj2.GetRef() );
|
||||||
}
|
}
|
||||||
|
|
||||||
if( ii == 0 )
|
if( ii == 0 )
|
||||||
|
@ -470,7 +491,7 @@ bool SortComponentsByReference( const OBJ_CMP_TO_LIST& obj1,
|
||||||
int ii;
|
int ii;
|
||||||
const wxString* Text1, * Text2;
|
const wxString* Text1, * Text2;
|
||||||
|
|
||||||
ii = RefDesStringCompare( obj1.m_Reference, obj2.m_Reference );
|
ii = RefDesStringCompare( obj1.GetRef(), obj2.GetRef() );
|
||||||
|
|
||||||
if( ii == 0 )
|
if( ii == 0 )
|
||||||
{
|
{
|
||||||
|
@ -528,7 +549,6 @@ bool SortLabelsBySheet( const LABEL_OBJECT& obj1, const LABEL_OBJECT& obj2 )
|
||||||
int ii;
|
int ii;
|
||||||
wxString Text1, Text2;
|
wxString Text1, Text2;
|
||||||
|
|
||||||
|
|
||||||
ii = obj1.m_SheetPath.Cmp( obj2.m_SheetPath );
|
ii = obj1.m_SheetPath.Cmp( obj2.m_SheetPath );
|
||||||
|
|
||||||
if( ii == 0 )
|
if( ii == 0 )
|
||||||
|
@ -567,7 +587,7 @@ static void DeleteSubCmp( std::vector <OBJ_CMP_TO_LIST>& aList )
|
||||||
if( libItem == NULL )
|
if( libItem == NULL )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
currName = CONV_FROM_UTF8( aList[ii].m_Reference );
|
currName = aList[ii].GetRef();
|
||||||
|
|
||||||
if( !oldName.IsEmpty() )
|
if( !oldName.IsEmpty() )
|
||||||
{
|
{
|
||||||
|
@ -606,6 +626,7 @@ void DIALOG_BUILD_BOM::PrintFieldData( FILE* f, SCH_COMPONENT* DrawLibItem,
|
||||||
{
|
{
|
||||||
if( ! IsFieldChecked( ii ) )
|
if( ! IsFieldChecked( ii ) )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if( CompactForm )
|
if( CompactForm )
|
||||||
fprintf( f, "%c%s", s_ExportSeparatorSymbol,
|
fprintf( f, "%c%s", s_ExportSeparatorSymbol,
|
||||||
CONV_TO_UTF8( DrawLibItem->GetField( ii )->m_Text ) );
|
CONV_TO_UTF8( DrawLibItem->GetField( ii )->m_Text ) );
|
||||||
|
@ -624,10 +645,6 @@ int DIALOG_BUILD_BOM::PrintComponentsListByRef(
|
||||||
bool CompactForm,
|
bool CompactForm,
|
||||||
bool aIncludeSubComponents )
|
bool aIncludeSubComponents )
|
||||||
{
|
{
|
||||||
EDA_BaseStruct* DrawList;
|
|
||||||
SCH_COMPONENT* DrawLibItem;
|
|
||||||
LIB_COMPONENT* Entry;
|
|
||||||
char CmpName[80];
|
|
||||||
wxString msg;
|
wxString msg;
|
||||||
|
|
||||||
if( CompactForm )
|
if( CompactForm )
|
||||||
|
@ -654,6 +671,7 @@ int DIALOG_BUILD_BOM::PrintComponentsListByRef(
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
msg = _( "Field" );
|
msg = _( "Field" );
|
||||||
|
|
||||||
fprintf( f, "%c%s%d", s_ExportSeparatorSymbol, CONV_TO_UTF8(
|
fprintf( f, "%c%s%d", s_ExportSeparatorSymbol, CONV_TO_UTF8(
|
||||||
msg ), ii - FIELD1 + 1 );
|
msg ), ii - FIELD1 + 1 );
|
||||||
}
|
}
|
||||||
|
@ -666,80 +684,91 @@ int DIALOG_BUILD_BOM::PrintComponentsListByRef(
|
||||||
|
|
||||||
if( aIncludeSubComponents )
|
if( aIncludeSubComponents )
|
||||||
msg << _( " (with SubCmp)" );
|
msg << _( " (with SubCmp)" );
|
||||||
|
|
||||||
fprintf( f, "%s\n", CONV_TO_UTF8( msg ) );
|
fprintf( f, "%s\n", CONV_TO_UTF8( msg ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string CmpName;
|
||||||
|
wxString subRef;
|
||||||
|
|
||||||
// Print list of items
|
// Print list of items
|
||||||
for( unsigned ii = 0; ii < aList.size(); ii++ )
|
for( unsigned ii = 0; ii < aList.size(); ii++ )
|
||||||
{
|
{
|
||||||
DrawList = aList[ii].m_RootCmp;
|
EDA_BaseStruct* item = aList[ii].m_RootCmp;
|
||||||
|
if( item == NULL )
|
||||||
if( DrawList == NULL )
|
|
||||||
continue;
|
|
||||||
if( DrawList->Type() != TYPE_SCH_COMPONENT )
|
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
DrawLibItem = (SCH_COMPONENT*) DrawList;
|
if( item->Type() != TYPE_SCH_COMPONENT )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
SCH_COMPONENT* comp = (SCH_COMPONENT*) item;
|
||||||
|
|
||||||
bool isMulti = false;
|
bool isMulti = false;
|
||||||
wxString subRef;
|
|
||||||
Entry = CMP_LIBRARY::FindLibraryComponent( DrawLibItem->m_ChipName );
|
LIB_COMPONENT* entry = CMP_LIBRARY::FindLibraryComponent( comp->m_ChipName );
|
||||||
if( Entry )
|
if( entry )
|
||||||
isMulti = Entry->IsMulti();
|
isMulti = entry->IsMulti();
|
||||||
|
|
||||||
if( isMulti && aIncludeSubComponents )
|
if( isMulti && aIncludeSubComponents )
|
||||||
subRef = LIB_COMPONENT::ReturnSubReference( aList[ii].m_Unit );
|
subRef = LIB_COMPONENT::ReturnSubReference( aList[ii].m_Unit );
|
||||||
else
|
else
|
||||||
subRef.Empty();
|
subRef.Empty();
|
||||||
|
|
||||||
sprintf( CmpName, "%s", aList[ii].m_Reference );
|
CmpName = aList[ii].GetRefStr();
|
||||||
|
|
||||||
if( !CompactForm )
|
if( !CompactForm )
|
||||||
sprintf( CmpName + strlen( CmpName ), "%s", CONV_TO_UTF8(subRef) );
|
CmpName += CONV_TO_UTF8(subRef);
|
||||||
|
|
||||||
if( CompactForm )
|
if( CompactForm )
|
||||||
#if defined(KICAD_GOST)
|
#if defined(KICAD_GOST)
|
||||||
fprintf( f, "%s%c%s%c%s", CmpName, s_ExportSeparatorSymbol,
|
fprintf( f, "%s%c%s%c%s", CmpName.c_str(), s_ExportSeparatorSymbol,
|
||||||
CONV_TO_UTF8( DrawLibItem->GetField(
|
CONV_TO_UTF8( comp->GetField(
|
||||||
VALUE )->m_Text ), s_ExportSeparatorSymbol,
|
VALUE )->m_Text ), s_ExportSeparatorSymbol,
|
||||||
CONV_TO_UTF8( DrawLibItem->GetField( DATASHEET )->m_Text ) );
|
CONV_TO_UTF8( comp->GetField( DATASHEET )->m_Text ) );
|
||||||
#else
|
#else
|
||||||
fprintf( f, "%s%c%s", CmpName, s_ExportSeparatorSymbol,
|
fprintf( f, "%s%c%s", CmpName.c_str(), s_ExportSeparatorSymbol,
|
||||||
CONV_TO_UTF8( DrawLibItem->GetField( VALUE )->m_Text ) );
|
CONV_TO_UTF8( comp->GetField( VALUE )->m_Text ) );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
else
|
else
|
||||||
#if defined(KICAD_GOST)
|
#if defined(KICAD_GOST)
|
||||||
fprintf( f, "| %-10s %-12s %-20s", CmpName,
|
fprintf( f, "| %-10s %-12s %-20s", CmpName.c_str(),
|
||||||
CONV_TO_UTF8( DrawLibItem->GetField( VALUE )->m_Text ),
|
CONV_TO_UTF8( comp->GetField( VALUE )->m_Text ),
|
||||||
CONV_TO_UTF8( DrawLibItem->GetField( DATASHEET )->m_Text ) );
|
CONV_TO_UTF8( comp->GetField( DATASHEET )->m_Text ) );
|
||||||
#else
|
#else
|
||||||
fprintf( f, "| %-10s %-12s", CmpName,
|
fprintf( f, "| %-10s %-12s", CmpName.c_str(),
|
||||||
CONV_TO_UTF8( DrawLibItem->GetField( VALUE )->m_Text ) );
|
CONV_TO_UTF8( comp->GetField( VALUE )->m_Text ) );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if( aIncludeSubComponents )
|
if( aIncludeSubComponents )
|
||||||
{
|
{
|
||||||
msg = aList[ii].m_SheetPath.PathHumanReadable();
|
msg = aList[ii].m_SheetPath.PathHumanReadable();
|
||||||
|
|
||||||
if( CompactForm )
|
if( CompactForm )
|
||||||
{
|
{
|
||||||
fprintf( f, "%c%s", s_ExportSeparatorSymbol,
|
fprintf( f, "%c%s", s_ExportSeparatorSymbol,
|
||||||
CONV_TO_UTF8( msg ) );
|
CONV_TO_UTF8( msg ) );
|
||||||
|
|
||||||
msg = m_Parent->GetXYSheetReferences(
|
msg = m_Parent->GetXYSheetReferences(
|
||||||
(BASE_SCREEN*) DrawLibItem->GetParent(),
|
(BASE_SCREEN*) comp->GetParent(),
|
||||||
DrawLibItem->m_Pos );
|
comp->m_Pos );
|
||||||
|
|
||||||
fprintf( f, "%c%s)", s_ExportSeparatorSymbol,
|
fprintf( f, "%c%s)", s_ExportSeparatorSymbol,
|
||||||
CONV_TO_UTF8( msg ) );
|
CONV_TO_UTF8( msg ) );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
fprintf( f, " (Sheet %s)", CONV_TO_UTF8( msg ) );
|
fprintf( f, " (Sheet %s)", CONV_TO_UTF8( msg ) );
|
||||||
|
|
||||||
msg = m_Parent->GetXYSheetReferences(
|
msg = m_Parent->GetXYSheetReferences(
|
||||||
(BASE_SCREEN*) DrawLibItem->GetParent(),
|
(BASE_SCREEN*) comp->GetParent(),
|
||||||
DrawLibItem->m_Pos );
|
comp->m_Pos );
|
||||||
|
|
||||||
fprintf( f, " (loc %s)", CONV_TO_UTF8( msg ) );
|
fprintf( f, " (loc %s)", CONV_TO_UTF8( msg ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
PrintFieldData( f, DrawLibItem, CompactForm );
|
PrintFieldData( f, comp, CompactForm );
|
||||||
|
|
||||||
fprintf( f, "\n" );
|
fprintf( f, "\n" );
|
||||||
}
|
}
|
||||||
|
@ -771,18 +800,20 @@ int DIALOG_BUILD_BOM::PrintComponentsListByPart(
|
||||||
bool aIncludeSubComponents)
|
bool aIncludeSubComponents)
|
||||||
{
|
{
|
||||||
int qty = 0;
|
int qty = 0;
|
||||||
wxString RefName;
|
wxString refName;
|
||||||
wxString fullRefName; // reference + part Id (for multiple parts per package
|
wxString fullRefName; // reference + part Id (for multiple parts per package
|
||||||
wxString ValName;
|
wxString valName;
|
||||||
wxString RNames;
|
wxString refNames;
|
||||||
wxString lastRef;
|
wxString lastRef;
|
||||||
wxString unitId;
|
wxString unitId;
|
||||||
SCH_COMPONENT* currCmp, *nextCmp;
|
SCH_COMPONENT* currCmp;
|
||||||
|
SCH_COMPONENT* nextCmp;
|
||||||
SCH_COMPONENT dummyCmp; // A dummy component, to store fields
|
SCH_COMPONENT dummyCmp; // A dummy component, to store fields
|
||||||
|
|
||||||
for( unsigned ii = 0; ii < aList.size(); ii++ )
|
for( unsigned ii = 0; ii < aList.size(); ii++ )
|
||||||
{
|
{
|
||||||
currCmp = (SCH_COMPONENT*) aList[ii].m_RootCmp;
|
currCmp = (SCH_COMPONENT*) aList[ii].m_RootCmp;
|
||||||
|
|
||||||
if( ii < aList.size() -1 )
|
if( ii < aList.size() -1 )
|
||||||
nextCmp = aList[ii+1].m_RootCmp;
|
nextCmp = aList[ii+1].m_RootCmp;
|
||||||
else
|
else
|
||||||
|
@ -794,45 +825,50 @@ int DIALOG_BUILD_BOM::PrintComponentsListByPart(
|
||||||
// Ensure fields exists in dummy component
|
// Ensure fields exists in dummy component
|
||||||
if( dummyCmp.GetFieldCount() <= jj )
|
if( dummyCmp.GetFieldCount() <= jj )
|
||||||
dummyCmp.AddField( *currCmp->GetField( jj ) );
|
dummyCmp.AddField( *currCmp->GetField( jj ) );
|
||||||
|
|
||||||
// store useful data
|
// store useful data
|
||||||
if( !currCmp->GetField( jj )->m_Text.IsEmpty() )
|
if( !currCmp->GetField( jj )->m_Text.IsEmpty() )
|
||||||
dummyCmp.GetField( jj )->m_Text = currCmp->GetField( jj )->m_Text;
|
dummyCmp.GetField( jj )->m_Text = currCmp->GetField( jj )->m_Text;
|
||||||
}
|
}
|
||||||
|
|
||||||
RefName = CONV_FROM_UTF8( aList[ii].m_Reference );
|
refName = aList[ii].GetRef();
|
||||||
ValName = currCmp->GetField( VALUE )->m_Text;
|
valName = currCmp->GetField( VALUE )->m_Text;
|
||||||
|
|
||||||
int multi = 0;
|
int multi = 0;
|
||||||
if( aIncludeSubComponents )
|
if( aIncludeSubComponents )
|
||||||
{
|
{
|
||||||
LIB_COMPONENT* Entry = CMP_LIBRARY::FindLibraryComponent( currCmp->m_ChipName );
|
LIB_COMPONENT* entry = CMP_LIBRARY::FindLibraryComponent( currCmp->m_ChipName );
|
||||||
if( Entry )
|
if( entry )
|
||||||
multi = Entry->GetPartCount();
|
multi = entry->GetPartCount();
|
||||||
if ( multi <= 1 )
|
if ( multi <= 1 )
|
||||||
multi = 0;
|
multi = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( multi && aList[ii].m_Unit > 0 )
|
if ( multi && aList[ii].m_Unit > 0 )
|
||||||
unitId.Printf( wxT("%c"), 'A' -1 + aList[ii].m_Unit );
|
unitId.Printf( wxT("%c"), 'A' -1 + aList[ii].m_Unit );
|
||||||
else unitId.Empty();
|
|
||||||
fullRefName = RefName + unitId;
|
|
||||||
|
|
||||||
if( RNames.IsEmpty() )
|
|
||||||
RNames = fullRefName;
|
|
||||||
else
|
else
|
||||||
RNames << wxT( ", " ) << fullRefName;
|
unitId.Empty();
|
||||||
|
|
||||||
|
fullRefName = refName + unitId;
|
||||||
|
|
||||||
|
if( refNames.IsEmpty() )
|
||||||
|
refNames = fullRefName;
|
||||||
|
else
|
||||||
|
refNames << wxT( ", " ) << fullRefName;
|
||||||
|
|
||||||
// In multi parts per package, we have the reference more than once
|
// In multi parts per package, we have the reference more than once
|
||||||
// but we must count only one package
|
// but we must count only one package
|
||||||
if( lastRef != RefName )
|
if( lastRef != refName )
|
||||||
qty++;
|
qty++;
|
||||||
lastRef = RefName;
|
|
||||||
|
lastRef = refName;
|
||||||
|
|
||||||
// if the next cmoponent has same value the line will be printed after.
|
// if the next cmoponent has same value the line will be printed after.
|
||||||
if( nextCmp && nextCmp->GetField( VALUE )->m_Text.CmpNoCase( ValName ) == 0 )
|
if( nextCmp && nextCmp->GetField( VALUE )->m_Text.CmpNoCase( valName ) == 0 )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
// Print line for the current component value:
|
// Print line for the current component value:
|
||||||
fprintf( f, "%15s%c%3d", CONV_TO_UTF8( ValName ), s_ExportSeparatorSymbol, qty );
|
fprintf( f, "%15s%c%3d", CONV_TO_UTF8( valName ), s_ExportSeparatorSymbol, qty );
|
||||||
|
|
||||||
if( IsFieldChecked(FOOTPRINT ) )
|
if( IsFieldChecked(FOOTPRINT ) )
|
||||||
fprintf( f, "%c%15s", s_ExportSeparatorSymbol,
|
fprintf( f, "%c%15s", s_ExportSeparatorSymbol,
|
||||||
|
@ -843,14 +879,17 @@ int DIALOG_BUILD_BOM::PrintComponentsListByPart(
|
||||||
CONV_TO_UTF8( currCmp->GetField( DATASHEET )->m_Text ) );
|
CONV_TO_UTF8( currCmp->GetField( DATASHEET )->m_Text ) );
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
fprintf( f, "%c%s", s_ExportSeparatorSymbol,
|
// wrap the field in quotes, since it has commas in it.
|
||||||
CONV_TO_UTF8( RNames ) );
|
fprintf( f, "%c\"%s\"", s_ExportSeparatorSymbol,
|
||||||
|
CONV_TO_UTF8( refNames ) );
|
||||||
|
|
||||||
// print fields, on demand
|
// print fields, on demand
|
||||||
int last_nonempty_field_idx = 0;
|
int last_nonempty_field_idx = 0;
|
||||||
|
|
||||||
for( int jj = FOOTPRINT; jj < dummyCmp.GetFieldCount(); jj++ )
|
for( int jj = FOOTPRINT; jj < dummyCmp.GetFieldCount(); jj++ )
|
||||||
if ( !dummyCmp.GetField( jj )->m_Text.IsEmpty() )
|
if ( !dummyCmp.GetField( jj )->m_Text.IsEmpty() )
|
||||||
last_nonempty_field_idx = jj;
|
last_nonempty_field_idx = jj;
|
||||||
|
|
||||||
for( int jj = FIELD1; jj <= last_nonempty_field_idx ; jj++ )
|
for( int jj = FIELD1; jj <= last_nonempty_field_idx ; jj++ )
|
||||||
{
|
{
|
||||||
if ( IsFieldChecked( jj ) )
|
if ( IsFieldChecked( jj ) )
|
||||||
|
@ -862,7 +901,8 @@ int DIALOG_BUILD_BOM::PrintComponentsListByPart(
|
||||||
|
|
||||||
// Clear strings and values, to prepare next component
|
// Clear strings and values, to prepare next component
|
||||||
qty = 0;
|
qty = 0;
|
||||||
RNames.Empty();
|
refNames.Empty();
|
||||||
|
|
||||||
for( int jj = FOOTPRINT; jj < dummyCmp.GetFieldCount(); jj++ )
|
for( int jj = FOOTPRINT; jj < dummyCmp.GetFieldCount(); jj++ )
|
||||||
dummyCmp.GetField( jj )->m_Text.Empty();
|
dummyCmp.GetField( jj )->m_Text.Empty();
|
||||||
}
|
}
|
||||||
|
@ -876,10 +916,10 @@ int DIALOG_BUILD_BOM::PrintComponentsListByVal(
|
||||||
std::vector <OBJ_CMP_TO_LIST>& aList,
|
std::vector <OBJ_CMP_TO_LIST>& aList,
|
||||||
bool aIncludeSubComponents )
|
bool aIncludeSubComponents )
|
||||||
{
|
{
|
||||||
EDA_BaseStruct* DrawList;
|
EDA_BaseStruct* schItem;
|
||||||
SCH_COMPONENT* DrawLibItem;
|
SCH_COMPONENT* DrawLibItem;
|
||||||
LIB_COMPONENT* Entry;
|
LIB_COMPONENT* entry;
|
||||||
char CmpName[80];
|
std::string CmpName;
|
||||||
wxString msg;
|
wxString msg;
|
||||||
|
|
||||||
msg = _( "\n#Cmp ( order = Value )" );
|
msg = _( "\n#Cmp ( order = Value )" );
|
||||||
|
@ -887,24 +927,25 @@ int DIALOG_BUILD_BOM::PrintComponentsListByVal(
|
||||||
if( aIncludeSubComponents )
|
if( aIncludeSubComponents )
|
||||||
msg << _( " (with SubCmp)" );
|
msg << _( " (with SubCmp)" );
|
||||||
msg << wxT( "\n" );
|
msg << wxT( "\n" );
|
||||||
|
|
||||||
fputs( CONV_TO_UTF8( msg ), f );
|
fputs( CONV_TO_UTF8( msg ), f );
|
||||||
|
|
||||||
for( unsigned ii = 0; ii < aList.size(); ii++ )
|
for( unsigned ii = 0; ii < aList.size(); ii++ )
|
||||||
{
|
{
|
||||||
DrawList = aList[ii].m_RootCmp;
|
schItem = aList[ii].m_RootCmp;
|
||||||
|
|
||||||
if( DrawList == NULL )
|
if( schItem == NULL )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
if( DrawList->Type() != TYPE_SCH_COMPONENT )
|
if( schItem->Type() != TYPE_SCH_COMPONENT )
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
DrawLibItem = (SCH_COMPONENT*) DrawList;
|
DrawLibItem = (SCH_COMPONENT*) schItem;
|
||||||
|
|
||||||
bool isMulti = false;
|
bool isMulti = false;
|
||||||
Entry = CMP_LIBRARY::FindLibraryComponent( DrawLibItem->m_ChipName );
|
entry = CMP_LIBRARY::FindLibraryComponent( DrawLibItem->m_ChipName );
|
||||||
if( Entry )
|
if( entry )
|
||||||
isMulti = Entry->IsMulti();
|
isMulti = entry->IsMulti();
|
||||||
|
|
||||||
wxString subRef;
|
wxString subRef;
|
||||||
if( isMulti && aIncludeSubComponents )
|
if( isMulti && aIncludeSubComponents )
|
||||||
|
@ -912,11 +953,12 @@ int DIALOG_BUILD_BOM::PrintComponentsListByVal(
|
||||||
else
|
else
|
||||||
subRef.Empty();
|
subRef.Empty();
|
||||||
|
|
||||||
sprintf( CmpName, "%s%s", aList[ii].m_Reference, CONV_TO_UTF8(subRef) );
|
CmpName = aList[ii].GetRefStr();
|
||||||
|
CmpName += CONV_TO_UTF8(subRef);
|
||||||
|
|
||||||
fprintf( f, "| %-12s %-10s",
|
fprintf( f, "| %-12s %-10s",
|
||||||
CONV_TO_UTF8( DrawLibItem->GetField( VALUE )->m_Text ),
|
CONV_TO_UTF8( DrawLibItem->GetField( VALUE )->m_Text ),
|
||||||
CmpName );
|
CmpName.c_str() );
|
||||||
|
|
||||||
// print the sheet path
|
// print the sheet path
|
||||||
if( aIncludeSubComponents )
|
if( aIncludeSubComponents )
|
||||||
|
@ -962,9 +1004,9 @@ static int PrintListeGLabel( FILE* f, std::vector <LABEL_OBJECT>& aList )
|
||||||
sheetpath = aList[ii].m_SheetPath.PathHumanReadable();
|
sheetpath = aList[ii].m_SheetPath.PathHumanReadable();
|
||||||
msg.Printf(
|
msg.Printf(
|
||||||
_( "> %-28.28s %s (Sheet %s) pos: %3.3f, %3.3f\n" ),
|
_( "> %-28.28s %s (Sheet %s) pos: %3.3f, %3.3f\n" ),
|
||||||
DrawTextItem->m_Text.GetData(),
|
GetChars( DrawTextItem->m_Text ),
|
||||||
labeltype.GetData(),
|
GetChars( labeltype ),
|
||||||
sheetpath.GetData(),
|
GetChars( sheetpath ),
|
||||||
(float) DrawTextItem->m_Pos.x / 1000,
|
(float) DrawTextItem->m_Pos.x / 1000,
|
||||||
(float) DrawTextItem->m_Pos.y / 1000 );
|
(float) DrawTextItem->m_Pos.y / 1000 );
|
||||||
|
|
||||||
|
@ -975,18 +1017,23 @@ static int PrintListeGLabel( FILE* f, std::vector <LABEL_OBJECT>& aList )
|
||||||
{
|
{
|
||||||
DrawSheetLabel = (SCH_SHEET_PIN*) aList[ii].m_Label;
|
DrawSheetLabel = (SCH_SHEET_PIN*) aList[ii].m_Label;
|
||||||
int jj = DrawSheetLabel->m_Shape;
|
int jj = DrawSheetLabel->m_Shape;
|
||||||
|
|
||||||
if( jj < 0 )
|
if( jj < 0 )
|
||||||
jj = NET_TMAX;
|
jj = NET_TMAX;
|
||||||
|
|
||||||
if( jj > NET_TMAX )
|
if( jj > NET_TMAX )
|
||||||
jj = 4;
|
jj = 4;
|
||||||
|
|
||||||
wxString labtype = CONV_FROM_UTF8( SheetLabelType[jj] );
|
wxString labtype = CONV_FROM_UTF8( SheetLabelType[jj] );
|
||||||
|
|
||||||
msg.Printf(
|
msg.Printf(
|
||||||
_( "> %-28.28s PinSheet %-7.7s (Sheet %s) pos: %3.3f, %3.3f\n" ),
|
_( "> %-28.28s PinSheet %-7.7s (Sheet %s) pos: %3.3f, %3.3f\n" ),
|
||||||
DrawSheetLabel->m_Text.GetData(),
|
GetChars( DrawSheetLabel->m_Text ),
|
||||||
labtype.GetData(),
|
GetChars( labtype ),
|
||||||
aList[ii].m_SheetPath.PathHumanReadable().GetData(),
|
GetChars( aList[ii].m_SheetPath.PathHumanReadable()),
|
||||||
(float) DrawSheetLabel->m_Pos.x / 1000,
|
(float) DrawSheetLabel->m_Pos.x / 1000,
|
||||||
(float) DrawSheetLabel->m_Pos.y / 1000 );
|
(float) DrawSheetLabel->m_Pos.y / 1000 );
|
||||||
|
|
||||||
fputs( CONV_TO_UTF8( msg ), f );
|
fputs( CONV_TO_UTF8( msg ), f );
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -1008,35 +1055,27 @@ static int PrintListeGLabel( FILE* f, std::vector <LABEL_OBJECT>& aList )
|
||||||
* return 0 if the strings are equal
|
* return 0 if the strings are equal
|
||||||
* return 1 if the first string is greater than the second
|
* return 1 if the first string is greater than the second
|
||||||
*/
|
*/
|
||||||
int RefDesStringCompare( const char* obj1, const char* obj2 )
|
int RefDesStringCompare( const wxString& strFWord, const wxString& strSWord )
|
||||||
{
|
{
|
||||||
/* The strings we are going to compare */
|
// The different sections of the first string
|
||||||
wxString strFWord;
|
|
||||||
wxString strSWord;
|
|
||||||
|
|
||||||
/* The different sections of the first string */
|
|
||||||
wxString strFWordBeg, strFWordMid, strFWordEnd;
|
wxString strFWordBeg, strFWordMid, strFWordEnd;
|
||||||
|
|
||||||
/* The different sections of the second string */
|
// The different sections of the second string
|
||||||
wxString strSWordBeg, strSWordMid, strSWordEnd;
|
wxString strSWordBeg, strSWordMid, strSWordEnd;
|
||||||
|
|
||||||
int isEqual = 0; /* The numerical results of a string compare */
|
int isEqual = 0; // The numerical results of a string compare
|
||||||
int iReturn = 0; /* The variable that is being returned */
|
int iReturn = 0; // The variable that is being returned
|
||||||
|
|
||||||
long lFirstDigit = 0; /* The converted middle section of the first
|
long lFirstDigit = 0; /* The converted middle section of the first
|
||||||
*string */
|
*string */
|
||||||
long lSecondDigit = 0; /* The converted middle section of the second
|
long lSecondDigit = 0; /* The converted middle section of the second
|
||||||
*string */
|
*string */
|
||||||
|
|
||||||
/* Since m_Ref is a char * it is ASCII */
|
// Split the two string into separate parts
|
||||||
strFWord = wxString::FromAscii( obj1 );
|
|
||||||
strSWord = wxString::FromAscii( obj2 );
|
|
||||||
|
|
||||||
/* Split the two string into separate parts */
|
|
||||||
SplitString( strFWord, &strFWordBeg, &strFWordMid, &strFWordEnd );
|
SplitString( strFWord, &strFWordBeg, &strFWordMid, &strFWordEnd );
|
||||||
SplitString( strSWord, &strSWordBeg, &strSWordMid, &strSWordEnd );
|
SplitString( strSWord, &strSWordBeg, &strSWordMid, &strSWordEnd );
|
||||||
|
|
||||||
/* Compare the Beginning section of the strings */
|
// Compare the Beginning section of the strings
|
||||||
isEqual = strFWordBeg.CmpNoCase( strSWordBeg );
|
isEqual = strFWordBeg.CmpNoCase( strSWordBeg );
|
||||||
if( isEqual > 0 )
|
if( isEqual > 0 )
|
||||||
iReturn = 1;
|
iReturn = 1;
|
||||||
|
@ -1044,17 +1083,19 @@ int RefDesStringCompare( const char* obj1, const char* obj2 )
|
||||||
iReturn = -1;
|
iReturn = -1;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* If the first sections are equal compare there digits */
|
// If the first sections are equal compare there digits
|
||||||
strFWordMid.ToLong( &lFirstDigit );
|
strFWordMid.ToLong( &lFirstDigit );
|
||||||
strSWordMid.ToLong( &lSecondDigit );
|
strSWordMid.ToLong( &lSecondDigit );
|
||||||
|
|
||||||
if( lFirstDigit > lSecondDigit )
|
if( lFirstDigit > lSecondDigit )
|
||||||
iReturn = 1;
|
iReturn = 1;
|
||||||
else if( lFirstDigit < lSecondDigit )
|
else if( lFirstDigit < lSecondDigit )
|
||||||
iReturn = -1;
|
iReturn = -1;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* If the first two sections are equal compare the endings */
|
// If the first two sections are equal compare the endings
|
||||||
isEqual = strFWordEnd.CmpNoCase( strSWordEnd );
|
isEqual = strFWordEnd.CmpNoCase( strSWordEnd );
|
||||||
|
|
||||||
if( isEqual > 0 )
|
if( isEqual > 0 )
|
||||||
iReturn = 1;
|
iReturn = 1;
|
||||||
else if( isEqual < 0 )
|
else if( isEqual < 0 )
|
||||||
|
@ -1079,16 +1120,16 @@ int SplitString( wxString strToSplit,
|
||||||
wxString* strDigits,
|
wxString* strDigits,
|
||||||
wxString* strEnd )
|
wxString* strEnd )
|
||||||
{
|
{
|
||||||
/* Clear all the return strings */
|
// Clear all the return strings
|
||||||
strBeginning->Clear();
|
strBeginning->Clear();
|
||||||
strDigits->Clear();
|
strDigits->Clear();
|
||||||
strEnd->Clear();
|
strEnd->Clear();
|
||||||
|
|
||||||
/* There no need to do anything if the string is empty */
|
// There no need to do anything if the string is empty
|
||||||
if( strToSplit.length() == 0 )
|
if( strToSplit.length() == 0 )
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/* Starting at the end of the string look for the first digit */
|
// Starting at the end of the string look for the first digit
|
||||||
int ii;
|
int ii;
|
||||||
for( ii = (strToSplit.length() - 1); ii >= 0; ii-- )
|
for( ii = (strToSplit.length() - 1); ii >= 0; ii-- )
|
||||||
{
|
{
|
||||||
|
@ -1096,15 +1137,15 @@ int SplitString( wxString strToSplit,
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If there were no digits then just set the single string */
|
// If there were no digits then just set the single string
|
||||||
if( ii < 0 )
|
if( ii < 0 )
|
||||||
*strBeginning = strToSplit;
|
*strBeginning = strToSplit;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* Since there is at least one digit this is the trailing string */
|
// Since there is at least one digit this is the trailing string
|
||||||
*strEnd = strToSplit.substr( ii + 1 );
|
*strEnd = strToSplit.substr( ii + 1 );
|
||||||
|
|
||||||
/* Go to the end of the digits */
|
// Go to the end of the digits
|
||||||
int position = ii + 1;
|
int position = ii + 1;
|
||||||
for( ; ii >= 0; ii-- )
|
for( ; ii >= 0; ii-- )
|
||||||
{
|
{
|
||||||
|
@ -1112,7 +1153,7 @@ int SplitString( wxString strToSplit,
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If all that was left was digits, then just set the digits string */
|
// If all that was left was digits, then just set the digits string
|
||||||
if( ii < 0 )
|
if( ii < 0 )
|
||||||
*strDigits = strToSplit.substr( 0, position );
|
*strDigits = strToSplit.substr( 0, position );
|
||||||
|
|
||||||
|
|
|
@ -477,12 +477,6 @@ SCH_SHEET_PATH* SCH_SHEET_LIST::GetSheet( int aIndex )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/** Function BuildSheetList
|
|
||||||
* Build the list of sheets and their sheet path from the aSheet sheet
|
|
||||||
* if aSheet = g_RootSheet, the full sheet path list (and full sheet list) is
|
|
||||||
* built
|
|
||||||
* @param aSheet = the starting sheet to build list
|
|
||||||
*/
|
|
||||||
void SCH_SHEET_LIST::BuildSheetList( SCH_SHEET* aSheet )
|
void SCH_SHEET_LIST::BuildSheetList( SCH_SHEET* aSheet )
|
||||||
{
|
{
|
||||||
if( m_List == NULL )
|
if( m_List == NULL )
|
||||||
|
|
|
@ -53,18 +53,15 @@
|
||||||
class SCH_MARKER;
|
class SCH_MARKER;
|
||||||
|
|
||||||
|
|
||||||
/****************************************/
|
/**
|
||||||
/* class to handle and access to a sheet */
|
* Class SCH_SHEET_PATH
|
||||||
/* a 'path' so to speak.. */
|
* handles access to a sheet by way of a path.
|
||||||
/****************************************/
|
* <p>
|
||||||
|
|
||||||
/*
|
|
||||||
* The member m_sheets stores the list of sheets from the first (usually
|
* The member m_sheets stores the list of sheets from the first (usually
|
||||||
* g_RootSheet)
|
* g_RootSheet) to a given sheet in last position.
|
||||||
* to a given sheet in last position.
|
* The _last_ sheet is usually the sheet we want to select or reach (which is
|
||||||
* The last sheet is usually the sheet we want to select or reach. So Last()
|
* what the function Last() returns).
|
||||||
* return this last sheet
|
* Others sheets constitute the "path" from the first to the last sheet.
|
||||||
* Others sheets are the "path" from the first to the last sheet
|
|
||||||
*/
|
*/
|
||||||
class SCH_SHEET_PATH
|
class SCH_SHEET_PATH
|
||||||
{
|
{
|
||||||
|
@ -77,7 +74,7 @@ public:
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SCH_SHEET_PATH();
|
SCH_SHEET_PATH();
|
||||||
~SCH_SHEET_PATH() { };
|
// ~SCH_SHEET_PATH() { };
|
||||||
|
|
||||||
void Clear()
|
void Clear()
|
||||||
{
|
{
|
||||||
|
@ -215,15 +212,14 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
/*******************************************************/
|
/**
|
||||||
/* Class to handle the list of *Sheets* in a hierarchy */
|
* Class SCH_SHEET_LIST
|
||||||
/*******************************************************/
|
* handles the list of Sheets in a hiearchy.
|
||||||
|
* Sheets are not unique, there can be many sheets with the same
|
||||||
/* sheets are not unique - can have many sheets with the same
|
|
||||||
* filename and the same SCH_SCREEN reference.
|
* filename and the same SCH_SCREEN reference.
|
||||||
* the schematic (SCH_SCREEN) is shared between these sheets,
|
* The schematic (SCH_SCREEN) is shared between these sheets,
|
||||||
* and component references are specific to a sheet path.
|
* and component references are specific to a sheet path.
|
||||||
* When a sheet is entered, component references and sheet number are updated
|
* When a sheet is entered, component references and sheet number are updated.
|
||||||
*/
|
*/
|
||||||
class SCH_SHEET_LIST
|
class SCH_SHEET_LIST
|
||||||
{
|
{
|
||||||
|
@ -243,9 +239,12 @@ private:
|
||||||
SCH_SHEET_PATH m_currList;
|
SCH_SHEET_PATH m_currList;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/* The constructor: build the list of sheets from aSheet.
|
|
||||||
* If aSheet == NULL (default) build the whole list of sheets in hierarchy
|
/**
|
||||||
* So usually call it with no param.
|
* Constructor
|
||||||
|
* builds the list of sheets from aSheet.
|
||||||
|
* If aSheet == NULL (default) build the whole list of sheets in hierarchy.
|
||||||
|
* So usually call it with no parameter.
|
||||||
*/
|
*/
|
||||||
SCH_SHEET_LIST( SCH_SHEET* aSheet = NULL );
|
SCH_SHEET_LIST( SCH_SHEET* aSheet = NULL );
|
||||||
|
|
||||||
|
@ -256,40 +255,45 @@ public:
|
||||||
m_List = NULL;
|
m_List = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
/** Function GetCount()
|
* Function GetCount()
|
||||||
* @return the number of sheets in list:
|
* @return the number of sheets in list:
|
||||||
* usually the number of sheets found in the whole hierarchy
|
* usually the number of sheets found in the whole hierarchy
|
||||||
*/
|
*/
|
||||||
int GetCount() { return m_count; }
|
int GetCount() { return m_count; }
|
||||||
|
|
||||||
/** Function GetFirst
|
/**
|
||||||
|
* Function GetFirst
|
||||||
* @return the first item (sheet) in m_List and prepare calls to GetNext()
|
* @return the first item (sheet) in m_List and prepare calls to GetNext()
|
||||||
*/
|
*/
|
||||||
SCH_SHEET_PATH* GetFirst();
|
SCH_SHEET_PATH* GetFirst();
|
||||||
|
|
||||||
/** Function GetNext
|
/**
|
||||||
|
* Function GetNext
|
||||||
* @return the next item (sheet) in m_List or NULL if no more item in
|
* @return the next item (sheet) in m_List or NULL if no more item in
|
||||||
* sheet list
|
* sheet list
|
||||||
*/
|
*/
|
||||||
SCH_SHEET_PATH* GetNext();
|
SCH_SHEET_PATH* GetNext();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the last sheet in the sheet list.
|
* Function GetLast
|
||||||
|
* returns the last sheet in the sheet list.
|
||||||
*
|
*
|
||||||
* @return Last sheet in the list or NULL if sheet list is empty.
|
* @return Last sheet in the list or NULL if sheet list is empty.
|
||||||
*/
|
*/
|
||||||
SCH_SHEET_PATH* GetLast();
|
SCH_SHEET_PATH* GetLast();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get the previous sheet in the sheet list.
|
* Function GetPrevious
|
||||||
|
* returns the previous sheet in the sheet list.
|
||||||
*
|
*
|
||||||
* @return The previous sheet in the sheet list or NULL if already at the
|
* @return The previous sheet in the sheet list or NULL if already at the
|
||||||
* beginning of the list.
|
* beginning of the list.
|
||||||
*/
|
*/
|
||||||
SCH_SHEET_PATH* GetPrevious();
|
SCH_SHEET_PATH* GetPrevious();
|
||||||
|
|
||||||
/** Function GetSheet
|
/**
|
||||||
|
* Function GetSheet
|
||||||
* @return the item (sheet) in aIndex position in m_List or NULL if less
|
* @return the item (sheet) in aIndex position in m_List or NULL if less
|
||||||
* than index items
|
* than index items
|
||||||
* @param aIndex = index in sheet list to get the sheet
|
* @param aIndex = index in sheet list to get the sheet
|
||||||
|
@ -297,7 +301,8 @@ public:
|
||||||
SCH_SHEET_PATH* GetSheet( int aIndex );
|
SCH_SHEET_PATH* GetSheet( int aIndex );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Search the entire schematic for the next schematic object.
|
* Function FindNextItem
|
||||||
|
* searches the entire schematic for the next schematic object.
|
||||||
*
|
*
|
||||||
* @param aType - The type of schematic item to find.
|
* @param aType - The type of schematic item to find.
|
||||||
* @param aSheetFound - The sheet the item was found in. NULL if the next item
|
* @param aSheetFound - The sheet the item was found in. NULL if the next item
|
||||||
|
@ -310,7 +315,8 @@ public:
|
||||||
SCH_ITEM* aLastItem = NULL, bool aWrap = true );
|
SCH_ITEM* aLastItem = NULL, bool aWrap = true );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Search the entire schematic for the previous schematic item.
|
* Function FindPreviousItem
|
||||||
|
* searches the entire schematic for the previous schematic item.
|
||||||
*
|
*
|
||||||
* @param aType - The type of schematic item to find.
|
* @param aType - The type of schematic item to find.
|
||||||
* @param aSheetFound - The sheet the item was found in. NULL if the previous item
|
* @param aSheetFound - The sheet the item was found in. NULL if the previous item
|
||||||
|
@ -323,7 +329,8 @@ public:
|
||||||
SCH_ITEM* aLastItem = NULL, bool aWrap = true );
|
SCH_ITEM* aLastItem = NULL, bool aWrap = true );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Search the entire schematic for the next item that matches the search criteria.
|
* Function MatchNextItem
|
||||||
|
* searches the entire schematic for the next item that matches the search criteria.
|
||||||
*
|
*
|
||||||
* @param aSearchData - Criteria to search item against.
|
* @param aSearchData - Criteria to search item against.
|
||||||
* @param aSheetFound - The sheet the item was found in. NULL if the next item
|
* @param aSheetFound - The sheet the item was found in. NULL if the next item
|
||||||
|
@ -337,12 +344,15 @@ public:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
/** Function BuildSheetList
|
/**
|
||||||
* Build the list of sheets and their sheet path from the aSheet sheet
|
* Function BuildSheetList
|
||||||
* if aSheet = g_RootSheet, the full sheet path and sheet list is built
|
* builds the list of sheets and their sheet path from \a aSheet.
|
||||||
* @param aSheet = the starting sheet from the built is made
|
* If aSheet = g_RootSheet, the full sheet path and sheet list is built
|
||||||
|
*
|
||||||
|
* @param aSheet is the starting sheet from which the list is built,
|
||||||
|
* or NULL indicating that g_RootSheet should be used.
|
||||||
*/
|
*/
|
||||||
void BuildSheetList( SCH_SHEET* sheet );
|
void BuildSheetList( SCH_SHEET* sheet );
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* CLASS_DRAWSHEET_PATH_H */
|
#endif // CLASS_DRAWSHEET_PATH_H
|
||||||
|
|
|
@ -216,18 +216,6 @@ void SCH_FIELD::SwapData( SCH_FIELD* copyitem )
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* return True if the field is void, i.e.:
|
|
||||||
* contains "~" or ""
|
|
||||||
*/
|
|
||||||
bool SCH_FIELD::IsVoid()
|
|
||||||
{
|
|
||||||
if( m_Text.IsEmpty() || m_Text == wxT( "~" ) )
|
|
||||||
return true;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Function GetBoundaryBox()
|
* Function GetBoundaryBox()
|
||||||
* @return an EDA_Rect contains the real (user coordinates) boundary box for
|
* @return an EDA_Rect contains the real (user coordinates) boundary box for
|
||||||
|
|
|
@ -47,11 +47,20 @@ public:
|
||||||
return wxT( "SCH_FIELD" );
|
return wxT( "SCH_FIELD" );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Place( WinEDA_SchematicFrame* frame, wxDC* DC );
|
void Place( WinEDA_SchematicFrame* frame, wxDC* DC );
|
||||||
|
|
||||||
EDA_Rect GetBoundaryBox() const;
|
EDA_Rect GetBoundaryBox() const;
|
||||||
bool IsVoid();
|
|
||||||
|
/**
|
||||||
|
* Function IsVoid
|
||||||
|
* returns true if the field is either empty or holds "~".
|
||||||
|
*/
|
||||||
|
bool IsVoid()
|
||||||
|
{
|
||||||
|
size_t len = m_Text.Len();
|
||||||
|
return len == 0 || ( len == 1 && m_Text[0] == wxChar( '~' ) );
|
||||||
|
}
|
||||||
|
|
||||||
void SwapData( SCH_FIELD* copyitem );
|
void SwapData( SCH_FIELD* copyitem );
|
||||||
|
|
||||||
/** Function ImportValues
|
/** Function ImportValues
|
||||||
|
|
|
@ -9,6 +9,7 @@
|
||||||
|
|
||||||
#include "dialog_build_BOM_base.h"
|
#include "dialog_build_BOM_base.h"
|
||||||
|
|
||||||
|
|
||||||
class DIALOG_BUILD_BOM : public DIALOG_BUILD_BOM_BASE
|
class DIALOG_BUILD_BOM : public DIALOG_BUILD_BOM_BASE
|
||||||
{
|
{
|
||||||
private:
|
private:
|
||||||
|
@ -27,25 +28,36 @@ private:
|
||||||
bool aIncludeSubComponents,
|
bool aIncludeSubComponents,
|
||||||
char aExportSeparatorSymbol,
|
char aExportSeparatorSymbol,
|
||||||
bool aRunBrowser);
|
bool aRunBrowser);
|
||||||
|
|
||||||
void GenereListeOfItems(const wxString & FullFileName, bool aIncludeSubComponents );
|
void GenereListeOfItems(const wxString & FullFileName, bool aIncludeSubComponents );
|
||||||
void CreateExportList(const wxString & FullFileName, bool aIncludeSubComponents);
|
void CreateExportList(const wxString & FullFileName, bool aIncludeSubComponents);
|
||||||
void CreatePartsList(const wxString & FullFileName, bool aIncludeSubComponents);
|
|
||||||
|
/**
|
||||||
|
* Function CreateParstList
|
||||||
|
* prints a list of components, in a form which can be imported by a
|
||||||
|
* spreadsheet. Form is:
|
||||||
|
* cmp value; number of components; <footprint>; <field1>; ...;
|
||||||
|
* list of references having the same value
|
||||||
|
*/
|
||||||
|
void CreatePartsList( const wxString& aFullFileName, bool aIncludeSubComponents );
|
||||||
|
|
||||||
int PrintComponentsListByRef( FILE * f, std::vector <OBJ_CMP_TO_LIST>& aList,
|
int PrintComponentsListByRef( FILE * f, std::vector <OBJ_CMP_TO_LIST>& aList,
|
||||||
bool CompactForm, bool aIncludeSubComponents );
|
bool CompactForm, bool aIncludeSubComponents );
|
||||||
|
|
||||||
int PrintComponentsListByVal( FILE *f, std::vector <OBJ_CMP_TO_LIST>& aList,
|
int PrintComponentsListByVal( FILE *f, std::vector <OBJ_CMP_TO_LIST>& aList,
|
||||||
bool aIncludeSubComponents);
|
bool aIncludeSubComponents);
|
||||||
|
|
||||||
int PrintComponentsListByPart( FILE *f, std::vector <OBJ_CMP_TO_LIST>& aList,
|
int PrintComponentsListByPart( FILE *f, std::vector <OBJ_CMP_TO_LIST>& aList,
|
||||||
bool aIncludeSubComponents);
|
bool aIncludeSubComponents);
|
||||||
void PrintFieldData(FILE * f, SCH_COMPONENT * DrawLibItem, bool CompactForm = FALSE);
|
|
||||||
bool IsFieldChecked(int aFieldId);
|
|
||||||
|
|
||||||
|
void PrintFieldData(FILE * f, SCH_COMPONENT * DrawLibItem, bool CompactForm = FALSE);
|
||||||
|
|
||||||
|
bool IsFieldChecked(int aFieldId);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
DIALOG_BUILD_BOM( WinEDA_DrawFrame* parent );
|
DIALOG_BUILD_BOM( WinEDA_DrawFrame* parent );
|
||||||
~DIALOG_BUILD_BOM() {};
|
// ~DIALOG_BUILD_BOM() {};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif // _DIALOG_BUILD_BOM_H_
|
||||||
|
|
||||||
#endif
|
|
||||||
// _DIALOG_BUILD_BOM_H_
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -45,6 +45,11 @@ enum TypeNetForm {
|
||||||
*/
|
*/
|
||||||
class OBJ_CMP_TO_LIST
|
class OBJ_CMP_TO_LIST
|
||||||
{
|
{
|
||||||
|
private:
|
||||||
|
/// Component reference prefix, without number (for IC1, this is IC) )
|
||||||
|
std::string m_Ref; // it's private, use the accessors please
|
||||||
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
SCH_COMPONENT* m_RootCmp; // the component in schematic
|
SCH_COMPONENT* m_RootCmp; // the component in schematic
|
||||||
LIB_COMPONENT* m_Entry; // the source component in library
|
LIB_COMPONENT* m_Entry; // the source component in library
|
||||||
|
@ -57,8 +62,6 @@ public:
|
||||||
* components */
|
* components */
|
||||||
wxString* m_Value; /* Component value (same for all
|
wxString* m_Value; /* Component value (same for all
|
||||||
* instances) */
|
* instances) */
|
||||||
char m_Reference[32]; /* Component reference prefix, without
|
|
||||||
* number (for IC1, this is IC) ) */
|
|
||||||
int m_NumRef; /* Reference number (for IC1, this is
|
int m_NumRef; /* Reference number (for IC1, this is
|
||||||
* 1) ) depending on sheet path*/
|
* 1) ) depending on sheet path*/
|
||||||
int m_Flag; /* flag for computations */
|
int m_Flag; /* flag for computations */
|
||||||
|
@ -73,11 +76,32 @@ public:
|
||||||
m_TimeStamp = 0;
|
m_TimeStamp = 0;
|
||||||
m_IsNew = false;
|
m_IsNew = false;
|
||||||
m_Value = NULL;
|
m_Value = NULL;
|
||||||
m_Reference[0] = 0;
|
|
||||||
m_NumRef = 0;
|
m_NumRef = 0;
|
||||||
m_Flag = 0;
|
m_Flag = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Some accessors which hide the strategy of how the reference is stored,
|
||||||
|
thereby making it easy to change that strategy.
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
void SetRef( const wxString& aReference )
|
||||||
|
{
|
||||||
|
m_Ref = CONV_TO_UTF8( aReference );
|
||||||
|
}
|
||||||
|
wxString GetRef() const
|
||||||
|
{
|
||||||
|
return CONV_FROM_UTF8( m_Ref.c_str() );
|
||||||
|
}
|
||||||
|
void SetRefStr( const std::string& aReference )
|
||||||
|
{
|
||||||
|
m_Ref = aReference;
|
||||||
|
}
|
||||||
|
const char* GetRefStr() const
|
||||||
|
{
|
||||||
|
return m_Ref.c_str();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int CompareValue( const OBJ_CMP_TO_LIST& item ) const
|
int CompareValue( const OBJ_CMP_TO_LIST& item ) const
|
||||||
{
|
{
|
||||||
|
@ -87,7 +111,7 @@ public:
|
||||||
|
|
||||||
int CompareRef( const OBJ_CMP_TO_LIST& item ) const
|
int CompareRef( const OBJ_CMP_TO_LIST& item ) const
|
||||||
{
|
{
|
||||||
return strnicmp( m_Reference, item.m_Reference, 32 );
|
return m_Ref.compare( item.m_Ref );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue