pcbnew: Fix Eagle UTF8 import error

Implicit convertion from wxString to std::string will use narrow strings
and drop UTF-8.

Fixes: lp:1789311
* https://bugs.launchpad.net/kicad/+bug/1789311
This commit is contained in:
Seth Hillbrand 2018-08-30 13:05:54 -07:00
parent d45946396c
commit 34b920a74f
1 changed files with 9 additions and 5 deletions

View File

@ -811,13 +811,16 @@ void EAGLE_PLUGIN::loadLibrary( wxXmlNode* aLib, const wxString* aLibName )
{ {
m_xpath->push( "package", "name" ); m_xpath->push( "package", "name" );
const wxString& pack_ref = package->GetAttribute( "name" ); wxString pack_ref = package->GetAttribute( "name" );
std::string pack_name( pack_ref ); ReplaceIllegalFileNameChars( pack_ref, '_' );
ReplaceIllegalFileNameChars( &pack_name, '_' ); std::string pack_name = Convert<std::string>( pack_ref );
if(pack_name.length() == 0 )
printf("Empty!\n");
m_xpath->Value( pack_name.c_str() ); m_xpath->Value( pack_name.c_str() );
wxString key = aLibName ? makeKey( *aLibName, pack_name ) : wxString( pack_name ); wxString key = aLibName ? makeKey( *aLibName, pack_ref ) : pack_ref;
MODULE* m = makeModule( package, pack_name ); MODULE* m = makeModule( package, pack_name );
@ -832,8 +835,9 @@ void EAGLE_PLUGIN::loadLibrary( wxXmlNode* aLib, const wxString* aLibName )
wxString pkg = FROM_UTF8( pack_name.c_str() ); wxString pkg = FROM_UTF8( pack_name.c_str() );
wxString emsg = wxString::Format( wxString emsg = wxString::Format(
_( "<package> name: \"%s\" duplicated in eagle <library>: \"%s\"" ), _( "<package> name: \"%s\" : %s duplicated in eagle <library>: \"%s\"" ),
GetChars( pkg ), GetChars( pkg ),
GetChars( key ),
GetChars( lib ) GetChars( lib )
); );
THROW_IO_ERROR( emsg ); THROW_IO_ERROR( emsg );