From cfe0003ca4aaafd37c5a1d39b0a1d6423265e63a Mon Sep 17 00:00:00 2001 From: jean-pierre charras Date: Sun, 27 Mar 2022 18:48:55 +0200 Subject: [PATCH] Eeschema: fix misplaced nullptr test that prevent saving SCH_TEXT items. Fixes #11250 https://gitlab.com/kicad/code/kicad/issues/11250 --- eeschema/sch_plugins/kicad/sch_sexpr_plugin.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/eeschema/sch_plugins/kicad/sch_sexpr_plugin.cpp b/eeschema/sch_plugins/kicad/sch_sexpr_plugin.cpp index d083c35982..ac8e2b15e4 100644 --- a/eeschema/sch_plugins/kicad/sch_sexpr_plugin.cpp +++ b/eeschema/sch_plugins/kicad/sch_sexpr_plugin.cpp @@ -1057,10 +1057,9 @@ void SCH_SEXPR_PLUGIN::saveText( SCH_TEXT* aText, int aNestLevel ) { wxCHECK_RET( aText != nullptr && m_out != nullptr, "" ); + // Note: label is nullptr SCH_TEXT, but not for SCH_LABEL_XXX, SCH_LABEL_BASE* label = dynamic_cast( aText ); - wxCHECK( label, /* void */ ); - m_out->Print( aNestLevel, "(%s %s", getTextTypeToken( aText->Type() ), m_out->Quotew( aText->GetText() ).c_str() ); @@ -1079,7 +1078,8 @@ void SCH_SEXPR_PLUGIN::saveText( SCH_TEXT* aText, int aNestLevel ) || aText->Type() == SCH_HIER_LABEL_T || aText->Type() == SCH_DIRECTIVE_LABEL_T ) { - m_out->Print( 0, " (shape %s)", getSheetPinShapeToken( label->GetShape() ) ); + if( label ) // Should be always the case + m_out->Print( 0, " (shape %s)", getSheetPinShapeToken( label->GetShape() ) ); // The angle of the text is always 0 or 90 degrees for readibility reasons, // but the item itself can have more rotation (-90 and 180 deg)