Don't create SCH_LINE till we know the layer.
The CTOR makes some decisions on initialization based on the layer.
This commit is contained in:
parent
f23cd9c9e5
commit
58b5ac4970
|
@ -549,8 +549,7 @@ void SCH_SEXPR_PARSER::parseStroke( STROKE_PARAMS& aStroke )
|
||||||
|
|
||||||
void SCH_SEXPR_PARSER::parseFill( FILL_PARAMS& aFill )
|
void SCH_SEXPR_PARSER::parseFill( FILL_PARAMS& aFill )
|
||||||
{
|
{
|
||||||
wxCHECK_RET( CurTok() == T_fill,
|
wxCHECK_RET( CurTok() == T_fill, "Cannot parse " + GetTokenString( CurTok() ) + " as a fill." );
|
||||||
wxT( "Cannot parse " ) + GetTokenString( CurTok() ) + wxT( " as fill." ) );
|
|
||||||
|
|
||||||
aFill.m_FillType = FILL_T::NO_FILL;
|
aFill.m_FillType = FILL_T::NO_FILL;
|
||||||
aFill.m_Color = COLOR4D::UNSPECIFIED;
|
aFill.m_Color = COLOR4D::UNSPECIFIED;
|
||||||
|
@ -605,7 +604,7 @@ void SCH_SEXPR_PARSER::parseFill( FILL_PARAMS& aFill )
|
||||||
void SCH_SEXPR_PARSER::parseEDA_TEXT( EDA_TEXT* aText, bool aConvertOverbarSyntax )
|
void SCH_SEXPR_PARSER::parseEDA_TEXT( EDA_TEXT* aText, bool aConvertOverbarSyntax )
|
||||||
{
|
{
|
||||||
wxCHECK_RET( aText && CurTok() == T_effects,
|
wxCHECK_RET( aText && CurTok() == T_effects,
|
||||||
wxT( "Cannot parse " ) + GetTokenString( CurTok() ) + wxT( " as EDA_TEXT." ) );
|
"Cannot parse " + GetTokenString( CurTok() ) + " as an EDA_TEXT." );
|
||||||
|
|
||||||
// In version 20210606 the notation for overbars was changed from `~...~` to `~{...}`.
|
// In version 20210606 the notation for overbars was changed from `~...~` to `~{...}`.
|
||||||
// We need to convert the old syntax to the new one.
|
// We need to convert the old syntax to the new one.
|
||||||
|
@ -729,8 +728,7 @@ void SCH_SEXPR_PARSER::parseHeader( TSCHEMATIC_T::T aHeaderType, int aFileVersio
|
||||||
void SCH_SEXPR_PARSER::parsePinNames( std::unique_ptr<LIB_SYMBOL>& aSymbol )
|
void SCH_SEXPR_PARSER::parsePinNames( std::unique_ptr<LIB_SYMBOL>& aSymbol )
|
||||||
{
|
{
|
||||||
wxCHECK_RET( CurTok() == T_pin_names,
|
wxCHECK_RET( CurTok() == T_pin_names,
|
||||||
wxT( "Cannot parse " ) + GetTokenString( CurTok() ) +
|
"Cannot parse " + GetTokenString( CurTok() ) + " as a pin_name token." );
|
||||||
wxT( " as a pin_name token." ) );
|
|
||||||
|
|
||||||
wxString error;
|
wxString error;
|
||||||
|
|
||||||
|
@ -1603,8 +1601,7 @@ void SCH_SEXPR_PARSER::parsePAGE_INFO( PAGE_INFO& aPageInfo )
|
||||||
void SCH_SEXPR_PARSER::parseTITLE_BLOCK( TITLE_BLOCK& aTitleBlock )
|
void SCH_SEXPR_PARSER::parseTITLE_BLOCK( TITLE_BLOCK& aTitleBlock )
|
||||||
{
|
{
|
||||||
wxCHECK_RET( CurTok() == T_title_block,
|
wxCHECK_RET( CurTok() == T_title_block,
|
||||||
wxT( "Cannot parse " ) + GetTokenString( CurTok() ) +
|
"Cannot parse " + GetTokenString( CurTok() ) + " as a TITLE_BLOCK." );
|
||||||
wxT( " as TITLE_BLOCK." ) );
|
|
||||||
|
|
||||||
T token;
|
T token;
|
||||||
|
|
||||||
|
@ -1708,8 +1705,7 @@ void SCH_SEXPR_PARSER::parseTITLE_BLOCK( TITLE_BLOCK& aTitleBlock )
|
||||||
SCH_FIELD* SCH_SEXPR_PARSER::parseSchField( SCH_ITEM* aParent )
|
SCH_FIELD* SCH_SEXPR_PARSER::parseSchField( SCH_ITEM* aParent )
|
||||||
{
|
{
|
||||||
wxCHECK_MSG( CurTok() == T_property, nullptr,
|
wxCHECK_MSG( CurTok() == T_property, nullptr,
|
||||||
wxT( "Cannot parse " ) + GetTokenString( CurTok() ) +
|
"Cannot parse " + GetTokenString( CurTok() ) + " as a property token." );
|
||||||
wxT( " as a property token." ) );
|
|
||||||
|
|
||||||
T token = NextTok();
|
T token = NextTok();
|
||||||
|
|
||||||
|
@ -1781,8 +1777,7 @@ SCH_SHEET_PIN* SCH_SEXPR_PARSER::parseSchSheetPin( SCH_SHEET* aSheet )
|
||||||
{
|
{
|
||||||
wxCHECK_MSG( aSheet != nullptr, nullptr, "" );
|
wxCHECK_MSG( aSheet != nullptr, nullptr, "" );
|
||||||
wxCHECK_MSG( CurTok() == T_pin, nullptr,
|
wxCHECK_MSG( CurTok() == T_pin, nullptr,
|
||||||
wxT( "Cannot parse " ) + GetTokenString( CurTok() ) +
|
"Cannot parse " + GetTokenString( CurTok() ) + " as a sheet pin token." );
|
||||||
wxT( " as a sheet pin token." ) );
|
|
||||||
|
|
||||||
T token = NextTok();
|
T token = NextTok();
|
||||||
|
|
||||||
|
@ -1867,8 +1862,7 @@ SCH_SHEET_PIN* SCH_SEXPR_PARSER::parseSchSheetPin( SCH_SHEET* aSheet )
|
||||||
void SCH_SEXPR_PARSER::parseSchSheetInstances( SCH_SHEET* aRootSheet, SCH_SCREEN* aScreen )
|
void SCH_SEXPR_PARSER::parseSchSheetInstances( SCH_SHEET* aRootSheet, SCH_SCREEN* aScreen )
|
||||||
{
|
{
|
||||||
wxCHECK_RET( CurTok() == T_sheet_instances,
|
wxCHECK_RET( CurTok() == T_sheet_instances,
|
||||||
wxT( "Cannot parse " ) + GetTokenString( CurTok() ) +
|
"Cannot parse " + GetTokenString( CurTok() ) + " as an instances token." );
|
||||||
wxT( " as a instances token." ) );
|
|
||||||
wxCHECK( aScreen, /* void */ );
|
wxCHECK( aScreen, /* void */ );
|
||||||
|
|
||||||
T token;
|
T token;
|
||||||
|
@ -1947,8 +1941,7 @@ void SCH_SEXPR_PARSER::parseSchSheetInstances( SCH_SHEET* aRootSheet, SCH_SCREEN
|
||||||
void SCH_SEXPR_PARSER::parseSchSymbolInstances( SCH_SCREEN* aScreen )
|
void SCH_SEXPR_PARSER::parseSchSymbolInstances( SCH_SCREEN* aScreen )
|
||||||
{
|
{
|
||||||
wxCHECK_RET( CurTok() == T_symbol_instances,
|
wxCHECK_RET( CurTok() == T_symbol_instances,
|
||||||
wxT( "Cannot parse " ) + GetTokenString( CurTok() ) +
|
"Cannot parse " + GetTokenString( CurTok() ) + " as an instances token." );
|
||||||
wxT( " as a instances token." ) );
|
|
||||||
wxCHECK( aScreen, /* void */ );
|
wxCHECK( aScreen, /* void */ );
|
||||||
|
|
||||||
T token;
|
T token;
|
||||||
|
@ -2771,20 +2764,21 @@ SCH_BUS_WIRE_ENTRY* SCH_SEXPR_PARSER::parseBusEntry()
|
||||||
|
|
||||||
SCH_LINE* SCH_SEXPR_PARSER::parseLine()
|
SCH_LINE* SCH_SEXPR_PARSER::parseLine()
|
||||||
{
|
{
|
||||||
T token;
|
T token;
|
||||||
STROKE_PARAMS stroke( Mils2iu( DEFAULT_LINE_WIDTH_MILS ), PLOT_DASH_TYPE::DEFAULT );
|
STROKE_PARAMS stroke( Mils2iu( DEFAULT_LINE_WIDTH_MILS ), PLOT_DASH_TYPE::DEFAULT );
|
||||||
std::unique_ptr<SCH_LINE> line = std::make_unique<SCH_LINE>();
|
int layer;
|
||||||
|
|
||||||
switch( CurTok() )
|
switch( CurTok() )
|
||||||
{
|
{
|
||||||
case T_polyline: line->SetLayer( LAYER_NOTES ); break;
|
case T_polyline: layer = LAYER_NOTES; break;
|
||||||
case T_wire: line->SetLayer( LAYER_WIRE ); break;
|
case T_wire: layer = LAYER_WIRE; break;
|
||||||
case T_bus: line->SetLayer( LAYER_BUS ); break;
|
case T_bus: layer = LAYER_BUS; break;
|
||||||
default:
|
default:
|
||||||
wxCHECK_MSG( false, nullptr,
|
wxCHECK_MSG( false, nullptr, "Cannot parse " + GetTokenString( CurTok() ) + " as a line." );
|
||||||
wxT( "Cannot parse " ) + GetTokenString( CurTok() ) + wxT( " as a line." ) );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::unique_ptr<SCH_LINE> line = std::make_unique<SCH_LINE>( wxPoint(), layer );
|
||||||
|
|
||||||
for( token = NextTok(); token != T_RIGHT; token = NextTok() )
|
for( token = NextTok(); token != T_RIGHT; token = NextTok() )
|
||||||
{
|
{
|
||||||
if( token != T_LEFT )
|
if( token != T_LEFT )
|
||||||
|
|
Loading…
Reference in New Issue