From c53fe1c1f083d92dd3bab4386259807879aeab5e Mon Sep 17 00:00:00 2001 From: Seth Hillbrand Date: Thu, 18 Aug 2022 11:53:11 -0700 Subject: [PATCH] Be more verbose when finding an error Try to give the user more information about what the actual file error is, rather than immediately throwing the IO_ERROR --- .../sch_plugins/kicad/sch_sexpr_parser.cpp | 26 +++++++++++++++++-- 1 file changed, 24 insertions(+), 2 deletions(-) diff --git a/eeschema/sch_plugins/kicad/sch_sexpr_parser.cpp b/eeschema/sch_plugins/kicad/sch_sexpr_parser.cpp index 2f546b9908..ea3e0fd5af 100644 --- a/eeschema/sch_plugins/kicad/sch_sexpr_parser.cpp +++ b/eeschema/sch_plugins/kicad/sch_sexpr_parser.cpp @@ -187,9 +187,20 @@ LIB_SYMBOL* SCH_SEXPR_PARSER::ParseSymbol( LIB_SYMBOL_MAP& aSymbolLibMap, int aF name = FromUTF8(); LIB_ID id; + int bad_pos = id.Parse( name ); - if( id.Parse( name ) >= 0 ) + if( bad_pos >= 0 ) { + if( static_cast( name.size() ) > bad_pos ) + { + wxString msg = wxString::Format( + _( "Symbol %s contains invalid character '%c'" ), name, + name[bad_pos] ); + + THROW_PARSE_ERROR( msg, CurSource(), CurLine(), CurLineNumber(), CurOffset() ); + } + + THROW_PARSE_ERROR( _( "Invalid library identifier" ), CurSource(), CurLine(), CurLineNumber(), CurOffset() ); } @@ -2443,9 +2454,20 @@ SCH_SYMBOL* SCH_SEXPR_PARSER::parseSchematicSymbol() Expecting( "symbol|number" ); LIB_ID libId; + wxString name = FromUTF8(); + int bad_pos = libId.Parse( name ); - if( libId.Parse( FromUTF8() ) >= 0 ) + if( bad_pos >= 0 ) { + if( static_cast( name.size() ) > bad_pos ) + { + wxString msg = wxString::Format( + _( "Symbol %s contains invalid character '%c'" ), name, + name[bad_pos] ); + + THROW_PARSE_ERROR( msg, CurSource(), CurLine(), CurLineNumber(), CurOffset() ); + } + THROW_PARSE_ERROR( _( "Invalid symbol library ID" ), CurSource(), CurLine(), CurLineNumber(), CurOffset() ); }