LIB_ID: fix incorrect detection of illegal chars, when values are not ASCII values.

Fixes: lp:1764055
https://bugs.launchpad.net/kicad/+bug/1764055
This commit is contained in:
jean-pierre charras 2018-04-30 11:44:35 +02:00
parent b636aaddf6
commit 7395949ae0
3 changed files with 15 additions and 10 deletions

View File

@ -403,18 +403,19 @@ const unsigned schIllegalChars[] = { BASE_ILLEGAL_CHARS, ' ' };
const unsigned pcbIllegalChars[] = { BASE_ILLEGAL_CHARS, 0 }; const unsigned pcbIllegalChars[] = { BASE_ILLEGAL_CHARS, 0 };
#define ILL_CHAR_SIZE (sizeof(schIllegalChars) / sizeof(int)) #define ILL_CHAR_SIZE (sizeof(schIllegalChars) / sizeof(int))
bool LIB_ID::isLegalChar( unsigned aChar, LIB_ID_TYPE aType ) bool LIB_ID::isLegalChar( unsigned aUniChar, LIB_ID_TYPE aType )
{ {
const unsigned (&illegalChars)[ILL_CHAR_SIZE] = const unsigned (&illegalChars)[ILL_CHAR_SIZE] =
aType == ID_SCH ? schIllegalChars : pcbIllegalChars; aType == ID_SCH ? schIllegalChars : pcbIllegalChars;
for( const unsigned ch : illegalChars ) for( const unsigned ch : illegalChars )
{ {
if( ch == aChar ) if( ch == aUniChar )
return false; return false;
} }
if( !wxIsascii( aChar ) ) // Test for "printable" code (aUniChar is a unicode (32 bits) char, not a ASCII value )
if( aUniChar < ' ' )
return false; return false;
return true; return true;

View File

@ -137,7 +137,6 @@ void RESCUE_CASE_CANDIDATE::FindRescues( RESCUER& aRescuer,
{ {
typedef std::map<wxString, RESCUE_CASE_CANDIDATE> candidate_map_t; typedef std::map<wxString, RESCUE_CASE_CANDIDATE> candidate_map_t;
candidate_map_t candidate_map; candidate_map_t candidate_map;
// Remember the list of components is sorted by part name. // Remember the list of components is sorted by part name.
// So a search in libraries is made only once by group // So a search in libraries is made only once by group
LIB_ALIAS* case_sensitive_match = nullptr; LIB_ALIAS* case_sensitive_match = nullptr;
@ -383,12 +382,14 @@ void RESCUE_SYMBOL_LIB_TABLE_CANDIDATE::FindRescues(
&& !cache_match->PinsConflictWith( *lib_match, true, true, true, true, false ) ) && !cache_match->PinsConflictWith( *lib_match, true, true, true, true, false ) )
|| (!cache_match && lib_match ) ) || (!cache_match && lib_match ) )
&& !LIB_ID::HasIllegalChars( part_id.GetLibItemName(), LIB_ID::ID_SCH ) ) && !LIB_ID::HasIllegalChars( part_id.GetLibItemName(), LIB_ID::ID_SCH ) )
{
continue; continue;
}
// Fix illegal LIB_ID name characters. // Fix illegal LIB_ID name characters.
wxString new_name = LIB_ID::FixIllegalChars( part_id.GetLibItemName(), LIB_ID::ID_SCH ); wxString new_name = LIB_ID::FixIllegalChars( part_id.GetLibItemName(), LIB_ID::ID_SCH );
// Differentiate symbol name in the resue library by appending the symbol library // Differentiate symbol name in the rescue library by appending the symbol library
// table nickname to the symbol name to prevent name clashes in the rescue library. // table nickname to the symbol name to prevent name clashes in the rescue library.
wxString libNickname = GetRescueLibraryFileName().GetName(); wxString libNickname = GetRescueLibraryFileName().GetName();

View File

@ -236,8 +236,11 @@ public:
#endif #endif
protected: protected:
///> Tests whether a character is a legal LIB_ID character /** Tests whether a unicode character is a legal LIB_ID character
static bool isLegalChar( unsigned aChar, LIB_ID_TYPE aType ); * note: aUniChar is expected to be a unicode 32 bits char, not a UTF8 char, that use
* a variable lenght coding value
*/
static bool isLegalChar( unsigned aUniChar, LIB_ID_TYPE aType );
UTF8 nickname; ///< The nickname of the library or empty. UTF8 nickname; ///< The nickname of the library or empty.
UTF8 item_name; ///< The name of the entry in the logical library. UTF8 item_name; ///< The name of the entry in the logical library.