mirror of
https://github.com/autc04/Retro68.git
synced 2025-01-11 18:30:58 +00:00
Rez: strings
This commit is contained in:
parent
399131a8a6
commit
e0ab85c1c4
@ -8,6 +8,11 @@ int Expression::evaluateInt(ResourceCompiler *ctx)
|
|||||||
throw TypeError();
|
throw TypeError();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string Expression::evaluateString(ResourceCompiler *ctx)
|
||||||
|
{
|
||||||
|
throw TypeError();
|
||||||
|
}
|
||||||
|
|
||||||
Expression::~Expression()
|
Expression::~Expression()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
@ -17,6 +22,11 @@ StringExpr::~StringExpr()
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string StringExpr::evaluateString(ResourceCompiler *ctx)
|
||||||
|
{
|
||||||
|
return str;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
IntExpr::~IntExpr()
|
IntExpr::~IntExpr()
|
||||||
{
|
{
|
||||||
|
@ -34,6 +34,7 @@ class Expression
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual int evaluateInt(ResourceCompiler *ctx);
|
virtual int evaluateInt(ResourceCompiler *ctx);
|
||||||
|
virtual std::string evaluateString(ResourceCompiler *ctx);
|
||||||
virtual ~Expression();
|
virtual ~Expression();
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -43,6 +44,7 @@ class StringExpr : public Expression
|
|||||||
public:
|
public:
|
||||||
StringExpr(const std::string& str) : str(str) {}
|
StringExpr(const std::string& str) : str(str) {}
|
||||||
~StringExpr();
|
~StringExpr();
|
||||||
|
virtual std::string evaluateString(ResourceCompiler *ctx);
|
||||||
};
|
};
|
||||||
|
|
||||||
class IntExpr : public Expression
|
class IntExpr : public Expression
|
||||||
|
@ -88,7 +88,69 @@ bool SimpleField::needsValue()
|
|||||||
|
|
||||||
void SimpleField::compile(ExprPtr expr, ResourceCompiler *compiler, bool prePass)
|
void SimpleField::compile(ExprPtr expr, ResourceCompiler *compiler, bool prePass)
|
||||||
{
|
{
|
||||||
int bitSize;
|
switch(type)
|
||||||
|
{
|
||||||
|
case Type::bitstring:
|
||||||
|
case Type::boolean:
|
||||||
|
case Type::byte:
|
||||||
|
case Type::integer:
|
||||||
|
case Type::longint:
|
||||||
|
compileInt(expr, compiler, prePass);
|
||||||
|
break;
|
||||||
|
case Type::string:
|
||||||
|
case Type::wstring:
|
||||||
|
case Type::pstring:
|
||||||
|
case Type::char_:
|
||||||
|
compileString(expr, compiler, prePass);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void SimpleField::compileString(ExprPtr expr, ResourceCompiler *compiler, bool prePass)
|
||||||
|
{
|
||||||
|
std::string str;
|
||||||
|
{
|
||||||
|
ResourceCompiler::FieldScope scope(compiler, this);
|
||||||
|
str = (value ? value : expr)->evaluateString(compiler);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(arrayCount || type == Type::char_)
|
||||||
|
{
|
||||||
|
int requestedSize = type == Type::char_ ? 1 : arrayCount->evaluateInt(compiler);
|
||||||
|
if(requestedSize < str.size())
|
||||||
|
str.erase(str.begin() + requestedSize, str.end());
|
||||||
|
else if(requestedSize > str.size())
|
||||||
|
str.insert(str.end(),requestedSize - str.size(), '\0');
|
||||||
|
}
|
||||||
|
|
||||||
|
int count = str.size();
|
||||||
|
|
||||||
|
if(type == Type::pstring)
|
||||||
|
{
|
||||||
|
if(count > 255)
|
||||||
|
{
|
||||||
|
str.erase(str.begin() + 255, str.end());
|
||||||
|
count = 255;
|
||||||
|
}
|
||||||
|
compiler->write(8, count);
|
||||||
|
}
|
||||||
|
else if(type == Type::wstring)
|
||||||
|
{
|
||||||
|
if(count > 65535)
|
||||||
|
{
|
||||||
|
str.erase(str.begin() + 65535, str.end());
|
||||||
|
count = 65535;
|
||||||
|
}
|
||||||
|
compiler->write(16, count);
|
||||||
|
}
|
||||||
|
|
||||||
|
for(char c : str)
|
||||||
|
compiler->write(8, c);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SimpleField::compileInt(ExprPtr expr, ResourceCompiler *compiler, bool prePass)
|
||||||
|
{
|
||||||
|
int bitSize = 0;
|
||||||
|
|
||||||
switch(type)
|
switch(type)
|
||||||
{
|
{
|
||||||
@ -113,15 +175,7 @@ void SimpleField::compile(ExprPtr expr, ResourceCompiler *compiler, bool prePass
|
|||||||
if(!prePass)
|
if(!prePass)
|
||||||
{
|
{
|
||||||
ResourceCompiler::FieldScope scope(compiler, this);
|
ResourceCompiler::FieldScope scope(compiler, this);
|
||||||
if(value)
|
actualValue = (value ? value : expr)->evaluateInt(compiler);
|
||||||
{
|
|
||||||
actualValue = value->evaluateInt(compiler);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// TODO: add alternatives to context
|
|
||||||
actualValue = expr->evaluateInt(compiler);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
compiler->write(bitSize, actualValue);
|
compiler->write(bitSize, actualValue);
|
||||||
|
@ -90,6 +90,10 @@ public:
|
|||||||
|
|
||||||
virtual bool needsValue();
|
virtual bool needsValue();
|
||||||
virtual void compile(ExprPtr expr, ResourceCompiler *compiler, bool prePass);
|
virtual void compile(ExprPtr expr, ResourceCompiler *compiler, bool prePass);
|
||||||
|
|
||||||
|
private:
|
||||||
|
void compileString(ExprPtr expr, ResourceCompiler *compiler, bool prePass);
|
||||||
|
void compileInt(ExprPtr expr, ResourceCompiler *compiler, bool prePass);
|
||||||
};
|
};
|
||||||
typedef std::shared_ptr<SimpleField> SimpleFieldPtr;
|
typedef std::shared_ptr<SimpleField> SimpleFieldPtr;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user