diff --git a/eeschema/annotate.cpp b/eeschema/annotate.cpp index a4866c5303..458da4e4a0 100644 --- a/eeschema/annotate.cpp +++ b/eeschema/annotate.cpp @@ -43,18 +43,6 @@ static void ComputeReferenceNumber( SCH_REFERENCE_LIST& aComponentsList, bool aUseSheetNum, int aSheetIntervalId ); -/** - * Search in the sorted list of components, for a given component an other - * component with the same reference and a given part unit. Mainly used to - * manage multiple parts per package components in aComponentsList. - * @param aObjet = index in aComponentsList for the given SCH_REFERENCE - * item to test - * @param Unit = the given unit number to search - * @param aComponentsList = list of items to examine - * @return index in aComponentsList if found or -1 if not found - */ -static int ExistUnit( int aObjet, int aUnit, SCH_REFERENCE_LIST& aComponentList ); - /** * Function DeleteAnnotation * Remove current component annotations @@ -105,12 +93,11 @@ void SCH_EDIT_FRAME::DeleteAnnotation( bool aCurrentSheetOnly ) * for each sheet annotation starts from sheet number * 100 * ( the first sheet uses 100 to 199, the second 200 to 299 ... ) */ -void SCH_EDIT_FRAME::AnnotateComponents( - bool aAnnotateSchematic, - int aSortOption, - int aAlgoOption, - bool aResetAnnotation, - bool aRepairsTimestamps ) +void SCH_EDIT_FRAME::AnnotateComponents( bool aAnnotateSchematic, + int aSortOption, + int aAlgoOption, + bool aResetAnnotation, + bool aRepairsTimestamps ) { SCH_REFERENCE_LIST references; @@ -158,22 +145,23 @@ void SCH_EDIT_FRAME::AnnotateComponents( /* Break full components reference in name (prefix) and number: * example: IC1 become IC, and 1 */ - references.SplitReferences( ); + references.SplitReferences(); switch( aSortOption ) { default: case 0: - references.SortCmpByXCoordinate(); + references.SortByXCoordinate(); break; case 1: - references.SortCmpByYCoordinate(); + references.SortByYCoordinate(); break; } bool useSheetNum = false; int idStep = 100; + switch( aAlgoOption ) { default: @@ -198,74 +186,15 @@ void SCH_EDIT_FRAME::AnnotateComponents( CheckAnnotate( NULL, !aAnnotateSchematic ); OnModify(); - // Update on screen refences, that can be modified by previous calculations: + // Update on screen references, that can be modified by previous calculations: m_CurrentSheet->UpdateAllScreenReferences(); SetSheetNumberAndCount(); DrawPanel->Refresh( true ); } -#ifdef USE_OLD_ALGO -/** helper function - * Search the last used (greatest) reference number in the component list - * for the prefix reference given by Objet - * The component list must be sorted. - * - * @param aObjet = reference item ( aComponentsList[aObjet].m_TextRef is - * the search pattern) - * @param aComponentsList = list of items - * @param aMinValue = min value for the current search - */ -static int GetLastNumberInReference( int aObjet,SCH_REFERENCE_LIST& aComponentsList, - int aMinValue ) -{ - int lastNumber = aMinValue; - - for( unsigned ii = 0; ii < aComponentsList.GetCount(); ii++ ) - { - // search only for the current reference prefix: - if( aComponentsList[aObjet].CompareRef( aComponentsList[ii] ) != 0 ) - continue; - - // update max value for the current reference prefix - if( lastNumber < aComponentsList[ii].m_NumRef ) - lastNumber = aComponentsList[ii].m_NumRef; - } - - return lastNumber; -} - -#else -/** - * helper function BuildRefIdInUseList - * creates the list of reference numbers in use for a given reference prefix. - * This list is read by CreateFirstFreeRefId to fing not yet used reference Id. - * @see CreateFirstFreeRefId - * @param aObjet = the current component index to use for reference prefix filtering. - * @param aComponentsList = the full list of components - * @param aIdList = the buffer to fill - * @param aMinRefId = the min id value to store. all values < aMinRefId are ignored - */ -static void BuildRefIdInUseList( int aObjet,SCH_REFERENCE_LIST& aComponentsList, - std::vector& aIdList, int aMinRefId ) -{ - aIdList.clear(); - - for( unsigned ii = 0; ii < aComponentsList.GetCount(); ii++ ) - { - if( ( aComponentsList[aObjet].CompareRef( aComponentsList[ii] ) == 0 ) - && ( aComponentsList[ii].m_NumRef >= aMinRefId ) ) - aIdList.push_back( aComponentsList[ii].m_NumRef ); - } - sort( aIdList.begin(), aIdList.end() ); - - // Ensure each reference Id appears only once - // If there are multiple parts per package the same Id will be stored for each part. - std::vector::iterator new_end = unique( aIdList.begin(), aIdList.end() ); - if( new_end != aIdList.end() ) - aIdList.erase(new_end, aIdList.end() ); -} +#ifndef USE_OLD_ALGO /** * helper function CreateFirstFreeRefId * Search for a free ref Id inside a list of reference numbers in use. @@ -279,13 +208,14 @@ static void BuildRefIdInUseList( int aObjet,SCH_REFERENCE_LIST& aComponentsList * @return a free (not yet used) Id * and this new id is added in list */ -static int CreateFirstFreeRefId( std::vector& aIdList, int aFirstValue ) +static int CreateFirstFreeRefId( std::vector& aIdList, int aFirstValue ) { int expectedId = aFirstValue; - // We search for expectedId a value >= aFirstValue. + // We search for expected Id a value >= aFirstValue. // Skip existing Id < aFirstValue unsigned ii = 0; + for( ; ii < aIdList.size(); ii++ ) { if( expectedId <= aIdList[ii] ) @@ -294,7 +224,7 @@ static int CreateFirstFreeRefId( std::vector& aIdList, int aFirstValue ) // Ids are sorted by increasing value, from aFirstValue // So we search from aFirstValue the first not used value, i.e. the first hole in list. - for(; ii < aIdList.size(); ii++ ) + for(; ii < aIdList.size(); ii++ ) { if( expectedId != aIdList[ii] ) // This id is not yet used. { @@ -302,6 +232,7 @@ static int CreateFirstFreeRefId( std::vector& aIdList, int aFirstValue ) aIdList.insert(aIdList.begin() + ii, expectedId); return expectedId; } + expectedId++; } @@ -329,17 +260,8 @@ static void ComputeReferenceNumber( SCH_REFERENCE_LIST& aComponentsList, int LastReferenceNumber = 0; int NumberOfUnits, Unit; - /* Components with an invisible reference (power...) always are - * re-annotated. So set their .m_IsNew member to true - */ - for( unsigned ii = 0; ii < aComponentsList.GetCount(); ii++ ) - { - if( aComponentsList[ii].GetRefStr()[0] == '#' ) - { - aComponentsList[ii].m_IsNew = true; - aComponentsList[ii].m_NumRef = 0; - } - } + /* Components with an invisible reference (power...) always are re-annotated. */ + aComponentsList.ResetHiddenReferences(); /* calculate index of the first component with the same reference prefix * than the current component. All components having the same reference @@ -351,47 +273,56 @@ static void ComputeReferenceNumber( SCH_REFERENCE_LIST& aComponentsList, /* calculate the last used number for this reference prefix: */ #ifdef USE_OLD_ALGO int minRefId = 0; + // when using sheet number, ensure ref number >= sheet number* aSheetIntervalId if( aUseSheetNum ) minRefId = aComponentsList[first].m_SheetNum * aSheetIntervalId; - LastReferenceNumber = GetLastNumberInReference( first, aComponentsList, minRefId ); + + LastReferenceNumber = aComponentsList.GetLastReference( first, minRefId ); #else int minRefId = 1; + // when using sheet number, ensure ref number >= sheet number* aSheetIntervalId if( aUseSheetNum ) minRefId = aComponentsList[first].m_SheetNum * aSheetIntervalId + 1; + // This is the list of all Id already in use for a given reference prefix. // Will be refilled for each new reference prefix. std::vectoridList; - BuildRefIdInUseList( first, aComponentsList, idList, minRefId ); + aComponentsList.GetRefsInUse( first, idList, minRefId ); #endif for( unsigned ii = 0; ii < aComponentsList.GetCount(); ii++ ) { if( aComponentsList[ii].m_Flag ) continue; - if( ( aComponentsList[first].CompareRef( aComponentsList[ii] ) != 0 ) || - ( aUseSheetNum && ( aComponentsList[first].m_SheetNum != aComponentsList[ii].m_SheetNum ) ) - ) + + if( ( aComponentsList[first].CompareRef( aComponentsList[ii] ) != 0 ) + || ( aUseSheetNum + && ( aComponentsList[first].m_SheetNum != aComponentsList[ii].m_SheetNum ) ) ) { - /* New reference found: we need a new ref number for this - * reference */ + /* New reference found: we need a new ref number for this reference */ first = ii; #ifdef USE_OLD_ALGO minRefId = 0; + // when using sheet number, ensure ref number >= sheet number* aSheetIntervalId if( aUseSheetNum ) minRefId = aComponentsList[ii].m_SheetNum * aSheetIntervalId; - LastReferenceNumber = GetLastNumberInReference( ii, aComponentsList, minRefId); + + LastReferenceNumber = aComponentsList.GetLastReference( ii, minRefId ); #else minRefId = 1; + // when using sheet number, ensure ref number >= sheet number* aSheetIntervalId if( aUseSheetNum ) minRefId = aComponentsList[ii].m_SheetNum * aSheetIntervalId + 1; - BuildRefIdInUseList( first, aComponentsList, idList, minRefId ); + + aComponentsList.GetRefsInUse( first, idList, minRefId ); #endif } - /* Annotation of one part per package components (trivial case)*/ - if( aComponentsList[ii].m_Entry->GetPartCount() <= 1 ) + + // Annotation of one part per package components (trivial case). + if( aComponentsList[ii].GetLibComponent()->GetPartCount() <= 1 ) { if( aComponentsList[ii].m_IsNew ) { @@ -409,9 +340,8 @@ static void ComputeReferenceNumber( SCH_REFERENCE_LIST& aComponentsList, continue; } - /* Annotation of multi-part components ( n parts per package ) - * (complex case) */ - NumberOfUnits = aComponentsList[ii].m_Entry->GetPartCount(); + /* Annotation of multi-part components ( n parts per package ) (complex case) */ + NumberOfUnits = aComponentsList[ii].GetLibComponent()->GetPartCount(); if( aComponentsList[ii].m_IsNew ) { @@ -424,6 +354,7 @@ static void ComputeReferenceNumber( SCH_REFERENCE_LIST& aComponentsList, if( !aComponentsList[ii].IsPartsLocked() ) aComponentsList[ii].m_Unit = 1; + aComponentsList[ii].m_Flag = 1; } @@ -436,14 +367,12 @@ static void ComputeReferenceNumber( SCH_REFERENCE_LIST& aComponentsList, if( aComponentsList[ii].m_Unit == Unit ) continue; - int found = ExistUnit( ii, Unit, aComponentsList ); + int found = aComponentsList.FindUnit( ii, Unit ); if( found >= 0 ) - continue; /* this unit exists for this reference (unit - * already annotated) */ + continue; /* this unit exists for this reference (unit already annotated) */ - /* Search a component to annotate ( same prefix, same value, - * not annotated) */ + /* Search a component to annotate ( same prefix, same value, not annotated) */ for( unsigned jj = ii + 1; jj < aComponentsList.GetCount(); jj++ ) { if( aComponentsList[jj].m_Flag ) // already tested @@ -458,8 +387,7 @@ static void ComputeReferenceNumber( SCH_REFERENCE_LIST& aComponentsList, if( !aComponentsList[jj].m_IsNew ) continue; - /* Component without reference number found, annotate it - * if possible */ + /* Component without reference number found, annotate it if possible */ if( !aComponentsList[jj].IsPartsLocked() || ( aComponentsList[jj].m_Unit == Unit ) ) { @@ -475,42 +403,6 @@ static void ComputeReferenceNumber( SCH_REFERENCE_LIST& aComponentsList, } -/* - * Search in the sorted list of components, for a given component an other - * component with the same reference and a given part unit. Mainly used to - * manage multiple parts per package components in aComponentsList. - */ -static int ExistUnit( int aObjet, int Unit, SCH_REFERENCE_LIST& aComponentsList ) -{ - int NumRef; - - NumRef = aComponentsList[aObjet].m_NumRef; - - for( unsigned ii = 0; ii < aComponentsList.GetCount(); ii++ ) - { - if( aObjet == (int) ii ) - // Do not compare with itself ! - continue; - if( aComponentsList[ii].m_IsNew ) - // Not already with an updated reference - continue; - if( aComponentsList[ii].m_NumRef != NumRef ) - // Not the same reference number (like 35 in R35) - continue; - if( aComponentsList[aObjet].CompareRef( aComponentsList[ii] ) != 0 ) - // Not the same reference prefix - continue; - if( aComponentsList[ii].m_Unit == Unit ) - { - // A part with the same reference and the given unit is found - return ii; - } - } - - return -1; -} - - /** * Function CheckAnnotate * Check errors relatives to annotation: @@ -542,13 +434,13 @@ int SCH_EDIT_FRAME::CheckAnnotate( wxArrayString* aMessageList, bool aOneSheetOn else GetSheet()->GetComponents( ComponentsList ); - ComponentsList.SortComponentsByRefAndValue(); + ComponentsList.SortByRefAndValue(); /* Break full components reference in name (prefix) and number: example: * IC1 become IC, and 1 */ ComponentsList.SplitReferences(); - /* count not yet annotated items or annottaion error*/ + /* count not yet annotated items or annotation error*/ for( unsigned ii = 0; ii < ComponentsList.GetCount(); ii++ ) { msg.Empty(); @@ -581,7 +473,7 @@ int SCH_EDIT_FRAME::CheckAnnotate( wxArrayString* aMessageList, bool aOneSheetOn // Annotate error if unit selected does not exist ( i.e. > number of parts ) // Can happen if a component has changed in a lib, after a previous annotation - if( MAX( ComponentsList[ii].m_Entry->GetPartCount(), 1 ) < ComponentsList[ii].m_Unit ) + if( MAX( ComponentsList[ii].GetLibComponent()->GetPartCount(), 1 ) < ComponentsList[ii].m_Unit ) { if( ComponentsList[ii].m_NumRef >= 0 ) Buff << ComponentsList[ii].m_NumRef; @@ -594,7 +486,7 @@ int SCH_EDIT_FRAME::CheckAnnotate( wxArrayString* aMessageList, bool aOneSheetOn Buff.Printf( _( " unit %d and no more than %d parts" ), ComponentsList[ii].m_Unit, - ComponentsList[ii].m_Entry->GetPartCount() ); + ComponentsList[ii].GetLibComponent()->GetPartCount() ); msg << Buff; if( aMessageList ) @@ -651,8 +543,8 @@ int SCH_EDIT_FRAME::CheckAnnotate( wxArrayString* aMessageList, bool aOneSheetOn /* Test error if units are different but number of parts per package * too high (ex U3 ( 1 part) and we find U3B this is an error) */ - if( ComponentsList[ii].m_Entry->GetPartCount() - != ComponentsList[ii + 1].m_Entry->GetPartCount() ) + if( ComponentsList[ii].GetLibComponent()->GetPartCount() + != ComponentsList[ii + 1].GetLibComponent()->GetPartCount() ) { if( ComponentsList[ii].m_NumRef >= 0 ) Buff << ComponentsList[ii].m_NumRef; @@ -676,8 +568,7 @@ int SCH_EDIT_FRAME::CheckAnnotate( wxArrayString* aMessageList, bool aOneSheetOn error++; } - /* Error if values are different between units, for the same - * reference */ + /* Error if values are different between units, for the same reference */ int next = ii + 1; if( ComponentsList[ii].CompareValue( ComponentsList[next] ) != 0 ) @@ -723,7 +614,7 @@ int SCH_EDIT_FRAME::CheckAnnotate( wxArrayString* aMessageList, bool aOneSheetOn for( int ii = 0; ( ii < imax ) && ( error < 4 ); ii++ ) { if( ( ComponentsList[ii].m_TimeStamp != ComponentsList[ii + 1].m_TimeStamp ) - || ( ComponentsList[ii].m_SheetPath != ComponentsList[ii + 1].m_SheetPath ) ) + || ( ComponentsList[ii].GetSheetPath() != ComponentsList[ii + 1].GetSheetPath() ) ) continue; /* Same time stamp found. */ @@ -731,7 +622,7 @@ int SCH_EDIT_FRAME::CheckAnnotate( wxArrayString* aMessageList, bool aOneSheetOn wxString full_path; full_path.Printf( wxT( "%s%8.8X" ), - GetChars( ComponentsList[ii].m_SheetPath.Path() ), + GetChars( ComponentsList[ii].GetSheetPath().Path() ), ComponentsList[ii].m_TimeStamp ); cmpref = ComponentsList[ii].GetRef(); diff --git a/eeschema/component_references_lister.cpp b/eeschema/component_references_lister.cpp index 2dd187dd00..cc9b7f4e56 100644 --- a/eeschema/component_references_lister.cpp +++ b/eeschema/component_references_lister.cpp @@ -43,16 +43,8 @@ -/* sort function to annotate items from their position. - * Components are sorted - * by reference - * if same reference: by sheet - * if same sheet, by X pos - * if same X pos, by Y pos - * if same Y pos, by time stamp - */ -bool SCH_REFERENCE_LIST::sortBy_X_Position( const SCH_REFERENCE& item1, - const SCH_REFERENCE& item2 ) +bool SCH_REFERENCE_LIST::sortByXPosition( const SCH_REFERENCE& item1, + const SCH_REFERENCE& item2 ) { int ii = item1.CompareRef( item2 ); @@ -69,16 +61,8 @@ bool SCH_REFERENCE_LIST::sortBy_X_Position( const SCH_REFERENCE& item1, } -/* sort function to annotate items by their position. - * Components are sorted - * by reference - * if same reference: by sheet - * if same sheet, by Y pos - * if same Y pos, by X pos - * if same X pos, by time stamp - */ -bool SCH_REFERENCE_LIST::sortBy_Y_Position( const SCH_REFERENCE& item1, - const SCH_REFERENCE& item2 ) +bool SCH_REFERENCE_LIST::sortByYPosition( const SCH_REFERENCE& item1, + const SCH_REFERENCE& item2 ) { int ii = item1.CompareRef( item2 ); @@ -94,16 +78,9 @@ bool SCH_REFERENCE_LIST::sortBy_Y_Position( const SCH_REFERENCE& item1, return ii < 0; } -/* - * sort function to annotate items by value - * Components are sorted - * by reference - * if same reference: by value - * if same value: by unit number - * if same unit number, by sheet - * if same sheet, by position X, and Y - */ -bool SCH_REFERENCE_LIST::sortByRefAndValue( const SCH_REFERENCE& item1, const SCH_REFERENCE& item2 ) + +bool SCH_REFERENCE_LIST::sortByRefAndValue( const SCH_REFERENCE& item1, + const SCH_REFERENCE& item2 ) { int ii = item1.CompareRef( item2 ); if( ii == 0 ) @@ -122,13 +99,9 @@ bool SCH_REFERENCE_LIST::sortByRefAndValue( const SCH_REFERENCE& item1, const SC return ii < 0; } -/* sort function for for list by values - * components are sorted - * by value - * if same value: by reference - * if same reference: by unit number - */ -bool SCH_REFERENCE_LIST::sortComponentsByValueOnly( const SCH_REFERENCE& item1, const SCH_REFERENCE& item2 ) + +bool SCH_REFERENCE_LIST::sortByValueOnly( const SCH_REFERENCE& item1, + const SCH_REFERENCE& item2 ) { int ii; const wxString* Text1, * Text2; @@ -150,16 +123,9 @@ bool SCH_REFERENCE_LIST::sortComponentsByValueOnly( const SCH_REFERENCE& item1, return ii < 0; } -/** - * Function sortComponentsByReferenceOnly - * compare function for sorting in BOM creation. - * components are sorted - * by reference - * if same reference: by value - * if same value: by unit number - */ -bool SCH_REFERENCE_LIST::sortComponentsByReferenceOnly( const SCH_REFERENCE& item1, - const SCH_REFERENCE& item2 ) + +bool SCH_REFERENCE_LIST::sortByReferenceOnly( const SCH_REFERENCE& item1, + const SCH_REFERENCE& item2 ) { int ii; const wxString* Text1, * Text2; @@ -182,12 +148,8 @@ bool SCH_REFERENCE_LIST::sortComponentsByReferenceOnly( const SCH_REFERENCE& ite } -/***************************************************************************** - * qsort function to annotate items by value - * Components are sorted by time stamp - *****************************************************************************/ bool SCH_REFERENCE_LIST::sortByTimeStamp( const SCH_REFERENCE& item1, - const SCH_REFERENCE& item2 ) + const SCH_REFERENCE& item2 ) { int ii = item1.m_SheetPath.Cmp( item2.m_SheetPath ); @@ -198,10 +160,32 @@ bool SCH_REFERENCE_LIST::sortByTimeStamp( const SCH_REFERENCE& item1, } +int SCH_REFERENCE_LIST::FindUnit( size_t aIndex, int aUnit ) +{ + int NumRef; + + NumRef = componentFlatList[aIndex].m_NumRef; + + for( size_t ii = 0; ii < componentFlatList.size(); ii++ ) + { + if( ( aIndex == ii ) + || ( componentFlatList[ii].m_IsNew ) + || ( componentFlatList[ii].m_NumRef != NumRef ) + || ( componentFlatList[aIndex].CompareRef( componentFlatList[ii] ) != 0 ) ) + continue; + + if( componentFlatList[ii].m_Unit == aUnit ) + return (int) ii; + } + + return -1; +} + + /* Remove sub components from the list, when multiples parts per package are * found in this list */ -void SCH_REFERENCE_LIST::RemoveSubComponentsFromList( ) +void SCH_REFERENCE_LIST::RemoveSubComponentsFromList() { SCH_COMPONENT* libItem; wxString oldName; @@ -209,7 +193,8 @@ void SCH_REFERENCE_LIST::RemoveSubComponentsFromList( ) // The component list **MUST** be sorted by reference and by unit number // in order to find all parts of a component - SortComponentsByReferenceOnly(); + SortByReferenceOnly(); + for( unsigned ii = 0; ii < componentFlatList.size(); ii++ ) { libItem = componentFlatList[ii].m_RootCmp; @@ -220,18 +205,72 @@ void SCH_REFERENCE_LIST::RemoveSubComponentsFromList( ) if( !oldName.IsEmpty() ) { - if( oldName == currName ) // currName is a subpart of oldName: - // remove it + if( oldName == currName ) // currName is a subpart of oldName: remove it { componentFlatList.erase( componentFlatList.begin() + ii ); ii--; } } + oldName = currName; } } +void SCH_REFERENCE_LIST::ResetHiddenReferences() +{ + for( unsigned ii = 0; ii < componentFlatList.size(); ii++ ) + { + if( componentFlatList[ii].GetRefStr()[0] == '#' ) + { + componentFlatList[ii].m_IsNew = true; + componentFlatList[ii].m_NumRef = 0; + } + } +} + + +void SCH_REFERENCE_LIST::GetRefsInUse( int aIndex, std::vector< int >& aIdList, int aMinRefId ) +{ + aIdList.clear(); + + for( unsigned ii = 0; ii < componentFlatList.size(); ii++ ) + { + if( ( componentFlatList[aIndex].CompareRef( componentFlatList[ii] ) == 0 ) + && ( componentFlatList[ii].m_NumRef >= aMinRefId ) ) + aIdList.push_back( componentFlatList[ii].m_NumRef ); + } + + sort( aIdList.begin(), aIdList.end() ); + + // Ensure each reference number appears only once. If there are components with + // multiple parts per package the same number will be stored for each part. + std::vector< int >::iterator it = unique( aIdList.begin(), aIdList.end() ); + + // Using the C++ unique algorithm only moves the duplicate entries to the end of + // of the array. This removes the duplicate entries from the array. + aIdList.resize( it - aIdList.begin() ); +} + + +int SCH_REFERENCE_LIST::GetLastReference( int aIndex, int aMinValue ) +{ + int lastNumber = aMinValue; + + for( unsigned ii = 0; ii < componentFlatList.size(); ii++ ) + { + // search only for the current reference prefix: + if( componentFlatList[aIndex].CompareRef( componentFlatList[ii] ) != 0 ) + continue; + + // update max value for the current reference prefix + if( lastNumber < componentFlatList[ii].m_NumRef ) + lastNumber = componentFlatList[ii].m_NumRef; + } + + return lastNumber; +} + SCH_REFERENCE::SCH_REFERENCE( SCH_COMPONENT* aComponent, LIB_COMPONENT* aLibComponent, SCH_SHEET_PATH& aSheetPath ) diff --git a/eeschema/dialogs/dialog_build_BOM.cpp b/eeschema/dialogs/dialog_build_BOM.cpp index 956bb1cb05..a55745710b 100644 --- a/eeschema/dialogs/dialog_build_BOM.cpp +++ b/eeschema/dialogs/dialog_build_BOM.cpp @@ -408,7 +408,7 @@ void DIALOG_BUILD_BOM::CreatePartsList( const wxString& aFullFileName, bool aInc cmplist.RemoveSubComponentsFromList(); // sort component list by value - cmplist.SortComponentsByValueOnly( ); + cmplist.SortByValueOnly( ); PrintComponentsListByPart( f, cmplist,aIncludeSubComponents ); fclose( f ); @@ -440,7 +440,7 @@ void DIALOG_BUILD_BOM::CreateExportList( const wxString& aFullFileName, sheetList.GetComponents( cmplist, false ); // sort component list - cmplist.SortComponentsByReferenceOnly( ); + cmplist.SortByReferenceOnly( ); if( !aIncludeSubComponents ) cmplist.RemoveSubComponentsFromList(); @@ -489,7 +489,7 @@ void DIALOG_BUILD_BOM::GenereListeOfItems( const wxString& aFullFileName, fprintf( f, "%s >> Creation date: %s\n", CONV_TO_UTF8( Title ), Line ); // sort component list - cmplist.SortComponentsByReferenceOnly(); + cmplist.SortByReferenceOnly(); if( !aIncludeSubComponents ) cmplist.RemoveSubComponentsFromList(); @@ -499,7 +499,7 @@ void DIALOG_BUILD_BOM::GenereListeOfItems( const wxString& aFullFileName, if( m_ListCmpbyValItems->GetValue() ) { - cmplist.SortComponentsByValueOnly(); + cmplist.SortByValueOnly(); PrintComponentsListByVal( f, cmplist, aIncludeSubComponents ); } } @@ -632,7 +632,7 @@ int DIALOG_BUILD_BOM::PrintComponentsListByRef( FILE* f, // Print list of items for( unsigned ii = 0; ii < aList.GetCount(); ii++ ) { - EDA_ITEM* item = aList[ii].m_RootCmp; + EDA_ITEM* item = aList[ii].GetComponent(); if( item == NULL ) continue; @@ -680,7 +680,7 @@ int DIALOG_BUILD_BOM::PrintComponentsListByRef( FILE* f, if( aIncludeSubComponents ) { - msg = aList[ii].m_SheetPath.PathHumanReadable(); + msg = aList[ii].GetSheetPath().PathHumanReadable(); BASE_SCREEN * screen = (BASE_SCREEN*) comp->GetParent(); if( screen ) @@ -747,10 +747,10 @@ int DIALOG_BUILD_BOM::PrintComponentsListByPart( FILE* f, SCH_REFERENCE_LIST& aL for( unsigned ii = 0; ii < aList.GetCount(); ii++ ) { - currCmp = (SCH_COMPONENT*) aList[ii].m_RootCmp; + currCmp = aList[ii].GetComponent(); if( ii < aList.GetCount() -1 ) - nextCmp = aList[ii+1].m_RootCmp; + nextCmp = aList[ii+1].GetComponent(); else nextCmp = NULL; @@ -882,7 +882,7 @@ int DIALOG_BUILD_BOM::PrintComponentsListByVal( FILE* f, for( unsigned ii = 0; ii < aList.GetCount(); ii++ ) { - schItem = aList[ii].m_RootCmp; + schItem = aList[ii].GetComponent(); if( schItem == NULL ) continue; @@ -918,7 +918,7 @@ int DIALOG_BUILD_BOM::PrintComponentsListByVal( FILE* f, BASE_SCREEN * screen = (BASE_SCREEN*) DrawLibItem->GetParent(); if( screen ) { - msg = aList[ii].m_SheetPath.PathHumanReadable(); + msg = aList[ii].GetSheetPath().PathHumanReadable(); fprintf( f, " (Sheet %s)", CONV_TO_UTF8( msg ) ); msg = m_Parent->GetXYSheetReferences( screen, DrawLibItem->m_Pos ); fprintf( f, " (loc %s)", CONV_TO_UTF8( msg ) ); diff --git a/eeschema/lib_pin.cpp b/eeschema/lib_pin.cpp index 29139d0fe9..6ee5084c0d 100644 --- a/eeschema/lib_pin.cpp +++ b/eeschema/lib_pin.cpp @@ -1841,34 +1841,18 @@ wxArrayString LIB_PIN::GetElectricalTypeNames( void ) } -/** - * Get a list of pin electrical type icons. - * @return List of valid pin electrical type bitmaps symbols in .xpm format - * for menus and dialogs . - */ const char*** LIB_PIN::GetElectricalTypeSymbols( void ) { return s_icons_Pins_Electrical_Type; } -/** - * Get a list of pin orientation icons. - * - * @return List of valid pin orientation bitmaps symbols in .xpm format - * for menus and dialogs . - */ const char*** LIB_PIN::GetOrientationSymbols() { return s_icons_Pins_Orientations; } -/** - * Get a list of pin styles bitmaps for menus and dialogs. - * - * @return List of valid pin electrical type bitmaps symbols in .xpm format. - */ const char*** LIB_PIN::GetStyleSymbols() { return s_icons_Pins_Shapes; diff --git a/eeschema/lib_pin.h b/eeschema/lib_pin.h index 55256c5e67..b1e510899e 100644 --- a/eeschema/lib_pin.h +++ b/eeschema/lib_pin.h @@ -361,7 +361,7 @@ public: static wxArrayString GetOrientationNames(); /** - * Get a list of pin orientation bitmaps for menus and dialogs.. + * Get a list of pin orientation bitmaps for menus and dialogs. * * @return List of valid pin orientation bitmaps symbols in .xpm format */ diff --git a/eeschema/netform.cpp b/eeschema/netform.cpp index 5832e820f6..baaddcffc6 100644 --- a/eeschema/netform.cpp +++ b/eeschema/netform.cpp @@ -1370,16 +1370,13 @@ bool EXPORT_HELP::WriteNetListPCBNEW( SCH_EDIT_FRAME* frame, FILE* f, bool with_ // Get the Component FootprintFilter and put the component in // cmpList if filter is present - LIB_COMPONENT* entry = - CMP_LIBRARY::FindLibraryComponent( comp->GetLibName() ); + LIB_COMPONENT* entry = CMP_LIBRARY::FindLibraryComponent( comp->GetLibName() ); if( entry ) { if( entry->GetFootPrints().GetCount() != 0 ) // Put in list { - cmpList.push_back( SCH_REFERENCE() ); - cmpList.back().m_RootCmp = comp; - cmpList.back().SetRef( comp->GetRef( path ) ); + cmpList.push_back( SCH_REFERENCE( comp, entry, *path ) ); } } @@ -1442,11 +1439,10 @@ bool EXPORT_HELP::WriteNetListPCBNEW( SCH_EDIT_FRAME* frame, FILE* f, bool with_ wxString ref; ret |= fprintf( f, "{ Allowed footprints by component:\n" ); + for( unsigned ii = 0; ii < cmpList.size(); ii++ ) { - SCH_COMPONENT* comp = cmpList[ii].m_RootCmp; - - LIB_COMPONENT* entry = CMP_LIBRARY::FindLibraryComponent( comp->GetLibName() ); + LIB_COMPONENT* entry = cmpList[ii].GetLibComponent(); ref = cmpList[ii].GetRef(); diff --git a/eeschema/netlist.h b/eeschema/netlist.h index 303ce1a2b6..ce0dda4716 100644 --- a/eeschema/netlist.h +++ b/eeschema/netlist.h @@ -39,6 +39,7 @@ class SCH_COMPONENT; +class SCH_REFERENC_LIST; #define NETLIST_HEAD_STRING "EESchema Netlist Version 1.1" @@ -61,16 +62,17 @@ class SCH_REFERENCE private: /// Component reference prefix, without number (for IC1, this is IC) ) std::string m_Ref; // it's private, use the accessors please + SCH_COMPONENT* m_RootCmp; ///< The component associated the reference object. + LIB_COMPONENT* m_Entry; ///< The source component from a library. + wxPoint m_CmpPos; ///< The physical position of the component in schematic + ///< used to annotate by X or Y position + SCH_SHEET_PATH m_SheetPath; ///< The sheet path for this reference. + friend class SCH_REFERENCE_LIST; public: - SCH_COMPONENT* m_RootCmp; // the component in schematic - LIB_COMPONENT* m_Entry; // the source component in library int m_Unit; /* Selected part (For multi parts per - * package) depending on sheet path */ - wxPoint m_CmpPos; // The physical position of the component in schematic - // used to annotate by Y ou Y position - SCH_SHEET_PATH m_SheetPath; /* the sheet path for this component */ + * package) depending on sheet path */ int m_SheetNum; // the sheet num for this component unsigned long m_TimeStamp; /* unique identification number * depending on sheet path */ @@ -100,6 +102,12 @@ public: SCH_REFERENCE( SCH_COMPONENT* aComponent, LIB_COMPONENT* aLibComponent, SCH_SHEET_PATH& aSheetPath ); + SCH_COMPONENT* GetComponent() const { return m_RootCmp; } + + LIB_COMPONENT* GetLibComponent() const { return m_Entry; } + + SCH_SHEET_PATH GetSheetPath() const { return m_SheetPath; } + /** * Function Annotate * updates the annotation of the component according the the current object state. @@ -119,11 +127,11 @@ public: 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() ); @@ -137,32 +145,30 @@ public: return m_Ref.c_str(); } - int CompareValue( const SCH_REFERENCE& item ) const { return m_Value->CmpNoCase( *item.m_Value ); } - int CompareRef( const SCH_REFERENCE& item ) const { return m_Ref.compare( item.m_Ref ); } - bool IsPartsLocked() { return m_Entry->UnitsLocked(); } }; -/* object used in annotation to handle a list of components in schematic - * because in a complex hierarchy, a component is used more than once, - * and its reference is depending on the sheet path - * for the same component, we must create a flat list of components - * used in nelist generation, BOM generation and annotation - */ +/** + * Class SCH_REFERENCE_LIST + * is used create a flattened list of components because in a complex hierarchy, a component + * can used more than once and its reference designator is dependent on the sheet path for the + * same component. This flattened list is used for netlist generation, BOM generation, and + * schematic annotation. + */ class SCH_REFERENCE_LIST { private: @@ -193,20 +199,19 @@ public: * Function GetItem * @return the aIdx item */ - SCH_REFERENCE& GetItem(int aIdx) + SCH_REFERENCE& GetItem( int aIdx ) { return componentFlatList[aIdx]; } /** * Function AddItem - * Add a OBJ_CMP_TO_LIST object in aComponentsList for each component found - * in sheet + * adds a SCH_REFERENCE object to the list of references. * @param aItem - a SCH_REFERENCE item to add */ void AddItem( SCH_REFERENCE& aItem ) { - componentFlatList.push_back( aItem); + componentFlatList.push_back( aItem ); } /** @@ -215,19 +220,18 @@ public: * found in this list. * Useful to create BOM, when a component must appear only once */ - void RemoveSubComponentsFromList( ); + void RemoveSubComponentsFromList(); /* Sort functions: - * Sort functions are used to sort components for annotatioon or BOM generation. + * Sort functions are used to sort components for annotation or BOM generation. * Because sorting depend on we want to do, there are many sort functions. * Note: * When creating BOM, components are fully annotated. - * references are somethink like U3, U5 or R4, R8 + * references are something like U3, U5 or R4, R8 * When annotating, some or all components are not annotated, * i.e. ref is only U or R, with no number. */ - /** * Function SplitReferences * attempts to split all reference designators into a name (U) and number (1). If the @@ -244,10 +248,9 @@ public: /** * function UpdateAnnotation - * Update the reference components for the schematic project (or the current sheet) - * Note: this function does not calculate the reference numbers - * stored in m_NumRef - * So, it must be called after calcultaion of new reference numbers + * Updates the reference components for the schematic project (or the current sheet) + * Note: this function does not calculate the reference numbers stored in m_NumRef + * So, it must be called after calculation of new reference numbers * @see SCH_REFERENCE::Annotate() */ void UpdateAnnotation() @@ -260,23 +263,41 @@ public: } /** - * Function SortCmpByXCoordinate - * sort the flat list by X coordinates. - * The list is always sorted first by ref and sheet + * Function sortByXCoordinate + * sorts the list of references by X position. + *

+ * Components are sorted as follows: + *

    + *
  • Numeric value of reference designator.
  • + *
  • Sheet number.
  • + *
  • X coordinate position.
  • + *
  • Y coordinate position.
  • + *
  • Time stamp.
  • + *
+ *

*/ - void SortCmpByXCoordinate() + void SortByXCoordinate() { - sort( componentFlatList.begin(), componentFlatList.end(), sortBy_X_Position ); + sort( componentFlatList.begin(), componentFlatList.end(), sortByXPosition ); } /** - * Function SortCmpByYCoordinate - * sort the flat list by Y coordinates. - * The list is always sorted first by ref and sheet + * Function sortByYCoordinate + * sorts the list of references by Y position. + *

+ * Components are sorted as follows: + *

    + *
  • Numeric value of reference designator.
  • + *
  • Sheet number.
  • + *
  • Y coordinate position.
  • + *
  • X coordinate position.
  • + *
  • Time stamp.
  • + *
+ *

*/ - void SortCmpByYCoordinate() + void SortByYCoordinate() { - sort( componentFlatList.begin(), componentFlatList.end(), sortBy_Y_Position ); + sort( componentFlatList.begin(), componentFlatList.end(), sortByYPosition ); } /** @@ -290,103 +311,115 @@ public: } /** - * Function SortComponentsByValue - * sort the flat list by Value. - * Values are sorted by numeric values, not by alpahbetic order - * The list is always sorted first by ref + * Function SortByRefAndValue + * sorts the list of references by value. + *

+ * Components are sorted in the following order: + *

    + *
  • Numeric value of reference designator.
  • + *
  • Value of component.
  • + *
  • Unit number when component has multiple parts.
  • + *
  • Sheet number.
  • + *
  • X coordinate position.
  • + *
  • Y coordinate position.
  • + *
+ *

*/ - void SortComponentsByRefAndValue() + void SortByRefAndValue() { sort( componentFlatList.begin(), componentFlatList.end(), sortByRefAndValue ); } /** - * Function SortComponentsByReferenceOnly - * sort the flat list by references - * For BOM, sorted by reference + * Function SortByReferenceOnly + * sorts the list of references by reference. + *

+ * Components are sorted in the following order: + *

    + *
  • Numeric value of reference designator.
  • + *
  • Unit number when component has multiple parts.
  • + *
+ *

*/ - void SortComponentsByReferenceOnly() + void SortByReferenceOnly() { - sort( componentFlatList.begin(), componentFlatList.end(), sortComponentsByReferenceOnly ); + sort( componentFlatList.begin(), componentFlatList.end(), sortByReferenceOnly ); } /** - * Function SortComponentsByValueOnly - * sort the flat list by references - * For BOM, sorted by values + * Function SortByValueOnly + * sort the list of references by value. + *

+ * Components are sorted in the following order: + *

    + *
  • Value of component.
  • + *
  • Numeric value of reference designator.
  • + *
  • Unit number when component has multiple parts.
  • + *
+ *

*/ - void SortComponentsByValueOnly() + void SortByValueOnly() { - sort( componentFlatList.begin(), componentFlatList.end(), sortComponentsByValueOnly ); + sort( componentFlatList.begin(), componentFlatList.end(), sortByValueOnly ); } + /** + * Function GetUnit + * searches the sorted list of components for a another component with the same + * reference and a given part unit. Use this method to manage components with + * multiple parts per package. + * @param aIndex = index in aComponentsList for of given SCH_REFERENCE item to test. + * @param aUnit = the given unit number to search + * @return index in aComponentsList if found or -1 if not found + */ + int FindUnit( size_t aIndex, int aUnit ); + + /** + * Function ResetHiddenReferences + * clears the annotation for all references that have an invisible reference designator. + * Invisible reference designators always have # as the first letter. + */ + void ResetHiddenReferences(); + + /** + * Function GetRefsInUse + * adds all the reference designator numbers greater than \a aMinRefId to \a aIdList + * skipping the reference at \a aIndex. + * @param aIndex = the current component index to use for reference prefix filtering. + * @param aIdList = the buffer to fill + * @param aMinRefId = the min id value to store. all values < aMinRefId are ignored + */ + void GetRefsInUse( int aIndex, std::vector< int >& aIdList, int aMinRefId ); + + /** + * Function GetLastReference + * returns the last used (greatest) reference number in the reference list + * for the prefix reference given by \a aIndex. The component list must be + * sorted. + * + * @param aIndex The index of the reference item used for the search pattern. + * @param aMinValue The minimum value for the current search. + */ + int GetLastReference( int aIndex, int aMinValue ); + private: /* sort functions used to sort componentFlatList */ - /** - * Function sortByRefAndValue - * sort function to annotate items by value - * Components are sorted - * by reference (when used, referenc is only U ot R, with no number) - * if same reference: by value - * if same value: by unit number - * if same unit number, by sheet - * if same sheet, by position X, and Y - * @param item1, item2 = SCH_REFERENCE items to compare - */ static bool sortByRefAndValue( const SCH_REFERENCE& item1, const SCH_REFERENCE& item2 ); - /** - * Function sortBy_X_Position - * sort function to annotate items from their position. - * Components are sorted - * by reference (when used, referenc is only U ot R, with no number) - * if same reference: by sheet - * if same sheet, by X pos - * if same X pos, by Y pos - * if same Y pos, by time stamp - * @param item1, item2 = SCH_REFERENCE items to compare - */ - static bool sortBy_X_Position( const SCH_REFERENCE& item1, const SCH_REFERENCE& item2 ); - /** - * Function sortBy_Y_Position - * sort function to annotate items from their position. - * Components are sorted - * by reference (when used, referenc is only U ot R, with no number) - * if same reference: by sheet - * if same sheet, by Y pos - * if same Y pos, by X pos - * if same X pos, by time stamp - * @param item1, item2 = SCH_REFERENCE items to compare - */ - static bool sortBy_Y_Position( const SCH_REFERENCE& item1, const SCH_REFERENCE& item2 ); + static bool sortByXPosition( const SCH_REFERENCE& item1, const SCH_REFERENCE& item2 ); + + static bool sortByYPosition( const SCH_REFERENCE& item1, const SCH_REFERENCE& item2 ); static bool sortByTimeStamp( const SCH_REFERENCE& item1, const SCH_REFERENCE& item2 ); - /** - * Function sortComponentsByValueOnly - * compare function for sorting in BOM creation. - * components are sorted - * by value - * if same value: by reference - * if same reference: by unit number - * @param item1, item2 = SCH_REFERENCE items to compare - */ + static bool sortByValueOnly( const SCH_REFERENCE& item1, const SCH_REFERENCE& item2 ); - static bool sortComponentsByValueOnly( const SCH_REFERENCE& item1, const SCH_REFERENCE& item2 ); - /** - * Function sortComponentsByReferenceOnly - * compare function for sorting in BOM creation. - * components are sorted - * by reference - * if same reference: by value (happens only for multi parts per package) - * if same value: by unit number - * @param item1, item2 = SCH_REFERENCE items to compare - */ - static bool sortComponentsByReferenceOnly( const SCH_REFERENCE& item1, const SCH_REFERENCE& item2 ); + static bool sortByReferenceOnly( const SCH_REFERENCE& item1, const SCH_REFERENCE& item2 ); }; + /** * helper Class LABEL_OBJECT * is used in build BOM to handle the list of labels in schematic