Files
Descent3/AngelScript/scriptstring/scriptstring.cpp
Kevin Bentley df209742fc Initial import
2024-04-15 21:43:29 -06:00

706 lines
25 KiB
C++

#include <assert.h>
#include <string.h> // strstr
#include <stdio.h> // sprintf
#include "scriptstring.h"
using namespace std;
BEGIN_AS_NAMESPACE
//--------------
// constructors
//--------------
CScriptString::CScriptString()
{
// Count the first reference
refCount = 1;
}
CScriptString::CScriptString(const char *s, unsigned int len)
{
refCount = 1;
buffer.assign(s, len);
}
CScriptString::CScriptString(const string &s)
{
refCount = 1;
buffer = s;
}
CScriptString::CScriptString(const CScriptString &s)
{
refCount = 1;
buffer = s.buffer;
}
CScriptString::~CScriptString()
{
assert( refCount == 0 );
}
//--------------------
// reference counting
//--------------------
void CScriptString::AddRef()
{
refCount++;
}
static void StringAddRef_Generic(asIScriptGeneric *gen)
{
CScriptString *thisPointer = (CScriptString*)gen->GetObject();
thisPointer->AddRef();
}
void CScriptString::Release()
{
if( --refCount == 0 )
delete this;
}
static void StringRelease_Generic(asIScriptGeneric *gen)
{
CScriptString *thisPointer = (CScriptString*)gen->GetObject();
thisPointer->Release();
}
//-----------------
// string = string
//-----------------
CScriptString &CScriptString::operator=(const CScriptString &other)
{
// Copy only the buffer, not the reference counter
buffer = other.buffer;
// Return a reference to this object
return *this;
}
static void AssignString_Generic(asIScriptGeneric *gen)
{
CScriptString *a = (CScriptString*)gen->GetArgAddress(0);
CScriptString *thisPointer = (CScriptString*)gen->GetObject();
*thisPointer = *a;
gen->SetReturnAddress(thisPointer);
}
//------------------
// string += string
//------------------
CScriptString &CScriptString::operator+=(const CScriptString &other)
{
buffer += other.buffer;
return *this;
}
static void AddAssignString_Generic(asIScriptGeneric *gen)
{
CScriptString *a = (CScriptString*)gen->GetArgAddress(0);
CScriptString *thisPointer = (CScriptString*)gen->GetObject();
*thisPointer += *a;
gen->SetReturnAddress(thisPointer);
}
//-----------------
// string opCmp string
//-----------------
static int StringCmp(const string &a, const string &b)
{
int cmp = 0;
if( a < b ) cmp = -1;
else if( a > b ) cmp = 1;
return cmp;
}
static void StringCmp_Generic(asIScriptGeneric * gen)
{
string * a = static_cast<string *>(gen->GetObject());
string * b = static_cast<string *>(gen->GetArgAddress(0));
int cmp = 0;
if( *a < *b ) cmp = -1;
else if( *a > *b ) cmp = 1;
*(int*)gen->GetAddressOfReturnLocation() = cmp;
}
//-----------------
// string + string
//-----------------
CScriptString *operator+(const CScriptString &a, const CScriptString &b)
{
// Return a new object as a script handle
CScriptString *str = new CScriptString();
// Avoid unnecessary memory copying by first reserving the full memory buffer, then concatenating
str->buffer.reserve(a.buffer.length() + b.buffer.length());
str->buffer += a.buffer;
str->buffer += b.buffer;
return str;
}
static void ConcatenateStrings_Generic(asIScriptGeneric *gen)
{
CScriptString *a = (CScriptString*)gen->GetObject();
CScriptString *b = (CScriptString*)gen->GetArgAddress(0);
CScriptString *out = *a + *b;
gen->SetReturnAddress(out);
}
//----------------
// string = value
//----------------
static CScriptString &AssignUIntToString(unsigned int i, CScriptString &dest)
{
char buf[100];
sprintf(buf, "%u", i);
dest.buffer = buf;
return dest;
}
static void AssignUIntToString_Generic(asIScriptGeneric *gen)
{
unsigned int i = gen->GetArgDWord(0);
CScriptString *thisPointer = (CScriptString*)gen->GetObject();
AssignUIntToString(i, *thisPointer);
gen->SetReturnAddress(thisPointer);
}
static CScriptString &AssignIntToString(int i, CScriptString &dest)
{
char buf[100];
sprintf(buf, "%d", i);
dest.buffer = buf;
return dest;
}
static void AssignIntToString_Generic(asIScriptGeneric *gen)
{
int i = gen->GetArgDWord(0);
CScriptString *thisPointer = (CScriptString*)gen->GetObject();
AssignIntToString(i, *thisPointer);
gen->SetReturnAddress(thisPointer);
}
static CScriptString &AssignFloatToString(float f, CScriptString &dest)
{
char buf[100];
sprintf(buf, "%g", f);
dest.buffer = buf;
return dest;
}
static void AssignFloatToString_Generic(asIScriptGeneric *gen)
{
float f = gen->GetArgFloat(0);
CScriptString *thisPointer = (CScriptString*)gen->GetObject();
AssignFloatToString(f, *thisPointer);
gen->SetReturnAddress(thisPointer);
}
static CScriptString &AssignDoubleToString(double f, CScriptString &dest)
{
char buf[100];
sprintf(buf, "%g", f);
dest.buffer = buf;
return dest;
}
static void AssignDoubleToString_Generic(asIScriptGeneric *gen)
{
double f = gen->GetArgDouble(0);
CScriptString *thisPointer = (CScriptString*)gen->GetObject();
AssignDoubleToString(f, *thisPointer);
gen->SetReturnAddress(thisPointer);
}
//-----------------
// string += value
//-----------------
static CScriptString &AddAssignUIntToString(unsigned int i, CScriptString &dest)
{
char buf[100];
sprintf(buf, "%u", i);
dest.buffer += buf;
return dest;
}
static void AddAssignUIntToString_Generic(asIScriptGeneric *gen)
{
unsigned int i = gen->GetArgDWord(0);
CScriptString *thisPointer = (CScriptString*)gen->GetObject();
AddAssignUIntToString(i, *thisPointer);
gen->SetReturnAddress(thisPointer);
}
static CScriptString &AddAssignIntToString(int i, CScriptString &dest)
{
char buf[100];
sprintf(buf, "%d", i);
dest.buffer += buf;
return dest;
}
static void AddAssignIntToString_Generic(asIScriptGeneric *gen)
{
int i = gen->GetArgDWord(0);
CScriptString *thisPointer = (CScriptString*)gen->GetObject();
AddAssignIntToString(i, *thisPointer);
gen->SetReturnAddress(thisPointer);
}
static CScriptString &AddAssignFloatToString(float f, CScriptString &dest)
{
char buf[100];
sprintf(buf, "%g", f);
dest.buffer += buf;
return dest;
}
static void AddAssignFloatToString_Generic(asIScriptGeneric *gen)
{
float f = gen->GetArgFloat(0);
CScriptString *thisPointer = (CScriptString*)gen->GetObject();
AddAssignFloatToString(f, *thisPointer);
gen->SetReturnAddress(thisPointer);
}
static CScriptString &AddAssignDoubleToString(double f, CScriptString &dest)
{
char buf[100];
sprintf(buf, "%g", f);
dest.buffer += buf;
return dest;
}
static void AddAssignDoubleToString_Generic(asIScriptGeneric *gen)
{
double f = gen->GetArgDouble(0);
CScriptString *thisPointer = (CScriptString*)gen->GetObject();
AddAssignDoubleToString(f, *thisPointer);
gen->SetReturnAddress(thisPointer);
}
//----------------
// string + value
//----------------
static CScriptString *AddStringUInt(const CScriptString &str, unsigned int i)
{
char buf[100];
sprintf(buf, "%u", i);
return new CScriptString(str.buffer + buf);
}
static void AddStringUInt_Generic(asIScriptGeneric *gen)
{
CScriptString *str = (CScriptString*)gen->GetObject();
unsigned int i = gen->GetArgDWord(0);
CScriptString *out = AddStringUInt(*str, i);
gen->SetReturnAddress(out);
}
static CScriptString *AddStringInt(const CScriptString &str, int i)
{
char buf[100];
sprintf(buf, "%d", i);
return new CScriptString(str.buffer + buf);
}
static void AddStringInt_Generic(asIScriptGeneric *gen)
{
CScriptString *str = (CScriptString*)gen->GetObject();
int i = gen->GetArgDWord(0);
CScriptString *out = AddStringInt(*str, i);
gen->SetReturnAddress(out);
}
static CScriptString *AddStringFloat(const CScriptString &str, float f)
{
char buf[100];
sprintf(buf, "%g", f);
return new CScriptString(str.buffer + buf);
}
static void AddStringFloat_Generic(asIScriptGeneric *gen)
{
CScriptString *str = (CScriptString*)gen->GetObject();
float f = gen->GetArgFloat(0);
CScriptString *out = AddStringFloat(*str, f);
gen->SetReturnAddress(out);
}
static CScriptString *AddStringDouble(const CScriptString &str, double f)
{
char buf[100];
sprintf(buf, "%g", f);
return new CScriptString(str.buffer + buf);
}
static void AddStringDouble_Generic(asIScriptGeneric *gen)
{
CScriptString *str = (CScriptString*)gen->GetObject();
double f = gen->GetArgDouble(0);
CScriptString *out = AddStringDouble(*str, f);
gen->SetReturnAddress(out);
}
//----------------
// value + string
//----------------
static CScriptString *AddIntString(int i, const CScriptString &str)
{
char buf[100];
sprintf(buf, "%d", i);
return new CScriptString(buf + str.buffer);
}
static void AddIntString_Generic(asIScriptGeneric *gen)
{
int i = gen->GetArgDWord(0);
CScriptString *str = (CScriptString*)gen->GetObject();
CScriptString *out = AddIntString(i, *str);
gen->SetReturnAddress(out);
}
static CScriptString *AddUIntString(unsigned int i, const CScriptString &str)
{
char buf[100];
sprintf(buf, "%u", i);
return new CScriptString(buf + str.buffer);
}
static void AddUIntString_Generic(asIScriptGeneric *gen)
{
unsigned int i = gen->GetArgDWord(0);
CScriptString *str = (CScriptString*)gen->GetObject();
CScriptString *out = AddUIntString(i, *str);
gen->SetReturnAddress(out);
}
static CScriptString *AddFloatString(float f, const CScriptString &str)
{
char buf[100];
sprintf(buf, "%g", f);
return new CScriptString(buf + str.buffer);
}
static void AddFloatString_Generic(asIScriptGeneric *gen)
{
float f = gen->GetArgFloat(0);
CScriptString *str = (CScriptString*)gen->GetObject();
CScriptString *out = AddFloatString(f, *str);
gen->SetReturnAddress(out);
}
static CScriptString *AddDoubleString(double f, const CScriptString &str)
{
char buf[100];
sprintf(buf, "%g", f);
return new CScriptString(buf + str.buffer);
}
static void AddDoubleString_Generic(asIScriptGeneric *gen)
{
double f = gen->GetArgDouble(0);
CScriptString *str = (CScriptString*)gen->GetObject();
CScriptString *out = AddDoubleString(f, *str);
gen->SetReturnAddress(out);
}
//----------
// string[]
//----------
static char *StringCharAt(unsigned int i, CScriptString &str)
{
if( i >= str.buffer.size() )
{
// Set a script exception
asIScriptContext *ctx = asGetActiveContext();
ctx->SetException("Out of range");
// Return a null pointer
return 0;
}
return &str.buffer[i];
}
static void StringCharAt_Generic(asIScriptGeneric *gen)
{
unsigned int i = gen->GetArgDWord(0);
CScriptString *str = (CScriptString*)gen->GetObject();
char *ch = StringCharAt(i, *str);
gen->SetReturnAddress(ch);
}
//-----------------------
// AngelScript functions
//-----------------------
// This is the string factory that creates new strings for the script based on string literals
static CScriptString *StringFactory(asUINT length, const char *s)
{
return new CScriptString(s, length);
}
static void StringFactory_Generic(asIScriptGeneric *gen)
{
asUINT length = gen->GetArgDWord(0);
const char *s = (const char*)gen->GetArgAddress(1);
CScriptString *str = StringFactory(length, s);
gen->SetReturnAddress(str);
}
// This is the default string factory, that is responsible for creating empty string objects, e.g. when a variable is declared
static CScriptString *StringDefaultFactory()
{
// Allocate and initialize with the default constructor
return new CScriptString();
}
static CScriptString *StringCopyFactory(const CScriptString &other)
{
// Allocate and initialize with the copy constructor
return new CScriptString(other);
}
static void StringDefaultFactory_Generic(asIScriptGeneric *gen)
{
*(CScriptString**)gen->GetAddressOfReturnLocation() = StringDefaultFactory();
}
static void StringCopyFactory_Generic(asIScriptGeneric *gen)
{
CScriptString *other = (CScriptString *)gen->GetArgObject(0);
*(CScriptString**)gen->GetAddressOfReturnLocation() = StringCopyFactory(*other);
}
static void StringEqual_Generic(asIScriptGeneric *gen)
{
string *a = (string*)gen->GetArgAddress(0);
string *b = (string*)gen->GetArgAddress(1);
bool r = *a == *b;
*(bool*)gen->GetAddressOfReturnLocation() = r;
}
static void StringEquals_Generic(asIScriptGeneric * gen)
{
string * a = static_cast<string *>(gen->GetObject());
string * b = static_cast<string *>(gen->GetArgAddress(0));
*(bool*)gen->GetAddressOfReturnLocation() = (*a == *b);
}
static void StringNotEqual_Generic(asIScriptGeneric *gen)
{
string *a = (string*)gen->GetArgAddress(0);
string *b = (string*)gen->GetArgAddress(1);
bool r = *a != *b;
*(bool*)gen->GetAddressOfReturnLocation() = r;
}
static void StringLesserOrEqual_Generic(asIScriptGeneric *gen)
{
string *a = (string*)gen->GetArgAddress(0);
string *b = (string*)gen->GetArgAddress(1);
bool r = *a <= *b;
*(bool*)gen->GetAddressOfReturnLocation() = r;
}
static void StringGreaterOrEqual_Generic(asIScriptGeneric *gen)
{
string *a = (string*)gen->GetArgAddress(0);
string *b = (string*)gen->GetArgAddress(1);
bool r = *a >= *b;
*(bool*)gen->GetAddressOfReturnLocation() = r;
}
static void StringLesser_Generic(asIScriptGeneric *gen)
{
string *a = (string*)gen->GetArgAddress(0);
string *b = (string*)gen->GetArgAddress(1);
bool r = *a < *b;
*(bool*)gen->GetAddressOfReturnLocation() = r;
}
static void StringGreater_Generic(asIScriptGeneric *gen)
{
string *a = (string*)gen->GetArgAddress(0);
string *b = (string*)gen->GetArgAddress(1);
bool r = *a > *b;
*(bool*)gen->GetAddressOfReturnLocation() = r;
}
static void StringLength_Generic(asIScriptGeneric *gen)
{
string *s = (string*)gen->GetObject();
size_t l = s->size();
if( sizeof(size_t) == 4 )
gen->SetReturnDWord((asUINT)l);
else
gen->SetReturnQWord((asQWORD)l);
}
static void StringResize_Generic(asIScriptGeneric *gen)
{
string *s = (string*)gen->GetObject();
size_t v = *(size_t*)gen->GetAddressOfArg(0);
s->resize(v);
}
// This is where we register the string type
void RegisterScriptString_Native(asIScriptEngine *engine)
{
int r;
// Register the type
r = engine->RegisterObjectType("string", 0, asOBJ_REF); assert( r >= 0 );
// Register the object operator overloads
// Note: We don't have to register the destructor, since the object uses reference counting
r = engine->RegisterObjectBehaviour("string", asBEHAVE_FACTORY, "string @f()", asFUNCTION(StringDefaultFactory), asCALL_CDECL); assert( r >= 0 );
r = engine->RegisterObjectBehaviour("string", asBEHAVE_FACTORY, "string @f(const string &in)", asFUNCTION(StringCopyFactory), asCALL_CDECL); assert( r >= 0 );
r = engine->RegisterObjectBehaviour("string", asBEHAVE_ADDREF, "void f()", asMETHOD(CScriptString,AddRef), asCALL_THISCALL); assert( r >= 0 );
r = engine->RegisterObjectBehaviour("string", asBEHAVE_RELEASE, "void f()", asMETHOD(CScriptString,Release), asCALL_THISCALL); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAssign(const string &in)", asMETHODPR(CScriptString, operator =, (const CScriptString&), CScriptString&), asCALL_THISCALL); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAddAssign(const string &in)", asMETHODPR(CScriptString, operator+=, (const CScriptString&), CScriptString&), asCALL_THISCALL); assert( r >= 0 );
// Register the factory to return a handle to a new string
// Note: We must register the string factory after the basic behaviours,
// otherwise the library will not allow the use of object handles for this type
r = engine->RegisterStringFactory("string@", asFUNCTION(StringFactory), asCALL_CDECL); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "bool opEquals(const string &in) const", asFUNCTIONPR(operator ==, (const string &, const string &), bool), asCALL_CDECL_OBJFIRST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "int opCmp(const string &in) const", asFUNCTION(StringCmp), asCALL_CDECL_OBJFIRST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd(const string &in) const", asFUNCTIONPR(operator +, (const CScriptString &, const CScriptString &), CScriptString*), asCALL_CDECL_OBJFIRST); assert( r >= 0 );
// Register the index operator, both as a mutator and as an inspector
r = engine->RegisterObjectBehaviour("string", asBEHAVE_INDEX, "uint8 &f(uint)", asFUNCTION(StringCharAt), asCALL_CDECL_OBJLAST); assert( r >= 0 );
r = engine->RegisterObjectBehaviour("string", asBEHAVE_INDEX, "const uint8 &f(uint) const", asFUNCTION(StringCharAt), asCALL_CDECL_OBJLAST); assert( r >= 0 );
// Register the object methods
if( sizeof(size_t) == 4 )
{
r = engine->RegisterObjectMethod("string", "uint length() const", asMETHOD(string,size), asCALL_THISCALL); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "void resize(uint)", asMETHODPR(string,resize,(size_t),void), asCALL_THISCALL); assert( r >= 0 );
}
else
{
r = engine->RegisterObjectMethod("string", "uint64 length() const", asMETHOD(string,size), asCALL_THISCALL); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "void resize(uint64)", asMETHODPR(string,resize,(size_t),void), asCALL_THISCALL); assert( r >= 0 );
}
// TODO: Add factory string(const string &in str, int repeatCount)
// TODO: Add explicit type conversion via constructor and value cast
// TODO: Add parseInt and parseDouble. Two versions, one without parameter, one with an outparm that returns the number of characters parsed.
// Automatic conversion from values
r = engine->RegisterObjectMethod("string", "string &opAssign(double)", asFUNCTION(AssignDoubleToString), asCALL_CDECL_OBJLAST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAddAssign(double)", asFUNCTION(AddAssignDoubleToString), asCALL_CDECL_OBJLAST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd(double) const", asFUNCTION(AddStringDouble), asCALL_CDECL_OBJFIRST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd_r(double) const", asFUNCTION(AddDoubleString), asCALL_CDECL_OBJLAST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAssign(float)", asFUNCTION(AssignFloatToString), asCALL_CDECL_OBJLAST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAddAssign(float)", asFUNCTION(AddAssignFloatToString), asCALL_CDECL_OBJLAST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd(float) const", asFUNCTION(AddStringFloat), asCALL_CDECL_OBJFIRST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd_r(float) const", asFUNCTION(AddFloatString), asCALL_CDECL_OBJLAST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAssign(int)", asFUNCTION(AssignIntToString), asCALL_CDECL_OBJLAST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAddAssign(int)", asFUNCTION(AddAssignIntToString), asCALL_CDECL_OBJLAST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd(int) const", asFUNCTION(AddStringInt), asCALL_CDECL_OBJFIRST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd_r(int) const", asFUNCTION(AddIntString), asCALL_CDECL_OBJLAST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAssign(uint)", asFUNCTION(AssignUIntToString), asCALL_CDECL_OBJLAST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAddAssign(uint)", asFUNCTION(AddAssignUIntToString), asCALL_CDECL_OBJLAST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd(uint) const", asFUNCTION(AddStringUInt), asCALL_CDECL_OBJFIRST); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd_r(uint) const", asFUNCTION(AddUIntString), asCALL_CDECL_OBJLAST); assert( r >= 0 );
}
void RegisterScriptString_Generic(asIScriptEngine *engine)
{
int r;
// Register the type
r = engine->RegisterObjectType("string", 0, asOBJ_REF); assert( r >= 0 );
// Register the object operator overloads
// Note: We don't have to register the destructor, since the object uses reference counting
r = engine->RegisterObjectBehaviour("string", asBEHAVE_FACTORY, "string @f()", asFUNCTION(StringDefaultFactory_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectBehaviour("string", asBEHAVE_FACTORY, "string @f(const string &in)", asFUNCTION(StringCopyFactory_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectBehaviour("string", asBEHAVE_ADDREF, "void f()", asFUNCTION(StringAddRef_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectBehaviour("string", asBEHAVE_RELEASE, "void f()", asFUNCTION(StringRelease_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAssign(const string &in)", asFUNCTION(AssignString_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAddAssign(const string &in)", asFUNCTION(AddAssignString_Generic), asCALL_GENERIC); assert( r >= 0 );
// Register the factory to return a handle to a new string
// Note: We must register the string factory after the basic behaviours,
// otherwise the library will not allow the use of object handles for this type
r = engine->RegisterStringFactory("string@", asFUNCTION(StringFactory_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "bool opEquals(const string &in) const", asFUNCTION(StringEquals_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "int opCmp(const string &in) const", asFUNCTION(StringCmp_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd(const string &in) const", asFUNCTION(ConcatenateStrings_Generic), asCALL_GENERIC); assert( r >= 0 );
// Register the index operator, both as a mutator and as an inspector
r = engine->RegisterObjectBehaviour("string", asBEHAVE_INDEX, "uint8 &f(uint)", asFUNCTION(StringCharAt_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectBehaviour("string", asBEHAVE_INDEX, "const uint8 &f(uint) const", asFUNCTION(StringCharAt_Generic), asCALL_GENERIC); assert( r >= 0 );
// Register the object methods
if( sizeof(size_t) == 4 )
{
r = engine->RegisterObjectMethod("string", "uint length() const", asFUNCTION(StringLength_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "void resize(uint)", asFUNCTION(StringResize_Generic), asCALL_GENERIC); assert( r >= 0 );
}
else
{
r = engine->RegisterObjectMethod("string", "uint64 length() const", asFUNCTION(StringLength_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "void resize(uint64)", asFUNCTION(StringResize_Generic), asCALL_GENERIC); assert( r >= 0 );
}
// Automatic conversion from values
r = engine->RegisterObjectMethod("string", "string &opAssign(double)", asFUNCTION(AssignDoubleToString_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAddAssign(double)", asFUNCTION(AddAssignDoubleToString_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd(double) const", asFUNCTION(AddStringDouble_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd_r(double) const", asFUNCTION(AddDoubleString_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAssign(float)", asFUNCTION(AssignFloatToString_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAddAssign(float)", asFUNCTION(AddAssignFloatToString_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd(float) const", asFUNCTION(AddStringFloat_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd_r(float) const", asFUNCTION(AddFloatString_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAssign(int)", asFUNCTION(AssignIntToString_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAddAssign(int)", asFUNCTION(AddAssignIntToString_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd(int) const", asFUNCTION(AddStringInt_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd_r(int) const", asFUNCTION(AddIntString_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAssign(uint)", asFUNCTION(AssignUIntToString_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string &opAddAssign(uint)", asFUNCTION(AddAssignUIntToString_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd(uint) const", asFUNCTION(AddStringUInt_Generic), asCALL_GENERIC); assert( r >= 0 );
r = engine->RegisterObjectMethod("string", "string@ opAdd_r(uint) const", asFUNCTION(AddUIntString_Generic), asCALL_GENERIC); assert( r >= 0 );
}
void RegisterScriptString(asIScriptEngine *engine)
{
if( strstr(asGetLibraryOptions(), "AS_MAX_PORTABILITY") )
RegisterScriptString_Generic(engine);
else
RegisterScriptString_Native(engine);
}
END_AS_NAMESPACE