97 auto& outline = ruleShape.
Outline( 0 );
99 outline.Append(
VECTOR2I( 22000, 20000) );
100 outline.Append(
VECTOR2I( 22000, 22000) );
101 outline.Append(
VECTOR2I( 20000, 22000) );
102 outline.SetClosed(
true );
103 outline.Simplify(
true );
119 table->SetColCount( 2 );
121 for(
int ii = 0; ii < 4; ++ii )
156 BOOST_FAIL( wxString::Format(
157 "Unhandled type: %d "
158 "(if you created a new type you need to handle it in this switch statement)",
188 auto item = std::unique_ptr<EDA_ITEM>( Instantiate( type ) );
190 if( item ==
nullptr )
195 IterateOverPositionsAndReferences<EDA_ITEM>(
199 auto item = std::unique_ptr<EDA_ITEM>( aOriginalItem->Clone() );
200 VECTOR2I originalPos = item->GetPosition();
202 SCH_ITEM* schItem = dynamic_cast<SCH_ITEM*>( item.get() );
207 if( schItem != nullptr )
209 schItem->Move( aRef );
210 BOOST_CHECK_EQUAL( schItem->GetPosition(), originalPos + aRef );
212 schItem->Move( -aRef );
215 CompareItems( item.get(), aOriginalItem );
228 auto item = std::unique_ptr<EDA_ITEM>( Instantiate( type ) );
230 if( item ==
nullptr )
238 if( item->GetClass() ==
"SCH_SHEET_PIN" )
240 auto newItem = std::unique_ptr<EDA_ITEM>( item->Clone() );
244 if( schItem !=
nullptr )
248 schItem->
Rotate( m_sheet.GetBodyBoundingBox().GetCenter(), false );
249 schItem->
Rotate( m_sheet.GetBodyBoundingBox().GetCenter(), false );
250 schItem->
Rotate( m_sheet.GetBodyBoundingBox().GetCenter(), false );
251 schItem->
Rotate( m_sheet.GetBodyBoundingBox().GetCenter(), false );
254 CompareItems( newItem.get(), item.get() );
258 IterateOverPositionsAndReferences<EDA_ITEM>(
262 auto item = std::unique_ptr<EDA_ITEM>( aOriginalItem->Clone() );
264 SCH_ITEM* schItem = dynamic_cast<SCH_ITEM*>( item.get() );
266 if( schItem != nullptr )
268 schItem->SetFieldsAutoplaced( AUTOPLACE_NONE );
269 schItem->Rotate( aRef, false );
270 schItem->Rotate( aRef, false );
271 schItem->Rotate( aRef, false );
272 schItem->Rotate( aRef, false );
275 CompareItems( item.get(), aOriginalItem );
289 auto item = std::unique_ptr<EDA_ITEM>( Instantiate( type ) );
291 if( item ==
nullptr )
296 IterateOverPositionsAndReferences<EDA_ITEM>(
300 auto item = std::unique_ptr<EDA_ITEM>( aOriginalItem->Clone() );
302 SCH_ITEM* schItem = dynamic_cast<SCH_ITEM*>( item.get() );
306 if( schItem != nullptr )
308 schItem->SetFieldsAutoplaced( AUTOPLACE_NONE );
309 schItem->MirrorHorizontally( aRef.x );
310 schItem->MirrorHorizontally( aRef.x );
313 CompareItems( item.get(), aOriginalItem );
326 auto item = std::unique_ptr<EDA_ITEM>( Instantiate( type ) );
328 if( item ==
nullptr )
333 IterateOverPositionsAndReferences<EDA_ITEM>(
337 auto item = std::unique_ptr<EDA_ITEM>( aOriginalItem->Clone() );
339 SCH_ITEM* schItem = dynamic_cast<SCH_ITEM*>( item.get() );
344 if( schItem != nullptr )
346 schItem->SetFieldsAutoplaced( AUTOPLACE_NONE );
347 schItem->MirrorVertically( aRef.y );
348 schItem->MirrorVertically( aRef.y );
351 CompareItems( item.get(), aOriginalItem );
constexpr EDA_IU_SCALE schIUScale
constexpr coord_type GetLeft() const
constexpr coord_type GetRight() const
constexpr coord_type GetTop() const
constexpr coord_type GetBottom() const
A base class for most all the KiCad significant classes used in schematics and boards.
virtual VECTOR2I GetPosition() const
virtual const BOX2I GetBoundingBox() const
Return the orthogonal bounding box of this object for display purposes.
virtual void SetParentGroup(EDA_GROUP *aGroup)
void SetPolyShape(const SHAPE_POLY_SET &aShape)
Define a library symbol object.
Object to handle a bitmap image that can be inserted in a schematic.
Class for a bus to bus entry.
Class for a wire to bus entry.
A set of SCH_ITEMs (i.e., without duplicates).
Base class for any item which can be embedded within the SCHEMATIC container class,...
void SetFieldsAutoplaced(AUTOPLACE_ALGO aAlgo)
virtual void Rotate(const VECTOR2I &aCenter, bool aRotateCCW)
Rotate the item around aCenter 90 degrees in the clockwise direction.
Segment description base class to describe items which have 2 end points (track, wire,...
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 SetSize(const VECTOR2I &aSize)
void SetPosition(const VECTOR2I &aPosition) override
VECTOR2I GetPosition() const override
void Append(int aX, int aY, bool aAllowDuplication=false)
Append a new point at the end of the line chain.
Represent a set of closed polygons.
SHAPE_LINE_CHAIN & Outline(int aIndex)
Return the reference to aIndex-th outline in the set.
int NewOutline()
Creates a new empty polygon in the set and returns its index.
EDA_ITEM * Instantiate(KICAD_T aType)
static void CompareItems(EDA_ITEM *aItem, EDA_ITEM *aOriginalItem)
std::shared_ptr< ERC_ITEM > m_ercItem
@ ERCE_DRIVER_CONFLICT
Conflicting drivers (labels, etc) on a subgraph.
Class to handle a set of SCH_ITEMs.
constexpr int mmToIU(double mm) const
BOOST_CHECK_EQUAL(ret, c.m_exp_result)
BOOST_AUTO_TEST_CASE(Move)
BOOST_AUTO_TEST_SUITE_END()
BOOST_TEST_CONTEXT("Test Clearance")
KICAD_T
The set of class identification values stored in EDA_ITEM::m_structType.
constexpr bool IsInstantiableType(const KICAD_T aType)
constexpr bool IsEeschemaType(const KICAD_T aType)
VECTOR2< int32_t > VECTOR2I