50#define SHEET_NAME_CANONICAL "Sheetname"
51#define SHEET_FILE_CANONICAL "Sheetfile"
52#define USER_FIELD_CANONICAL "Field%d"
127 m_pins.back()->SetParent(
this );
131 field.SetParent(
this );
196 wxCHECK_MSG(
Schematic(),
false,
"Can't call IsRootSheet without setting a schematic" );
205 [&](
const wxString& aVar )
208 aVars->push_back( aVar );
212 add(
m_fields[i].GetCanonicalName().Upper() );
219 if( sheetPath.
size() >= 2 )
231 add( wxT(
"SHEETPATH" ) );
239 wxCHECK( aPath,
false );
246 if( token->Contains(
':' ) )
254 if( token->IsSameAs(
m_fields[i].GetCanonicalName().Upper() ) )
256 *token =
m_fields[i].GetShownText( aPath,
false, aDepth + 1 );
263 if( token->IsSameAs(
m_fields[i].GetName() ) )
265 *token =
m_fields[i].GetShownText( aPath,
false, aDepth + 1 );
279 if( token->IsSameAs( wxT(
"#" ) ) )
284 else if( token->IsSameAs( wxT(
"##" ) ) )
287 *token = wxString::Format( wxT(
"%d" ), (
int) sheetList.size() );
290 else if( token->IsSameAs( wxT(
"SHEETPATH" ) ) )
298 if( aPath->
size() >= 2 )
303 if(
path.Last()->ResolveTextVar( &
path, token, aDepth + 1 ) )
321 wxString::Format( wxT(
"SCH_SHEET object cannot swap data with %s object." ),
334 sheetPin->SetParent(
this );
340 field.SetParent(
this );
360 return a.GetId() < b.GetId();
374 wxASSERT( aSheetPin !=
nullptr );
378 m_pins.push_back( aSheetPin );
385 wxASSERT( aSheetPin !=
nullptr );
390 if( *i == aSheetPin )
404 if(
pin->GetText().Cmp( aName ) == 0 )
416 if( sheetPin->GetPosition() == aPosition )
431 switch(
pin->GetSide() )
433 case SHEET_SIDE::LEFT: leftRight++;
break;
434 case SHEET_SIDE::RIGHT: leftRight++;
break;
435 case SHEET_SIDE::TOP: topBottom++;
break;
436 case SHEET_SIDE::BOTTOM: topBottom++;
break;
441 return topBottom > 0 && leftRight == 0;
461 if( HLabel ==
nullptr )
473 int base = aVal / gridSize;
474 int excess = abs( aVal % gridSize );
478 return ( base + 1 ) * gridSize;
480 else if( excess > 0 )
482 return ( base ) * gridSize;
486 return ( base - 1 ) * gridSize;
496 for(
size_t i = 0; i <
m_pins.size(); i++ )
500 if( edge == SHEET_SIDE::TOP || edge == SHEET_SIDE::BOTTOM )
504 pinsLeft = std::min( pinsLeft, pinRect.
GetLeft() );
505 pinsRight = std::max( pinsRight, pinRect.
GetRight() );
514 if( pinsLeft >= pinsRight )
517 pinMinWidth = pinsRight -
m_pos.
x;
530 for(
size_t i = 0; i <
m_pins.size(); i++ )
534 if( edge == SHEET_SIDE::RIGHT || edge == SHEET_SIDE::LEFT )
538 pinsTop = std::min( pinsTop, pinRect.
GetTop() );
539 pinsBottom = std::max( pinsBottom, pinRect.
GetBottom() );
548 if( pinsTop >= pinsBottom )
551 pinMinHeight = pinsBottom -
m_pos.
y;
561 std::vector<SCH_SHEET_PIN*> pins =
m_pins;
589 if(
pin->HitTest( aPosition ) )
613 int margin = borderMargin +
KiROUND( std::max( textSize.
x, textSize.
y ) * 0.5 );
631 margin = borderMargin +
KiROUND( std::max( textSize.
x, textSize.
y ) * 0.4 );
675 end.
x = std::max(
m_size.
x, textLength );
693 bbox.
Merge( field.GetBoundingBox() );
749 if( screen && screen->
GetFileName().Cmp( aFilename ) == 0 )
805 aList.emplace_back(
_(
"Sheet Name" ),
811 path.push_back(
this );
813 aList.emplace_back(
_(
"Hierarchical Path" ),
path.PathHumanReadable(
false,
true ) );
817 aList.emplace_back(
_(
"File Name" ),
835 m_pos += aMoveVector;
838 pin->Move( aMoveVector );
841 field.Move( aMoveVector );
867 sheetPin->Rotate( aCenter, aRotateCCW );
881 field.SetTextPos( pos );
896 sheetPin->MirrorVertically( aCenter );
902 field.SetTextPos( pos );
916 sheetPin->MirrorHorizontally( aCenter );
922 field.SetTextPos( pos );
948 sheetPin->ConstrainOnEdge( sheetPin->GetPosition(),
false );
965 pin->SetNumber(
id );
977 while( !sheetPath.
empty() && sheetPath.
Last() !=
this )
980 if( sheetPath.
empty() )
996 wxT(
"Invalid item in schematic sheet pin list. Bad programmer!" ) );
998 sheetPin->GetEndPoints( aItemList );
1004 std::vector<DANGLING_END_ITEM>& aItemListByPos,
1007 bool changed =
false;
1010 changed |= sheetPin->UpdateDanglingState( aItemListByType, aItemListByPos );
1026 wxCHECK( sheet,
false );
1040 for(
size_t i = 0; i <
m_pins.size(); i++ )
1052 std::vector<VECTOR2I> retval;
1055 retval.push_back( sheetPin->GetPosition() );
1062 const std::vector<KICAD_T>& aScanTypes )
1064 for(
KICAD_T scanType : aScanTypes )
1069 if( INSPECT_RESULT::QUIT == aInspector(
this,
nullptr ) )
1070 return INSPECT_RESULT::QUIT;
1078 if( INSPECT_RESULT::QUIT == aInspector( &field,
this ) )
1079 return INSPECT_RESULT::QUIT;
1088 if( INSPECT_RESULT::QUIT == aInspector( sheetPin,
this ) )
1089 return INSPECT_RESULT::QUIT;
1094 return INSPECT_RESULT::CONTINUE;
1101 aFunction( &field );
1110 return wxString::Format(
_(
"Hierarchical Sheet %s" ),
1117 return BITMAPS::add_hierarchical_subsheet;
1145 int aUnit,
int aBodyStyle,
const VECTOR2I& aOffset,
bool aDimmed )
1160 if( aBackground && backgroundColor.
a > 0.0 )
1162 aPlotter->
SetColor( backgroundColor );
1174 std::vector<wxString> properties;
1180 properties.emplace_back( wxString::Format( wxT(
"!%s = %s" ),
1182 field.GetShownText(
false ) ) );
1189 sheetPin->Plot( aPlotter, aBackground, aPlotOpts, aUnit, aBodyStyle, aOffset, aDimmed );
1193 field.Plot( aPlotter, aBackground, aPlotOpts, aUnit, aBodyStyle, aOffset, aDimmed );
1198 const VECTOR2I& aOffset,
bool aForceNoFill,
bool aDimmed )
1213 background = COLOR4D::UNSPECIFIED;
1215 if( background.
a > 0.0 )
1221 field.Print( aSettings, aUnit, aBodyStyle, aOffset, aForceNoFill, aDimmed );
1224 sheetPin->Print( aSettings, aUnit, aBodyStyle, aOffset, aForceNoFill, aDimmed );
1230 wxCHECK_MSG(
Type() == aItem.
Type(), *
this,
1231 wxT(
"Cannot assign object type " ) + aItem.
GetClass() + wxT(
" to type " ) +
1234 if( &aItem !=
this )
1247 m_pins.back()->SetParent(
this );
1263 auto sheet =
static_cast<const SCH_SHEET*
>( &aItem );
1278 for(
unsigned ii = 0; ii <
m_instances.size(); ii++ )
1284 " page %s, from project %s.",
1316 if( instance.m_Path == aSheetPath.
Path() )
1322 (
GetName().IsEmpty() ) ? wxString( wxT(
"root" ) ) :
GetName() );
1335 bool aTestFromEnd )
const
1341 if( instance.m_Path == aSheetPath )
1343 aInstance = instance;
1347 else if( instance.m_Path.EndsWith( aSheetPath ) )
1349 aInstance = instance;
1362 if( instance.m_Path.size() == 0 )
1374 if( instance.m_Path.size() == 0 )
1388 wxCHECK( aSheetPath.
IsFullPath(), wxEmptyString );
1391 wxString pageNumber;
1396 if( instance.m_Path ==
path )
1398 pageNumber = instance.m_PageNumber;
1416 if( instance.m_Path ==
path )
1418 instance.m_PageNumber = aPageNumber;
1427 if( aPageNumberA == aPageNumberB )
1432 bool isIntegerPageA = aPageNumberA.ToLong( &pageA );
1433 bool isIntegerPageB = aPageNumberB.ToLong( &pageB );
1435 if( isIntegerPageA && isIntegerPageB )
1444 if( isIntegerPageA )
1446 else if( isIntegerPageB )
1450 int result =
StrNumCmp( aPageNumberA, aPageNumberB );
1453 wxCHECK( result != 0, 0 );
1455 result = result /
std::abs( result );
1486 for(
size_t i = 0; i <
GetFields().size(); ++i )
1512void SCH_SHEET::Show(
int nestLevel, std::ostream& os )
const
1517 NestedSpace( nestLevel, os ) <<
'<' << s.Lower().mb_str() <<
">" <<
" sheet_name=\""
1522 sheetPin->Show( nestLevel + 1, os );
1524 NestedSpace( nestLevel, os ) <<
"</" << s.Lower().mb_str() <<
">\n" << std::flush;
1542 PROPERTY_DISPLAY::PT_SIZE ) );
constexpr EDA_IU_SCALE schIUScale
BITMAPS
A list of all bitmap identifiers.
const Vec GetCenter() const
bool Intersects(const BOX2< Vec > &aRect) const
coord_type GetTop() const
bool Contains(const Vec &aPoint) const
BOX2< Vec > & Inflate(coord_type dx, coord_type dy)
Inflates the rectangle horizontally by dx and vertically by dy.
coord_type GetRight() const
coord_type GetLeft() const
coord_type GetBottom() const
void SetEnd(coord_type x, coord_type y)
BOX2< Vec > & Merge(const BOX2< Vec > &aRect)
Modify the position and size of the rectangle in order to contain aRect.
The base class for create windows for drawing purpose.
A base class for most all the KiCad significant classes used in schematics and boards.
KICAD_T Type() const
Returns the type of object.
virtual void SetParent(EDA_ITEM *aParent)
EDA_ITEM * GetParent() const
virtual const wxString & GetText() const
Return the string associated with the text object.
static wxString GotoPageHref(const wxString &aDestination)
Generate a href to a page in the current schematic.
EE_TYPE OfType(KICAD_T aType) const
A color representation with 4 components: red, green, blue, alpha.
const COLOR4D & GetLayerColor(int aLayer) const
Return the color used to draw a layer.
wxDC * GetPrintDC() const
wxString AsString() const
Base plotter engine class.
RENDER_SETTINGS * RenderSettings()
bool GetColorMode() const
virtual void HyperlinkMenu(const BOX2I &aBox, const std::vector< wxString > &aDestURLs)
Create a clickable hyperlink menu with a rectangular click area.
virtual void Rect(const VECTOR2I &p1, const VECTOR2I &p2, FILL_T fill, int width=USE_DEFAULT_LINE_WIDTH)=0
virtual void SetColor(const COLOR4D &color)=0
Container for project specific data.
Provide class metadata.Helper macro to map type hashes to names.
void InheritsAfter(TYPE_ID aDerived, TYPE_ID aBase)
Declare an inheritance relationship between types.
static PROPERTY_MANAGER & Instance()
PROPERTY_BASE & AddProperty(PROPERTY_BASE *aProperty, const wxString &aGroup=wxEmptyString)
Register a property.
Holds all the data relating to one schematic.
SCH_SHEET_PATH & CurrentSheet() const override
SCHEMATIC_SETTINGS & Settings() const
SCH_SHEET_LIST GetSheets() const override
Builds and returns an updated schematic hierarchy TODO: can this be cached?
bool ResolveTextVar(const SCH_SHEET_PATH *aSheetPath, wxString *token, int aDepth) const
void GetContextualTextVars(wxArrayString *aVars) const
PROJECT & Prj() const override
Return a reference to the project this schematic is part of.
bool ResolveCrossReference(wxString *token, int aDepth) const
Resolves text vars that refer to other items.
Schematic editor (Eeschema) main window.
Instances are attached to a symbol or sheet and provide a place for the symbol's value,...
Base class for any item which can be embedded within the SCHEMATIC container class,...
SCH_ITEM & operator=(const SCH_ITEM &aPin)
SCH_RENDER_SETTINGS * getRenderSettings(PLOTTER *aPlotter) const
SCHEMATIC * Schematic() const
Searches the item hierarchy to find a SCHEMATIC.
FIELDS_AUTOPLACED m_fieldsAutoplaced
void SwapFlags(SCH_ITEM *aItem)
Swap the non-temp and non-edit flags.
wxString GetClass() const override
Return the class name.
int GetEffectivePenWidth(const SCH_RENDER_SETTINGS *aSettings) const
void AutoAutoplaceFields(SCH_SCREEN *aScreen)
Autoplace fields only if correct to do so automatically.
bool m_OverrideItemColors
EE_RTREE & Items()
Gets the full RTree, usually for iterating.
const wxString & GetFileName() const
const TITLE_BLOCK & GetTitleBlock() const
A container for handling SCH_SHEET_PATH objects in a flattened hierarchy.
Handle access to a stack of flattened SCH_SHEET objects by way of a path for creating a flattened sch...
bool empty() const
Forwarded method from std::vector.
wxString PathHumanReadable(bool aUseShortRootName=true, bool aStripTrailingSeparator=false) const
Return the sheet path in a human readable form made from the sheet names.
KIID_PATH Path() const
Get the sheet path as an KIID_PATH.
wxString GetPageNumber() const
SCH_SHEET * Last() const
Return a pointer to the last SCH_SHEET of the list.
void push_back(SCH_SHEET *aSheet)
Forwarded method from std::vector.
size_t size() const
Forwarded method from std::vector.
void pop_back()
Forwarded method from std::vector.
Define a sheet pin (label) used in sheets to create hierarchical schematics.
Sheet symbol placed in a schematic, and is the entry point for a sub schematic.
void GetEndPoints(std::vector< DANGLING_END_ITEM > &aItemList) override
Add the schematic item end points to aItemList if the item has end points.
void GetContextualTextVars(wxArrayString *aVars) const
Return the list of system text vars & fields for this sheet.
void SetBorderColor(KIGFX::COLOR4D aColor)
friend class SCH_SHEET_PIN
void SetFileName(const wxString &aFilename)
bool HasConnectivityChanges(const SCH_ITEM *aItem, const SCH_SHEET_PATH *aInstance=nullptr) const override
Check if aItem has connectivity changes against this object.
wxString GetFileName() const
Return the filename corresponding to this sheet.
bool getInstance(SCH_SHEET_INSTANCE &aInstance, const KIID_PATH &aSheetPath, bool aTestFromEnd=false) const
BITMAPS GetMenuImage() const override
Return a pointer to an image to be used in menus.
void setPageNumber(const SCH_SHEET_PATH &aInstance, const wxString &aPageNumber)
Set the page number for the sheet instance aInstance.
void RemoveInstance(const KIID_PATH &aInstancePath)
static const wxString GetDefaultFieldName(int aFieldNdx, bool aTranslated=true)
void AddPin(SCH_SHEET_PIN *aSheetPin)
Add aSheetPin to the sheet.
bool HasRootInstance() const
Check to see if this sheet has a root sheet instance.
wxString GetClass() const override
Return the class name.
void RunOnChildren(const std::function< void(SCH_ITEM *)> &aFunction) override
int GetPenWidth() const override
EDA_ITEM * Clone() const override
Create a duplicate of this item with linked list members set to NULL.
SCH_SHEET_PATH findSelf() const
Get the sheetpath of this sheet.
bool Matches(const EDA_SEARCH_DATA &aSearchData, void *aAuxData) const override
Compare the item against the search criteria in aSearchData.
double Similarity(const SCH_ITEM &aOther) const override
Return a measure of how likely the other object is to represent the same object.
std::vector< SCH_FIELD > & GetFields()
KIGFX::COLOR4D m_borderColor
void renumberPins()
Renumber the sheet pins in the sheet.
VECTOR2I GetRotationCenter() const
Rotating around the boundingBox's center can cause walking when the sheetname or filename is longer t...
SCH_SHEET_PIN * GetPin(const VECTOR2I &aPosition)
Return the sheet pin item found at aPosition in the sheet.
bool operator<(const SCH_ITEM &aItem) const override
void CleanupSheet()
Delete sheet label which do not have a corresponding hierarchical label.
void Print(const SCH_RENDER_SETTINGS *aSettings, int aUnit, int aBodyStyle, const VECTOR2I &aOffset, bool aForceNoFill, bool aDimmed) override
Print an item.
void RemovePin(const SCH_SHEET_PIN *aSheetPin)
Remove aSheetPin from the sheet.
void SetPositionIgnoringPins(const VECTOR2I &aPosition)
bool SearchHierarchy(const wxString &aFilename, SCH_SCREEN **aScreen)
Search the existing hierarchy for an instance of screen loaded from aFileName.
wxString GetItemDescription(UNITS_PROVIDER *aUnitsProvider) const override
Return a user-visible description string of this item.
bool LocatePathOfScreen(SCH_SCREEN *aScreen, SCH_SHEET_PATH *aList)
Search the existing hierarchy for an instance of screen loaded from aFileName.
std::vector< SCH_SHEET_INSTANCE > m_instances
bool HasUndefinedPins() const
Check all sheet labels against schematic for undefined hierarchical labels.
void SetPosition(const VECTOR2I &aPosition) override
void SetBackgroundColor(KIGFX::COLOR4D aColor)
int SymbolCount() const
Count our own symbols, without the power symbols.
void Plot(PLOTTER *aPlotter, bool aBackground, const SCH_PLOT_OPTS &aPlotOpts, int aUnit, int aBodyStyle, const VECTOR2I &aOffset, bool aDimmed) override
Plot the item to aPlotter.
void AddInstance(const SCH_SHEET_INSTANCE &aInstance)
int GetMinWidth(bool aFromLeft) const
Return the minimum width of the sheet based on the widths of the sheet pin text.
bool operator==(const SCH_ITEM &aOther) const override
void ViewGetLayers(int aLayers[], int &aCount) const override
Return the layers the item is drawn on (which may be more than its "home" layer)
std::vector< SCH_FIELD > m_fields
KIGFX::COLOR4D m_backgroundColor
void SetName(const wxString &aName)
int CountSheets() const
Count the number of sheets found in "this" sheet including all of the subsheets.
VECTOR2I GetPosition() const override
const BOX2I GetBodyBoundingBox() const
Return a bounding box for the sheet body but not the fields.
bool HasPin(const wxString &aName) const
Checks if the sheet already has a sheet pin named aName.
static int ComparePageNum(const wxString &aPageNumberA, const wxString &aPageNumberB)
Compares page numbers of schematic sheets.
SCH_SHEET(EDA_ITEM *aParent=nullptr, const VECTOR2I &aPos=VECTOR2I(0, 0), VECTOR2I aSize=VECTOR2I(schIUScale.MilsToIU(MIN_SHEET_WIDTH), schIUScale.MilsToIU(MIN_SHEET_HEIGHT)), FIELDS_AUTOPLACED aAutoplaceFields=FIELDS_AUTOPLACED_AUTO)
void MirrorHorizontally(int aCenter) override
Mirror item horizontally about aCenter.
wxString getPageNumber(const SCH_SHEET_PATH &aInstance) const
Return the sheet page number for aInstance.
void SetFields(const std::vector< SCH_FIELD > &aFields)
Set multiple schematic fields.
int GetScreenCount() const
Return the number of times the associated screen for the sheet is being used.
void SetScreen(SCH_SCREEN *aScreen)
Set the SCH_SCREEN associated with this sheet to aScreen.
SCH_SHEET & operator=(const SCH_ITEM &aSheet)
const SCH_SHEET_INSTANCE & GetRootInstance() const
Return the root sheet instance data.
bool doIsConnected(const VECTOR2I &aPosition) const override
Provide the object specific test to see if it is connected to aPosition.
void AutoplaceFields(SCH_SCREEN *aScreen, bool aManual) override
const BOX2I GetBoundingBox() const override
Return the orthogonal bounding box of this object for display purposes.
std::vector< VECTOR2I > GetConnectionPoints() const override
Add all the connection points for this item to aPoints.
KIGFX::COLOR4D GetBorderColor() const
std::vector< SCH_SHEET_PIN * > m_pins
INSPECT_RESULT Visit(INSPECTOR inspector, void *testData, const std::vector< KICAD_T > &aScanTypes) override
May be re-implemented for each derived class in order to handle all the types given by its member dat...
void SetBorderWidth(int aWidth)
bool addInstance(const SCH_SHEET_PATH &aInstance)
Add a new instance aSheetPath to the instance list.
void MirrorVertically(int aCenter) override
Mirror item vertically about aCenter.
void SwapData(SCH_ITEM *aItem) override
Swap the internal data structures aItem with the schematic item.
int GetMinHeight(bool aFromTop) const
Return the minimum height that the sheet can be resized based on the sheet pin positions.
bool UpdateDanglingState(std::vector< DANGLING_END_ITEM > &aItemListByType, std::vector< DANGLING_END_ITEM > &aItemListByPos, const SCH_SHEET_PATH *aPath=nullptr) override
Test the schematic item to aItemList to check if it's dangling state has changed.
void Resize(const VECTOR2I &aSize)
Resize this sheet to aSize and adjust all of the labels accordingly.
void Move(const VECTOR2I &aMoveVector) override
Move the item by aMoveVector to a new position.
int GetBorderWidth() const
void GetMsgPanelInfo(EDA_DRAW_FRAME *aFrame, std::vector< MSG_PANEL_ITEM > &aList) override
Populate aList of MSG_PANEL_ITEM objects with it's internal state for display purposes.
void Rotate(const VECTOR2I &aCenter, bool aRotateCCW) override
Rotate the item around aCenter 90 degrees in the clockwise direction.
bool ResolveTextVar(const SCH_SHEET_PATH *aPath, wxString *token, int aDepth=0) const
Resolve any references to system tokens supported by the sheet.
bool IsVerticalOrientation() const
bool HitTest(const VECTOR2I &aPosition, int aAccuracy) const override
Test if aPosition is inside or on the boundary of this item.
KIGFX::COLOR4D GetBackgroundColor() const
SCH_FIELD * GetField(MANDATORY_FIELD_T aFieldType)
Return a mandatory field in this symbol.
bool TextVarResolver(wxString *aToken, const PROJECT *aProject) const
static void GetContextualTextVars(wxArrayString *aVars)
#define DEFAULT_LINE_WIDTH_MILS
The default wire width in mils. (can be changed in preference menu)
static constexpr EDA_ANGLE ANGLE_90
static constexpr EDA_ANGLE ANGLE_VERTICAL
static constexpr EDA_ANGLE ANGLE_HORIZONTAL
static constexpr EDA_ANGLE ANGLE_270
const INSPECTOR_FUNC & INSPECTOR
void GRRect(wxDC *DC, const VECTOR2I &aStart, const VECTOR2I &aEnd, int aWidth, const COLOR4D &aColor)
void GRFilledRect(wxDC *DC, const VECTOR2I &aStart, const VECTOR2I &aEnd, int aWidth, const COLOR4D &aColor, const COLOR4D &aBgColor)
bool GetGRForceBlackPenState(void)
const wxChar *const traceSchSheetPaths
Flag to enable debug output of schematic symbol sheet path manipulation code.
@ LAYER_SELECTION_SHADOWS
void MIRROR(T &aPoint, const T &aMirrorRef)
Updates aPoint with the mirror of aPoint relative to the aMirrorRef.
Message panel definition file.
KICOMMON_API wxString EllipsizeMenuText(const wxString &aString)
Ellipsize text (at the end) to be no more than 36 characters.
KICOMMON_API wxString EllipsizeStatusText(wxWindow *aWindow, const wxString &aString)
Ellipsize text (at the end) to be no more than 1/3 of the window width.
bool contains(const _Container &__container, _Value __value)
Returns true if the container contains the given value.
EDA_ANGLE abs(const EDA_ANGLE &aAngle)
#define USER_FIELD_CANONICAL
#define SHEET_NAME_CANONICAL
int bumpToNextGrid(const int aVal, const int aDirection)
static struct SCH_SHEET_DESC _SCH_SHEET_DESC
#define SHEET_FILE_CANONICAL
@ SHEET_MANDATORY_FIELDS
The first 2 are mandatory, and must be instantiated in SCH_SHEET.
Definition of the SCH_SHEET_PATH and SCH_SHEET_LIST classes for Eeschema.
SHEET_SIDE
Define the edge of the sheet that the sheet pin is positioned.
std::vector< FAB_LAYER_COLOR > dummy
int StrNumCmp(const wxString &aString1, const wxString &aString2, bool aIgnoreCase)
Compare two strings with alphanumerical content.
#define TO_UTF8(wxstring)
Convert a wxString to a UTF8 encoded C string for all wxWidgets build modes.
constexpr int MilsToIU(int mils) const
A simple container for sheet instance information.
@ VALUE_FIELD
Field Value of part, i.e. "3.3K".
wxLogTrace helper definitions.
void RotatePoint(int *pX, int *pY, const EDA_ANGLE &aAngle)
Calculate the new point of coord coord pX, pY, for a rotation center 0, 0.
KICAD_T
The set of class identification values stored in EDA_ITEM::m_structType.
constexpr ret_type KiROUND(fp_type v)
Round a floating point number to an integer using "round halfway cases away from zero".