2011-10-15 13:25:57 +00:00
|
|
|
/*
|
|
|
|
* This program source code file is part of KiCad, a free EDA CAD application.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2009 Jean-Pierre Charras, jaen-pierre.charras@gipsa-lab.inpg.com
|
|
|
|
* Copyright (C) 2011 Wayne Stambaugh <stambaughw@verizon.net>
|
|
|
|
* Copyright (C) 1992-2011 KiCad Developers, see AUTHORS.txt for contributors.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, you may find one here:
|
|
|
|
* http://www.gnu.org/licenses/old-licenses/gpl-2.0.html
|
|
|
|
* or you may search the http://www.gnu.org website for the version 2 license,
|
|
|
|
* or you may write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
|
|
|
*/
|
|
|
|
|
2011-09-30 18:15:37 +00:00
|
|
|
/**
|
|
|
|
* @file sch_sheet_path.h
|
|
|
|
* @brief Definition of the SCH_SHEET_PATH and SCH_SHEET_LIST classes for Eeschema.
|
|
|
|
*/
|
2009-01-04 18:52:57 +00:00
|
|
|
|
|
|
|
#ifndef CLASS_DRAWSHEET_PATH_H
|
|
|
|
#define CLASS_DRAWSHEET_PATH_H
|
|
|
|
|
2012-01-23 04:33:36 +00:00
|
|
|
#include <base_struct.h>
|
2009-01-04 18:52:57 +00:00
|
|
|
|
2011-12-01 16:49:28 +00:00
|
|
|
|
2009-01-06 20:09:32 +00:00
|
|
|
/** Info about complex hierarchies handling:
|
2009-11-03 13:26:31 +00:00
|
|
|
* A hierarchical schematic uses sheets (hierarchical sheets) included in a
|
2009-12-02 21:44:03 +00:00
|
|
|
* given sheet. Each sheet corresponds to a schematic drawing handled by a
|
2009-11-03 13:26:31 +00:00
|
|
|
* SCH_SCREEN structure. A SCH_SCREEN structure contains drawings, and have
|
|
|
|
* a filename to write it's data. Also a SCH_SCREEN display a sheet number
|
|
|
|
* and the name of the sheet.
|
|
|
|
*
|
|
|
|
* In simple (and flat) hierarchies a sheet is linked to a SCH_SCREEN,
|
2009-01-06 20:09:32 +00:00
|
|
|
* and a SCH_SCREEN is used by only one hierarchical sheet.
|
|
|
|
*
|
2009-11-03 13:26:31 +00:00
|
|
|
* In complex hierarchies the same SCH_SCREEN (and its data) is shared between
|
|
|
|
* more than one sheet. Therefore subsheets (like subsheets in a SCH_SCREEN
|
|
|
|
* shared by many sheets) can be also shared. So the same SCH_SCREEN must
|
|
|
|
* handle different components references and parts selection depending on
|
|
|
|
* which sheet is currently selected, and how a given subsheet is selected.
|
|
|
|
* 2 sheets share the same SCH_SCREEN (the same drawings) if they have the
|
|
|
|
* same filename.
|
2009-01-06 20:09:32 +00:00
|
|
|
*
|
2011-09-30 18:15:37 +00:00
|
|
|
* In KiCad each component and sheet receives (when created) an unique
|
2009-11-03 13:26:31 +00:00
|
|
|
* identification called Time Stamp. So each sheet has 2 ids: its time stamp
|
|
|
|
* (that cannot change) and its name ( that can be edited and therefore is
|
2011-09-30 18:15:37 +00:00
|
|
|
* not reliable for strong identification). KiCad uses Time Stamp ( a unique
|
2009-11-03 13:26:31 +00:00
|
|
|
* 32 bit id), to identify sheets in hierarchies.
|
|
|
|
* A given sheet in a hierarchy is fully labeled by its path (or sheet path)
|
|
|
|
* that is the list of time stamp found to access it through the hierarchy
|
|
|
|
* the root sheet is /. All other sheets have a path like /1234ABCD or
|
|
|
|
* /4567FEDC/AA2233DD/. This path can be displayed as human readable sheet
|
|
|
|
* name like: / or /sheet1/include_sheet/ or /sheet2/include_sheet/
|
2009-01-06 20:09:32 +00:00
|
|
|
*
|
|
|
|
* So to know for a given SCH_SCREEN (a given schematic drawings) we must:
|
2009-11-03 13:26:31 +00:00
|
|
|
* 1) Handle all references possibilities.
|
|
|
|
* 2) When acceded by a given selected sheet, display (update) the
|
|
|
|
* corresponding references and sheet path
|
2009-01-06 20:09:32 +00:00
|
|
|
*
|
2009-12-02 21:44:03 +00:00
|
|
|
* The class SCH_SHEET_PATH handles paths used to access a sheet. The class
|
|
|
|
* SCH_SHEET_LIST allows to handle the full (or partial) list of sheets and
|
2009-11-03 13:26:31 +00:00
|
|
|
* their paths in a complex hierarchy. The class EDA_ScreenList allow to
|
|
|
|
* handle the list of SCH_SCREEN. It is useful to clear or save data,
|
|
|
|
* but is not suitable to handle the full complex hierarchy possibilities
|
|
|
|
* (usable in flat and simple hierarchies).
|
2009-01-06 20:09:32 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
2010-11-10 15:30:12 +00:00
|
|
|
class wxFindReplaceData;
|
|
|
|
class SCH_SCREEN;
|
2010-03-16 18:22:59 +00:00
|
|
|
class SCH_MARKER;
|
2011-01-23 21:22:42 +00:00
|
|
|
class SCH_SHEET;
|
2010-11-10 15:30:12 +00:00
|
|
|
class SCH_ITEM;
|
2011-01-01 17:28:21 +00:00
|
|
|
class SCH_REFERENCE_LIST;
|
Modular KiCad Blueprint Milestone B), major portions:
*) When kicad.exe closes a project, close any open KIFACEs so that they cannot
get disassociated from their true PROJECT.
*) Allow loading eeschema library editor from kicad.exe
*) Allow loading pcbnew library editor from kicad.exe
*) Rename LIB_COMPONENT to LIB_PART.
*) Add class PART_LIBS, and PART_LIB.
*) Make PART_LIBS non-global, i.e. PROJECT specific.
*) Implement "data on demand" for PART_LIBS
*) Implement "data on demand" for schematic SEARCH_STACK.
*) Use RSTRINGs to retain eeschema editor's notion of last library and part being edited.
*) Get rid of library search on every SCH_COMPONENT::Draw() call, instead use
a weak pointer.
*) Remove all chdir() calls so projects don't need to be CWD.
*) Romove APPEND support from OpenProjectFiles().
*) Make OpenProjectFiles() robust, even for creating new projects.
*) Load EESCHEMA colors in the KIWAY::OnKiwayStart() rather in window open,
and save them in the .eeschema config file, not in the project file.
*) Fix bug with wxDir() while accessing protected dirs in kicad.exe
*) Consolidate template copying into PROJECT class, not in kicad.exe source.
*) Generally untangle eeschema, making its libraries not global but rather
held in the PROJECT.
2014-08-13 20:28:54 +00:00
|
|
|
class PART_LIBS;
|
2010-03-16 18:22:59 +00:00
|
|
|
|
2015-06-07 20:31:55 +00:00
|
|
|
#define SHEET_NOT_FOUND -1
|
|
|
|
|
|
|
|
|
2015-03-23 11:45:31 +00:00
|
|
|
/**
|
|
|
|
* Type SCH_MULTI_UNIT_REFERENCE_MAP
|
|
|
|
* is used to create a map of reference designators for multi-unit parts.
|
|
|
|
*/
|
|
|
|
typedef std::map<wxString, SCH_REFERENCE_LIST> SCH_MULTI_UNIT_REFERENCE_MAP;
|
2010-03-16 18:22:59 +00:00
|
|
|
|
2010-07-30 21:41:55 +00:00
|
|
|
/**
|
|
|
|
* Class SCH_SHEET_PATH
|
2011-01-23 21:22:42 +00:00
|
|
|
* handles access to a sheet by way of a path.
|
2010-07-30 21:41:55 +00:00
|
|
|
* <p>
|
2011-01-23 21:22:42 +00:00
|
|
|
* The member m_sheets stores the list of sheets from the first (usually
|
|
|
|
* g_RootSheet) to a given sheet in last position.
|
|
|
|
* The _last_ sheet is usually the sheet we want to select or reach (which is
|
|
|
|
* what the function Last() returns).
|
|
|
|
* Others sheets constitute the "path" from the first to the last sheet.
|
2011-03-29 19:33:07 +00:00
|
|
|
* </p>
|
2009-01-07 17:33:18 +00:00
|
|
|
*/
|
2009-12-02 21:44:03 +00:00
|
|
|
class SCH_SHEET_PATH
|
2009-01-04 18:52:57 +00:00
|
|
|
{
|
2011-01-23 21:22:42 +00:00
|
|
|
#define DSLSZ 32 // Max number of levels for a sheet path
|
|
|
|
|
2011-03-29 19:33:07 +00:00
|
|
|
SCH_SHEET* m_sheets[ DSLSZ ];
|
|
|
|
unsigned m_numSheets;
|
2009-01-04 18:52:57 +00:00
|
|
|
|
2011-01-23 21:22:42 +00:00
|
|
|
public:
|
2010-03-16 18:22:59 +00:00
|
|
|
SCH_SHEET_PATH();
|
|
|
|
|
2011-01-23 21:22:42 +00:00
|
|
|
void Clear()
|
|
|
|
{
|
|
|
|
m_numSheets = 0;
|
|
|
|
}
|
2009-01-07 20:09:03 +00:00
|
|
|
|
2015-06-07 20:31:55 +00:00
|
|
|
unsigned GetCount()
|
2011-01-23 21:22:42 +00:00
|
|
|
{
|
|
|
|
return m_numSheets;
|
|
|
|
}
|
|
|
|
|
2015-06-07 20:31:55 +00:00
|
|
|
SCH_SHEET* GetSheet( unsigned index )
|
|
|
|
{
|
|
|
|
if( index < m_numSheets )
|
|
|
|
return m_sheets[index];
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function Cmp
|
2011-01-23 21:22:42 +00:00
|
|
|
* Compare if this is the same sheet path as aSheetPathToTest
|
|
|
|
* @param aSheetPathToTest = sheet path to compare
|
2015-12-14 21:20:54 +00:00
|
|
|
* @return 1 if this sheet path has more sheets than aSheetPathToTest,
|
|
|
|
* -1 if this sheet path has fewer sheets than aSheetPathToTest,
|
2015-08-31 11:13:26 +00:00
|
|
|
* or 0 if same
|
2009-01-06 20:09:32 +00:00
|
|
|
*/
|
2011-03-28 18:23:01 +00:00
|
|
|
int Cmp( const SCH_SHEET_PATH& aSheetPathToTest ) const;
|
2009-01-07 17:33:18 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function Last
|
2011-01-23 21:22:42 +00:00
|
|
|
* returns a pointer to the last sheet of the list
|
|
|
|
* One can see the others sheet as the "path" to reach this last sheet
|
2009-01-07 17:33:18 +00:00
|
|
|
*/
|
2014-04-30 19:16:22 +00:00
|
|
|
SCH_SHEET* Last() const;
|
2009-01-07 17:33:18 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function LastScreen
|
2011-01-23 21:22:42 +00:00
|
|
|
* @return the SCH_SCREEN relative to the last sheet in list
|
2009-01-07 17:33:18 +00:00
|
|
|
*/
|
2014-04-30 19:16:22 +00:00
|
|
|
SCH_SCREEN* LastScreen() const;
|
2009-01-07 17:33:18 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
2011-03-29 19:33:07 +00:00
|
|
|
* Function LastDrawList
|
2011-01-23 21:22:42 +00:00
|
|
|
* @return a pointer to the first schematic item handled by the
|
|
|
|
* SCH_SCREEN relative to the last sheet in list
|
2009-01-07 17:33:18 +00:00
|
|
|
*/
|
2014-04-30 19:16:22 +00:00
|
|
|
SCH_ITEM* LastDrawList() const;
|
2009-01-06 20:09:32 +00:00
|
|
|
|
2010-03-16 18:22:59 +00:00
|
|
|
/**
|
|
|
|
* Get the last schematic item relative to the first sheet in the list.
|
|
|
|
*
|
|
|
|
* @return Last schematic item relative to the first sheet in the list if list
|
|
|
|
* is not empty. Otherwise NULL.
|
|
|
|
*/
|
2014-04-30 19:16:22 +00:00
|
|
|
SCH_ITEM* FirstDrawList() const;
|
2010-03-16 18:22:59 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function Push
|
2011-01-23 21:22:42 +00:00
|
|
|
* store (push) aSheet in list
|
|
|
|
* @param aSheet = pointer to the SCH_SHEET to store in list
|
|
|
|
* Push is used when entered a sheet to select or analyze it
|
|
|
|
* This is like cd <directory> in directories navigation
|
2009-01-06 20:09:32 +00:00
|
|
|
*/
|
2011-03-28 18:23:01 +00:00
|
|
|
void Push( SCH_SHEET* aSheet );
|
2009-01-06 20:09:32 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function Pop
|
2011-01-23 21:22:42 +00:00
|
|
|
* retrieves (pop) the last entered sheet and remove it from list
|
|
|
|
* @return a SCH_SHEET* pointer to the removed sheet in list
|
|
|
|
* Pop is used when leaving a sheet after a selection or analyze
|
|
|
|
* This is like cd .. in directories navigation
|
2009-01-06 20:09:32 +00:00
|
|
|
*/
|
2011-03-28 18:23:01 +00:00
|
|
|
SCH_SHEET* Pop();
|
2009-01-04 18:52:57 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function Path
|
2011-01-23 21:22:42 +00:00
|
|
|
* the path uses the time stamps which do not changes even when editing
|
|
|
|
* sheet parameters
|
|
|
|
* a path is something like / (root) or /34005677 or /34005677/00AE4523
|
2009-01-04 18:52:57 +00:00
|
|
|
*/
|
2011-11-17 01:06:08 +00:00
|
|
|
wxString Path() const;
|
2009-01-04 18:52:57 +00:00
|
|
|
|
2010-07-31 23:57:36 +00:00
|
|
|
/**
|
|
|
|
* Function PathHumanReadable
|
2011-01-23 21:22:42 +00:00
|
|
|
* returns the sheet path in a human readable form, i.e. as a path made
|
|
|
|
* from sheet names. The the "normal" path instead uses the time
|
|
|
|
* stamps in the path. (Time stamps do not change even when editing
|
|
|
|
* sheet parameters).
|
2009-01-04 18:52:57 +00:00
|
|
|
*/
|
2011-03-28 18:23:01 +00:00
|
|
|
wxString PathHumanReadable() const;
|
2009-01-04 18:52:57 +00:00
|
|
|
|
2010-11-12 15:17:10 +00:00
|
|
|
/**
|
|
|
|
* Function BuildSheetPathInfoFromSheetPathValue
|
2011-01-23 21:22:42 +00:00
|
|
|
* Fill this with data to access to the hierarchical sheet known by its path \a aPath
|
2009-01-07 20:09:03 +00:00
|
|
|
* @param aPath = path of the sheet to reach (in non human readable format)
|
2010-12-14 15:56:30 +00:00
|
|
|
* @param aFound - Please document me.
|
2009-01-07 20:09:03 +00:00
|
|
|
* @return true if success else false
|
|
|
|
*/
|
2011-03-28 18:23:01 +00:00
|
|
|
bool BuildSheetPathInfoFromSheetPathValue( const wxString& aPath, bool aFound = false );
|
2009-01-07 20:09:03 +00:00
|
|
|
|
2009-01-04 18:52:57 +00:00
|
|
|
/**
|
|
|
|
* Function UpdateAllScreenReferences
|
2011-01-23 21:22:42 +00:00
|
|
|
* updates the reference and the m_Multi parameter (part selection) for all
|
|
|
|
* components on a screen depending on the actual sheet path.
|
|
|
|
* Mandatory in complex hierarchies because sheets use the same screen
|
|
|
|
* (basic schematic)
|
|
|
|
* but with different references and part selections according to the
|
|
|
|
* displayed sheet
|
2009-01-04 18:52:57 +00:00
|
|
|
*/
|
2011-03-28 18:23:01 +00:00
|
|
|
void UpdateAllScreenReferences();
|
2009-01-04 18:52:57 +00:00
|
|
|
|
2010-12-31 19:47:39 +00:00
|
|
|
/**
|
|
|
|
* Function GetComponents
|
|
|
|
* adds a SCH_REFERENCE() object to \a aReferences for each component in the sheet.
|
2014-11-02 16:25:04 +00:00
|
|
|
* @param aLibs the library list to use
|
2010-12-31 19:47:39 +00:00
|
|
|
* @param aReferences List of references to populate.
|
2014-11-02 16:25:04 +00:00
|
|
|
* @param aIncludePowerSymbols : false to only get normal components.
|
2010-12-31 19:47:39 +00:00
|
|
|
*/
|
2014-11-02 16:25:04 +00:00
|
|
|
void GetComponents( PART_LIBS* aLibs, SCH_REFERENCE_LIST& aReferences,
|
|
|
|
bool aIncludePowerSymbols = true );
|
2011-03-28 18:23:01 +00:00
|
|
|
|
2015-03-23 11:45:31 +00:00
|
|
|
/**
|
|
|
|
* Function GetMultiUnitComponents
|
|
|
|
* adds a SCH_REFERENCE_LIST object to \a aRefList for each same-reference set of
|
|
|
|
* multi-unit parts in the sheet. The map key for each element will be the
|
|
|
|
* reference designator.
|
|
|
|
* @param aLibs the library list to use
|
|
|
|
* @param aRefList Map of reference designators to reference lists
|
|
|
|
* @param aIncludePowerSymbols : false to only get normal components.
|
|
|
|
*/
|
|
|
|
void GetMultiUnitComponents( PART_LIBS* aLibs, SCH_MULTI_UNIT_REFERENCE_MAP &aRefList,
|
|
|
|
bool aIncludePowerSymbols = true );
|
|
|
|
|
2011-03-28 18:23:01 +00:00
|
|
|
/**
|
|
|
|
* Function SetFootprintField
|
|
|
|
* searches last sheet in the path for a component with \a aReference and set the footprint
|
|
|
|
* field to \a aFootPrint if found.
|
|
|
|
*
|
|
|
|
* @param aReference The reference designator of the component.
|
2011-03-29 15:21:35 +00:00
|
|
|
* @param aFootPrint The value to set the footprint field.
|
2011-03-28 18:23:01 +00:00
|
|
|
* @param aSetVisible The value to set the field visibility flag.
|
2011-03-29 15:21:35 +00:00
|
|
|
* @return True if \a aReference was found otherwise false.
|
2011-03-28 18:23:01 +00:00
|
|
|
*/
|
|
|
|
bool SetComponentFootprint( const wxString& aReference, const wxString& aFootPrint,
|
|
|
|
bool aSetVisible );
|
2010-12-31 19:47:39 +00:00
|
|
|
|
2010-03-16 18:22:59 +00:00
|
|
|
/**
|
2011-03-29 15:21:35 +00:00
|
|
|
* Find the next schematic item in this sheet object.
|
2010-03-16 18:22:59 +00:00
|
|
|
*
|
2011-01-23 21:22:42 +00:00
|
|
|
* @param aType - The type of schematic item object to search for.
|
|
|
|
* @param aLastItem - Start search from aLastItem. If no aLastItem, search from
|
|
|
|
* the beginning of the list.
|
|
|
|
* @param aWrap - Wrap around the end of the list to find the next item if aLastItem
|
2010-03-16 18:22:59 +00:00
|
|
|
* is defined.
|
2011-01-23 21:22:42 +00:00
|
|
|
* @return - The next schematic item if found. Otherwise, NULL is returned.
|
2010-03-16 18:22:59 +00:00
|
|
|
*/
|
2014-04-30 19:16:22 +00:00
|
|
|
SCH_ITEM* FindNextItem( KICAD_T aType, SCH_ITEM* aLastItem = NULL, bool aWrap = false ) const;
|
2010-03-16 18:22:59 +00:00
|
|
|
|
|
|
|
/**
|
2011-01-23 21:22:42 +00:00
|
|
|
* Find the previous schematic item in this sheet path object.
|
2010-03-16 18:22:59 +00:00
|
|
|
*
|
2011-01-23 21:22:42 +00:00
|
|
|
* @param aType - The type of schematic item object to search for.
|
|
|
|
* @param aLastItem - Start search from aLastItem. If no aLastItem, search from
|
|
|
|
* the end of the list.
|
|
|
|
* @param aWrap - Wrap around the beginning of the list to find the next item if aLastItem
|
|
|
|
* is defined.
|
|
|
|
* @return - The previous schematic item if found. Otherwise, NULL is returned.
|
2010-03-16 18:22:59 +00:00
|
|
|
*/
|
2014-04-30 19:16:22 +00:00
|
|
|
SCH_ITEM* FindPreviousItem( KICAD_T aType, SCH_ITEM* aLastItem = NULL, bool aWrap = false ) const;
|
2010-03-16 18:22:59 +00:00
|
|
|
|
2015-06-07 20:31:55 +00:00
|
|
|
/**
|
|
|
|
* Function TestForRecursion
|
|
|
|
*
|
|
|
|
* test the SCH_SHEET_PATH file names to check adding the sheet stored in the file
|
|
|
|
* \a aSrcFileName to the sheet stored in file \a aDestFileName will cause a sheet
|
|
|
|
* path recursion.
|
|
|
|
*
|
|
|
|
* @param aSrcFileName is the source file name of the sheet add to \a aDestFileName.
|
|
|
|
* @param aDestFileName is the file name of the destination sheet for \a aSrcFileName.
|
|
|
|
* @return true if \a aFileName will cause recursion in the sheet path. Otherwise false.
|
|
|
|
*/
|
|
|
|
bool TestForRecursion( const wxString& aSrcFileName, const wxString& aDestFileName ) const;
|
|
|
|
|
|
|
|
int FindSheet( const wxString& aFileName ) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function FindSheetByName
|
|
|
|
*
|
|
|
|
* searches the #SCH_SHEET_PATH for a sheet named \a aSheetName.
|
|
|
|
*
|
|
|
|
* @param aSheetName is the name of the sheet to find.
|
|
|
|
* @return a pointer to the sheet named \a aSheetName if found or NULL if not found.
|
|
|
|
*/
|
|
|
|
SCH_SHEET* FindSheetByName( const wxString& aSheetName );
|
|
|
|
|
2011-01-30 22:22:38 +00:00
|
|
|
SCH_SHEET_PATH& operator=( const SCH_SHEET_PATH& d1 );
|
2009-01-04 18:52:57 +00:00
|
|
|
|
2010-08-03 02:13:33 +00:00
|
|
|
bool operator==( const SCH_SHEET_PATH& d1 ) const;
|
2009-01-04 18:52:57 +00:00
|
|
|
|
2011-01-30 22:22:38 +00:00
|
|
|
bool operator!=( const SCH_SHEET_PATH& d1 ) const { return !( *this == d1 ) ; }
|
2009-01-04 18:52:57 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2010-07-30 21:41:55 +00:00
|
|
|
/**
|
|
|
|
* Class SCH_SHEET_LIST
|
2011-01-23 21:22:42 +00:00
|
|
|
* handles the list of Sheets in a hierarchy.
|
|
|
|
* Sheets are not unique, there can be many sheets with the same
|
|
|
|
* filename and the same SCH_SCREEN reference.
|
|
|
|
* The schematic (SCH_SCREEN) is shared between these sheets,
|
|
|
|
* and component references are specific to a sheet path.
|
|
|
|
* When a sheet is entered, component references and sheet number are updated.
|
2009-01-06 20:09:32 +00:00
|
|
|
*/
|
2009-12-02 21:44:03 +00:00
|
|
|
class SCH_SHEET_LIST
|
2009-01-04 18:52:57 +00:00
|
|
|
{
|
|
|
|
private:
|
2015-06-07 20:31:55 +00:00
|
|
|
SCH_SHEET_PATH* m_list;
|
2009-12-02 21:44:03 +00:00
|
|
|
int m_count; /* Number of sheets included in hierarchy,
|
|
|
|
* starting at the given sheet in constructor .
|
|
|
|
* the given sheet is counted
|
2009-01-04 18:52:57 +00:00
|
|
|
*/
|
2011-10-15 13:25:57 +00:00
|
|
|
int m_index; /* internal variable to handle GetNext(): cleared by
|
|
|
|
* GetFirst() and incremented by GetNext() after
|
2015-06-07 20:31:55 +00:00
|
|
|
* returning the next item in m_list. Also used for
|
2011-10-15 13:25:57 +00:00
|
|
|
* internal calculations in BuildSheetList()
|
2009-12-02 21:44:03 +00:00
|
|
|
*/
|
2013-10-27 18:21:53 +00:00
|
|
|
bool m_isRootSheet;
|
2009-12-02 21:44:03 +00:00
|
|
|
SCH_SHEET_PATH m_currList;
|
2009-01-04 18:52:57 +00:00
|
|
|
|
|
|
|
public:
|
2010-07-30 21:41:55 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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.
|
2009-01-06 20:09:32 +00:00
|
|
|
*/
|
2009-12-02 21:44:03 +00:00
|
|
|
SCH_SHEET_LIST( SCH_SHEET* aSheet = NULL );
|
2009-01-04 18:52:57 +00:00
|
|
|
|
2009-12-02 21:44:03 +00:00
|
|
|
~SCH_SHEET_LIST()
|
2009-01-04 18:52:57 +00:00
|
|
|
{
|
2015-06-07 20:31:55 +00:00
|
|
|
if( m_list )
|
|
|
|
delete[] m_list;
|
2011-03-29 19:33:07 +00:00
|
|
|
|
2015-06-07 20:31:55 +00:00
|
|
|
m_list = NULL;
|
2009-01-04 18:52:57 +00:00
|
|
|
}
|
|
|
|
|
2010-07-30 21:41:55 +00:00
|
|
|
/**
|
2010-11-12 16:59:16 +00:00
|
|
|
* Function GetCount
|
2011-01-23 21:22:42 +00:00
|
|
|
* @return the number of sheets in list:
|
2009-01-06 20:09:32 +00:00
|
|
|
* usually the number of sheets found in the whole hierarchy
|
|
|
|
*/
|
2014-04-30 19:16:22 +00:00
|
|
|
int GetCount() const { return m_count; }
|
2009-01-06 20:09:32 +00:00
|
|
|
|
2015-02-11 11:11:05 +00:00
|
|
|
/**
|
|
|
|
* Function GetIndex
|
|
|
|
* @return the last selected screen index.
|
|
|
|
*/
|
|
|
|
int GetIndex() const { return m_index; }
|
|
|
|
|
2010-07-30 21:41:55 +00:00
|
|
|
/**
|
|
|
|
* Function GetFirst
|
2015-06-07 20:31:55 +00:00
|
|
|
* @return the first item (sheet) in m_list and prepare calls to GetNext()
|
2009-01-06 20:09:32 +00:00
|
|
|
*/
|
2009-12-02 21:44:03 +00:00
|
|
|
SCH_SHEET_PATH* GetFirst();
|
2009-01-06 20:09:32 +00:00
|
|
|
|
2010-07-30 21:41:55 +00:00
|
|
|
/**
|
|
|
|
* Function GetNext
|
2015-06-07 20:31:55 +00:00
|
|
|
* @return the next item (sheet) in m_list or NULL if no more item in
|
2011-01-23 21:22:42 +00:00
|
|
|
* sheet list
|
2009-01-06 20:09:32 +00:00
|
|
|
*/
|
2009-12-02 21:44:03 +00:00
|
|
|
SCH_SHEET_PATH* GetNext();
|
2009-01-06 20:09:32 +00:00
|
|
|
|
2010-03-16 18:22:59 +00:00
|
|
|
/**
|
2010-07-30 21:41:55 +00:00
|
|
|
* Function GetLast
|
2011-01-23 21:22:42 +00:00
|
|
|
* returns the last sheet in the sheet list.
|
2010-03-16 18:22:59 +00:00
|
|
|
*
|
2011-01-23 21:22:42 +00:00
|
|
|
* @return Last sheet in the list or NULL if sheet list is empty.
|
2010-03-16 18:22:59 +00:00
|
|
|
*/
|
|
|
|
SCH_SHEET_PATH* GetLast();
|
|
|
|
|
|
|
|
/**
|
2010-07-30 21:41:55 +00:00
|
|
|
* Function GetPrevious
|
2011-01-23 21:22:42 +00:00
|
|
|
* returns the previous sheet in the sheet list.
|
2010-03-16 18:22:59 +00:00
|
|
|
*
|
|
|
|
* @return The previous sheet in the sheet list or NULL if already at the
|
|
|
|
* beginning of the list.
|
|
|
|
*/
|
|
|
|
SCH_SHEET_PATH* GetPrevious();
|
|
|
|
|
2010-07-30 21:41:55 +00:00
|
|
|
/**
|
|
|
|
* Function GetSheet
|
2011-11-17 01:06:08 +00:00
|
|
|
*
|
|
|
|
* @param aIndex A index in sheet list to get the sheet.
|
2015-06-07 20:31:55 +00:00
|
|
|
* @return the sheet at \a aIndex position in m_list or NULL if \a aIndex is
|
2011-11-17 01:06:08 +00:00
|
|
|
* outside the bounds of the index list.
|
2009-01-06 20:09:32 +00:00
|
|
|
*/
|
2015-06-07 20:31:55 +00:00
|
|
|
SCH_SHEET_PATH* GetSheet( int aIndex ) const;
|
2009-01-04 18:52:57 +00:00
|
|
|
|
2011-11-17 01:06:08 +00:00
|
|
|
/**
|
2015-06-08 14:37:45 +00:00
|
|
|
* Function GetSheetByPath
|
2011-11-17 01:06:08 +00:00
|
|
|
* returns a sheet matching the path name in \a aPath.
|
|
|
|
*
|
|
|
|
* @param aPath A wxString object containing path of the sheet to get.
|
|
|
|
* @param aHumanReadable True uses the human readable path for comparison.
|
|
|
|
* False uses the timestamp generated path.
|
|
|
|
* @return The sheet that matches \a aPath or NULL if no sheet matching
|
|
|
|
* \a aPath is found.
|
|
|
|
*/
|
2015-06-08 14:37:45 +00:00
|
|
|
SCH_SHEET_PATH* GetSheetByPath( const wxString aPath, bool aHumanReadable = true );
|
2011-11-17 01:06:08 +00:00
|
|
|
|
2010-12-31 19:47:39 +00:00
|
|
|
/**
|
|
|
|
* Function GetComponents
|
|
|
|
* adds a SCH_REFERENCE() object to \a aReferences for each component in the list
|
|
|
|
* of sheets.
|
2014-11-02 16:25:04 +00:00
|
|
|
* @param aLibs the library list to use
|
2010-12-31 19:47:39 +00:00
|
|
|
* @param aReferences List of references to populate.
|
|
|
|
* @param aIncludePowerSymbols Set to false to only get normal components.
|
|
|
|
*/
|
2016-01-03 13:58:27 +00:00
|
|
|
void GetComponents( PART_LIBS* aLibs, SCH_REFERENCE_LIST& aReferences,
|
|
|
|
bool aIncludePowerSymbols = true );
|
2010-12-31 19:47:39 +00:00
|
|
|
|
2015-03-23 11:45:31 +00:00
|
|
|
/**
|
|
|
|
* Function GetMultiUnitComponents
|
|
|
|
* adds a SCH_REFERENCE_LIST object to \a aRefList for each same-reference set of
|
|
|
|
* multi-unit parts in the list of sheets. The map key for each element will be the
|
|
|
|
* reference designator.
|
|
|
|
* @param aLibs the library list to use
|
|
|
|
* @param aRefList Map of reference designators to reference lists
|
|
|
|
* @param aIncludePowerSymbols Set to false to only get normal components.
|
|
|
|
*/
|
|
|
|
void GetMultiUnitComponents( PART_LIBS* aLibs, SCH_MULTI_UNIT_REFERENCE_MAP &aRefList,
|
|
|
|
bool aIncludePowerSymbols = true );
|
|
|
|
|
2010-03-16 18:22:59 +00:00
|
|
|
/**
|
2010-07-30 21:41:55 +00:00
|
|
|
* Function FindNextItem
|
|
|
|
* searches the entire schematic for the next schematic object.
|
2010-03-16 18:22:59 +00:00
|
|
|
*
|
2011-01-23 21:22:42 +00:00
|
|
|
* @param aType - The type of schematic item to find.
|
|
|
|
* @param aSheetFound - The sheet the item was found in. NULL if the next item
|
|
|
|
* is not found.
|
|
|
|
* @param aLastItem - Find next item after aLastItem if not NULL.
|
|
|
|
* @param aWrap - Wrap past around the end of the list of sheets.
|
2010-03-16 18:22:59 +00:00
|
|
|
* @return If found, Returns the next schematic item. Otherwise, returns NULL.
|
|
|
|
*/
|
|
|
|
SCH_ITEM* FindNextItem( KICAD_T aType, SCH_SHEET_PATH** aSheetFound = NULL,
|
|
|
|
SCH_ITEM* aLastItem = NULL, bool aWrap = true );
|
|
|
|
|
|
|
|
/**
|
2010-07-30 21:41:55 +00:00
|
|
|
* Function FindPreviousItem
|
|
|
|
* searches the entire schematic for the previous schematic item.
|
2010-03-16 18:22:59 +00:00
|
|
|
*
|
2011-01-23 21:22:42 +00:00
|
|
|
* @param aType - The type of schematic item to find.
|
|
|
|
* @param aSheetFound - The sheet the item was found in. NULL if the previous item
|
|
|
|
* is not found.
|
|
|
|
* @param aLastItem - Find the previous item before aLastItem if not NULL.
|
|
|
|
* @param aWrap - Wrap past around the beginning of the list of sheets.
|
2010-03-16 18:22:59 +00:00
|
|
|
* @return If found, the previous schematic item. Otherwise, NULL.
|
|
|
|
*/
|
|
|
|
SCH_ITEM* FindPreviousItem( KICAD_T aType, SCH_SHEET_PATH** aSheetFound = NULL,
|
|
|
|
SCH_ITEM* aLastItem = NULL, bool aWrap = true );
|
|
|
|
|
2011-03-28 18:23:01 +00:00
|
|
|
/**
|
|
|
|
* Function SetFootprintField
|
|
|
|
* searches all the sheets for a component with \a aReference and set the footprint
|
|
|
|
* field to \a aFootPrint if found.
|
|
|
|
*
|
|
|
|
* @param aReference The reference designator of the component.
|
2011-03-29 15:21:35 +00:00
|
|
|
* @param aFootPrint The value to set the footprint field.
|
2011-03-28 18:23:01 +00:00
|
|
|
* @param aSetVisible The value to set the field visibility flag.
|
2011-03-29 15:21:35 +00:00
|
|
|
* @return True if \a aReference was found otherwise false.
|
2011-03-28 18:23:01 +00:00
|
|
|
*/
|
|
|
|
bool SetComponentFootprint( const wxString& aReference, const wxString& aFootPrint,
|
|
|
|
bool aSetVisible );
|
|
|
|
|
2013-10-27 18:21:53 +00:00
|
|
|
/**
|
|
|
|
* Function IsComplexHierarchy
|
|
|
|
* searches all of the sheets for duplicate files names which indicates a complex
|
|
|
|
* hierarchy.
|
|
|
|
*
|
|
|
|
* @return true if the #SCH_SHEET_LIST is a complex hierarchy.
|
|
|
|
*/
|
2015-06-07 20:31:55 +00:00
|
|
|
bool IsComplexHierarchy() const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function TestForRecursion
|
|
|
|
*
|
|
|
|
* test every SCH_SHEET_PATH in the SCH_SHEET_LIST to verify if adding the sheets stored
|
|
|
|
* in \a aSrcSheetHierarchy to the sheet stored in \a aDestFileName will cause recursion.
|
|
|
|
*
|
|
|
|
* @param aSrcSheetHierarchy is the SCH_SHEET_LIST of the source sheet add to \a aDestFileName.
|
|
|
|
* @param aDestFileName is the file name of the destination sheet for \a aSrcFileName.
|
|
|
|
* @return true if \a aFileName will cause recursion in the sheet path. Otherwise false.
|
|
|
|
*/
|
|
|
|
bool TestForRecursion( const SCH_SHEET_LIST& aSrcSheetHierarchy,
|
|
|
|
const wxString& aDestFileName ) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function FindSheetByName
|
|
|
|
*
|
|
|
|
* searches the entire #SCH_SHEET_LIST for a sheet named \a aSheetName.
|
|
|
|
*
|
|
|
|
* @param aSheetName is the name of the sheet to find.
|
|
|
|
* @return a pointer to the sheet named \a aSheetName if found or NULL if not found.
|
|
|
|
*/
|
|
|
|
SCH_SHEET* FindSheetByName( const wxString& aSheetName );
|
2013-10-27 18:21:53 +00:00
|
|
|
|
2009-01-04 18:52:57 +00:00
|
|
|
private:
|
2009-01-06 20:09:32 +00:00
|
|
|
|
2010-07-30 21:41:55 +00:00
|
|
|
/**
|
|
|
|
* Function BuildSheetList
|
2011-01-23 21:22:42 +00:00
|
|
|
* builds the list of sheets and their sheet path from \a aSheet.
|
2011-11-10 15:55:05 +00:00
|
|
|
* If \a aSheet is the root sheet, the full sheet path and sheet list are built.
|
2010-07-30 21:41:55 +00:00
|
|
|
*
|
2011-11-10 15:55:05 +00:00
|
|
|
* @param aSheet is the starting sheet from which the list is built, or NULL
|
|
|
|
* indicating that g_RootSheet should be used.
|
|
|
|
* @throw std::bad_alloc if the memory for the sheet path list could not be allocated.
|
2009-01-06 20:09:32 +00:00
|
|
|
*/
|
2011-03-29 19:33:07 +00:00
|
|
|
void BuildSheetList( SCH_SHEET* aSheet );
|
2009-01-04 18:52:57 +00:00
|
|
|
};
|
|
|
|
|
2010-07-30 21:41:55 +00:00
|
|
|
#endif // CLASS_DRAWSHEET_PATH_H
|