Fix type coercion from empty string pointer to 0
This commit is contained in:
parent
b7630450f1
commit
07969d1fa6
|
@ -32,6 +32,8 @@ string::string(const string & s)
|
||||||
}
|
}
|
||||||
|
|
||||||
string::string(const char * s)
|
string::string(const char * s)
|
||||||
|
{
|
||||||
|
if (s)
|
||||||
{
|
{
|
||||||
char l = sstrlen(s);
|
char l = sstrlen(s);
|
||||||
if (l)
|
if (l)
|
||||||
|
@ -43,6 +45,9 @@ string::string(const char * s)
|
||||||
else
|
else
|
||||||
cstr = nullptr;
|
cstr = nullptr;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
cstr = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
string::string(const char * s, char size)
|
string::string(const char * s, char size)
|
||||||
{
|
{
|
||||||
|
@ -102,6 +107,8 @@ string & string::operator=(const string & s)
|
||||||
string & string::operator=(const char * s)
|
string & string::operator=(const char * s)
|
||||||
{
|
{
|
||||||
free(cstr);
|
free(cstr);
|
||||||
|
if (s)
|
||||||
|
{
|
||||||
char l = sstrlen(s);
|
char l = sstrlen(s);
|
||||||
if (l)
|
if (l)
|
||||||
{
|
{
|
||||||
|
@ -111,6 +118,9 @@ string & string::operator=(const char * s)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
cstr = nullptr;
|
cstr = nullptr;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
cstr = nullptr;
|
||||||
|
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
@ -140,6 +150,8 @@ string & string::operator+=(const string & s)
|
||||||
}
|
}
|
||||||
|
|
||||||
string & string::operator+=(const char * s)
|
string & string::operator+=(const char * s)
|
||||||
|
{
|
||||||
|
if (s)
|
||||||
{
|
{
|
||||||
char sl = sstrlen(s);
|
char sl = sstrlen(s);
|
||||||
if (sl)
|
if (sl)
|
||||||
|
@ -161,6 +173,7 @@ string & string::operator+=(const char * s)
|
||||||
smemcpy(cstr + 1, s, sl + 1);
|
smemcpy(cstr + 1, s, sl + 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -225,6 +238,8 @@ string string::operator+(const string & s) const
|
||||||
string string::operator+(const char * s) const
|
string string::operator+(const char * s) const
|
||||||
{
|
{
|
||||||
if (cstr)
|
if (cstr)
|
||||||
|
{
|
||||||
|
if (s)
|
||||||
{
|
{
|
||||||
char sl = sstrlen(s);
|
char sl = sstrlen(s);
|
||||||
if (sl)
|
if (sl)
|
||||||
|
@ -238,6 +253,9 @@ string string::operator+(const char * s) const
|
||||||
else
|
else
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
return string(s);
|
return string(s);
|
||||||
}
|
}
|
||||||
|
|
|
@ -16736,7 +16736,7 @@ void InterCodeProcedure::Close(void)
|
||||||
{
|
{
|
||||||
GrowingTypeArray tstack(IT_NONE);
|
GrowingTypeArray tstack(IT_NONE);
|
||||||
|
|
||||||
CheckFunc = !strcmp(mIdent->mString, "MenuItem::+MenuItem");
|
CheckFunc = !strcmp(mIdent->mString, "main");
|
||||||
|
|
||||||
mEntryBlock = mBlocks[0];
|
mEntryBlock = mBlocks[0];
|
||||||
|
|
||||||
|
|
|
@ -150,6 +150,11 @@ InterCodeGenerator::ExValue InterCodeGenerator::CoerceType(InterCodeProcedure* p
|
||||||
v.mTemp = cins->mDst.mTemp;
|
v.mTemp = cins->mDst.mTemp;
|
||||||
v.mType = type;
|
v.mType = type;
|
||||||
}
|
}
|
||||||
|
else if (type->mType == DT_TYPE_POINTER && v.mType->mType == DT_TYPE_ARRAY)
|
||||||
|
{
|
||||||
|
v.mType = type;
|
||||||
|
return v;
|
||||||
|
}
|
||||||
else if (v.mType->mSize < type->mSize)
|
else if (v.mType->mSize < type->mSize)
|
||||||
{
|
{
|
||||||
if (v.mType->mSize == 1 && type->mSize == 2)
|
if (v.mType->mSize == 1 && type->mSize == 2)
|
||||||
|
|
Loading…
Reference in New Issue