Be more explicit about string/character conversions.
This *may* fix the bug where a layer name isn't displayed correctly in the error dialog. But probably not.
This commit is contained in:
parent
9f6098321f
commit
0fecb5f277
|
@ -309,13 +309,12 @@ public:
|
||||||
VALUE* Run( CONTEXT* ctx );
|
VALUE* Run( CONTEXT* ctx );
|
||||||
std::string Dump() const;
|
std::string Dump() const;
|
||||||
|
|
||||||
virtual VAR_REF* createVarRef( COMPILER* aCompiler, const std::string& var,
|
virtual VAR_REF* createVarRef( COMPILER* aCompiler, const char* var, const char* field )
|
||||||
const std::string& field )
|
|
||||||
{
|
{
|
||||||
return nullptr;
|
return nullptr;
|
||||||
};
|
};
|
||||||
|
|
||||||
virtual FUNC_PTR createFuncCall( COMPILER* aCompiler, const std::string& name )
|
virtual FUNC_PTR createFuncCall( COMPILER* aCompiler, const char* name )
|
||||||
{
|
{
|
||||||
return nullptr;
|
return nullptr;
|
||||||
};
|
};
|
||||||
|
|
|
@ -140,7 +140,7 @@ bool DRC_RULE_CONDITION::Compile()
|
||||||
|
|
||||||
PCB_EXPR_CONTEXT preflightContext;
|
PCB_EXPR_CONTEXT preflightContext;
|
||||||
|
|
||||||
bool ok = compiler.Compile( (const char*) m_Expression.c_str(), m_ucode, &preflightContext );
|
bool ok = compiler.Compile( m_Expression.ToUTF8().data(), m_ucode, &preflightContext );
|
||||||
|
|
||||||
if( ok )
|
if( ok )
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -139,28 +139,28 @@ LIBEVAL::VALUE PCB_EXPR_VAR_REF::GetValue( LIBEVAL::CONTEXT* aCtx )
|
||||||
|
|
||||||
|
|
||||||
LIBEVAL::UCODE::FUNC_PTR PCB_EXPR_UCODE::createFuncCall( LIBEVAL::COMPILER* aCompiler,
|
LIBEVAL::UCODE::FUNC_PTR PCB_EXPR_UCODE::createFuncCall( LIBEVAL::COMPILER* aCompiler,
|
||||||
const std::string& name )
|
const char* aName )
|
||||||
{
|
{
|
||||||
PCB_EXPR_BUILTIN_FUNCTIONS& registry = PCB_EXPR_BUILTIN_FUNCTIONS::Instance();
|
PCB_EXPR_BUILTIN_FUNCTIONS& registry = PCB_EXPR_BUILTIN_FUNCTIONS::Instance();
|
||||||
|
|
||||||
auto f = registry.Get( boost::to_lower_copy( name ) );
|
std::string lowerName( aName );
|
||||||
|
boost::to_lower( lowerName );
|
||||||
|
|
||||||
return f;
|
return registry.Get( lowerName );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
LIBEVAL::VAR_REF* PCB_EXPR_UCODE::createVarRef( LIBEVAL::COMPILER *aCompiler,
|
LIBEVAL::VAR_REF* PCB_EXPR_UCODE::createVarRef( LIBEVAL::COMPILER *aCompiler, const char* aVar,
|
||||||
const std::string& aVar,
|
const char* aField )
|
||||||
const std::string& aField )
|
|
||||||
{
|
{
|
||||||
PROPERTY_MANAGER& propMgr = PROPERTY_MANAGER::Instance();
|
PROPERTY_MANAGER& propMgr = PROPERTY_MANAGER::Instance();
|
||||||
PCB_EXPR_VAR_REF* vref = nullptr;
|
PCB_EXPR_VAR_REF* vref = nullptr;
|
||||||
|
|
||||||
if( aVar == "A" )
|
if( *aVar == 'A' )
|
||||||
{
|
{
|
||||||
vref = new PCB_EXPR_VAR_REF( 0 );
|
vref = new PCB_EXPR_VAR_REF( 0 );
|
||||||
}
|
}
|
||||||
else if( aVar == "B" )
|
else if( *aVar == 'B' )
|
||||||
{
|
{
|
||||||
vref = new PCB_EXPR_VAR_REF( 1 );
|
vref = new PCB_EXPR_VAR_REF( 1 );
|
||||||
}
|
}
|
||||||
|
@ -170,11 +170,11 @@ LIBEVAL::VAR_REF* PCB_EXPR_UCODE::createVarRef( LIBEVAL::COMPILER *aCompiler,
|
||||||
return vref;
|
return vref;
|
||||||
}
|
}
|
||||||
|
|
||||||
if( aField.empty() ) // return reference to base object
|
if( strlen( aField ) == 0 ) // return reference to base object
|
||||||
return vref;
|
return vref;
|
||||||
|
|
||||||
std::string field( aField );
|
wxString field = wxString::FromUTF8( aField );
|
||||||
std::replace( field.begin(), field.end(), '_', ' ');
|
field.Replace( "_", " " );
|
||||||
|
|
||||||
for( const PROPERTY_MANAGER::CLASS_INFO& cls : propMgr.GetAllClasses() )
|
for( const PROPERTY_MANAGER::CLASS_INFO& cls : propMgr.GetAllClasses() )
|
||||||
{
|
{
|
||||||
|
@ -267,7 +267,7 @@ bool PCB_EXPR_EVALUATOR::Evaluate( const wxString& aExpr )
|
||||||
PCB_EXPR_UCODE ucode;
|
PCB_EXPR_UCODE ucode;
|
||||||
LIBEVAL::CONTEXT preflightContext;
|
LIBEVAL::CONTEXT preflightContext;
|
||||||
|
|
||||||
if( !m_compiler.Compile( (const char*) aExpr.c_str(), &ucode, &preflightContext ) )
|
if( !m_compiler.Compile( aExpr.ToUTF8().data(), &ucode, &preflightContext ) )
|
||||||
{
|
{
|
||||||
m_errorStatus = m_compiler.GetErrorStatus();
|
m_errorStatus = m_compiler.GetErrorStatus();
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -40,12 +40,10 @@ class PCB_EXPR_VAR_REF;
|
||||||
class PCB_EXPR_UCODE final : public LIBEVAL::UCODE
|
class PCB_EXPR_UCODE final : public LIBEVAL::UCODE
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual LIBEVAL::VAR_REF* createVarRef( LIBEVAL::COMPILER *aCompiler,
|
virtual LIBEVAL::VAR_REF* createVarRef( LIBEVAL::COMPILER *aCompiler, const char* aVar,
|
||||||
const std::string& aVar,
|
const char* aField ) override;
|
||||||
const std::string& aField ) override;
|
|
||||||
|
|
||||||
virtual FUNC_PTR createFuncCall( LIBEVAL::COMPILER* aCompiler,
|
virtual FUNC_PTR createFuncCall( LIBEVAL::COMPILER* aCompiler, const char* aName ) override;
|
||||||
const std::string& name ) override;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -70,7 +70,7 @@ bool test::DRC_RULE_CONDITION::Compile()
|
||||||
if (!m_ucode)
|
if (!m_ucode)
|
||||||
m_ucode = new PCB_EXPR_UCODE;
|
m_ucode = new PCB_EXPR_UCODE;
|
||||||
|
|
||||||
bool ok = compiler.Compile( (const char*) m_Expression.c_str(), m_ucode );
|
bool ok = compiler.Compile( m_Expression.ToUTF8().data(), m_ucode );
|
||||||
|
|
||||||
if( ok )
|
if( ok )
|
||||||
return true;
|
return true;
|
||||||
|
|
Loading…
Reference in New Issue