The API definition for AngelScript. More...
Classes | |
struct | asSFuncPtr |
Represents a function or method pointer. More... | |
struct | asSMessageInfo |
Represents a compiler message. More... | |
class | asIScriptEngine |
The engine interface. More... | |
class | asIStringFactory |
The interface for the string factory. More... | |
class | asIThreadManager |
The interface for the thread manager. More... | |
class | asIScriptModule |
The interface to the script modules. More... | |
class | asIScriptContext |
The interface to the virtual machine. More... | |
class | asIScriptGeneric |
The interface for the generic calling convention. More... | |
class | asIScriptObject |
The interface for an instance of a script object. More... | |
class | asITypeInfo |
The interface for describing types This interface is used to describe the types in the script engine. More... | |
class | asIScriptFunction |
The interface for a script function description. More... | |
class | asIBinaryStream |
A binary stream interface. More... | |
class | asILockableSharedBool |
A lockable shared boolean. More... | |
struct | asSVMRegisters |
A struct with registers from the VM sent to a JIT compiled function. More... | |
class | asIJITCompiler |
The interface that AS use to interact with the JIT compiler. More... | |
struct | asSBCInfo |
Information on a bytecode instruction. More... | |
Macros | |
#define | ANGELSCRIPT_VERSION 23400 |
Version 2.34.0. | |
#define | AS_CAN_USE_CPP11 1 |
This macro is defined if the compiler supports the C++11 feature set. | |
#define | asOFFSET(s, m) ((int)(size_t)(&reinterpret_cast<s*>(100000)->m)-100000) |
Returns the offset of an attribute in a struct. | |
#define | asFUNCTION(f) asFunctionPtr(f) |
Returns an asSFuncPtr representing the function specified by the name. | |
#define | asFUNCTIONPR(f, p, r) asFunctionPtr(reinterpret_cast<void (*)()>(static_cast<r (*)p>(f))) |
Returns an asSFuncPtr representing the function specified by the name, parameter list, and return type. | |
#define | asMETHOD(c, m) asSMethodPtr<sizeof(void (c::*)())>::Convert((void (c::*)())(&c::m)) |
Returns an asSFuncPtr representing the class method specified by class and method name. | |
#define | asMETHODPR(c, m, p, r) asSMethodPtr<sizeof(void (c::*)())>::Convert(AS_METHOD_AMBIGUITY_CAST(r (c::*)p)(&c::m)) |
Returns an asSFuncPtr representing the class method specified by class, method name, parameter list, return type. | |
#define | AS_API |
A define that specifies how the function should be imported. | |
#define | asBC_DWORDARG(x) (*(((asDWORD*)x)+1)) |
Macro to access the first DWORD argument in the bytecode instruction. | |
#define | asBC_INTARG(x) (*(int*)(((asDWORD*)x)+1)) |
Macro to access the first 32bit integer argument in the bytecode instruction. | |
#define | asBC_QWORDARG(x) (*(asQWORD*)(((asDWORD*)x)+1)) |
Macro to access the first QWORD argument in the bytecode instruction. | |
#define | asBC_FLOATARG(x) (*(float*)(((asDWORD*)x)+1)) |
Macro to access the first float argument in the bytecode instruction. | |
#define | asBC_PTRARG(x) (*(asPWORD*)(((asDWORD*)x)+1)) |
Macro to access the first pointer argument in the bytecode instruction. | |
#define | asBC_WORDARG0(x) (*(((asWORD*)x)+1)) |
Macro to access the first WORD argument in the bytecode instruction. | |
#define | asBC_WORDARG1(x) (*(((asWORD*)x)+2)) |
Macro to access the second WORD argument in the bytecode instruction. | |
#define | asBC_SWORDARG0(x) (*(((short*)x)+1)) |
Macro to access the first signed WORD argument in the bytecode instruction. | |
#define | asBC_SWORDARG1(x) (*(((short*)x)+2)) |
Macro to access the second signed WORD argument in the bytecode instruction. | |
#define | asBC_SWORDARG2(x) (*(((short*)x)+3)) |
Macro to access the third signed WORD argument in the bytecode instruction. | |
Typedefs | |
typedef signed char | asINT8 |
8 bit signed integer | |
typedef signed short | asINT16 |
16 bit signed integer | |
typedef unsigned char | asBYTE |
8 bit unsigned integer | |
typedef unsigned short | asWORD |
16 bit unsigned integer | |
typedef unsigned int | asUINT |
32 bit unsigned integer | |
typedef uintptr_t | asPWORD |
Unsigned integer with the size of a pointer. | |
typedef unsigned long | asDWORD |
32 bit unsigned integer | |
typedef unsigned __int64 | asQWORD |
64 bit unsigned integer | |
typedef __int64 | asINT64 |
64 bit integer | |
typedef void *(* | asALLOCFUNC_t) (size_t) |
The function signature for the custom memory allocation function. | |
typedef void(* | asFREEFUNC_t) (void *) |
The function signature for the custom memory deallocation function. | |
typedef void(* | asCLEANENGINEFUNC_t) (asIScriptEngine *) |
The function signature for the engine cleanup callback function. | |
typedef void(* | asCLEANMODULEFUNC_t) (asIScriptModule *) |
The function signature for the module cleanup callback function. | |
typedef void(* | asCLEANCONTEXTFUNC_t) (asIScriptContext *) |
The function signature for the context cleanup callback function. | |
typedef void(* | asCLEANFUNCTIONFUNC_t) (asIScriptFunction *) |
The function signature for the function cleanup callback function. | |
typedef void(* | asCLEANTYPEINFOFUNC_t) (asITypeInfo *) |
The function signature for the type info cleanup callback function. | |
typedef void(* | asCLEANSCRIPTOBJECTFUNC_t) (asIScriptObject *) |
The function signature for the script object cleanup callback function. | |
typedef asIScriptContext *(* | asREQUESTCONTEXTFUNC_t) (asIScriptEngine *, void *) |
The function signature for the request context callback. | |
typedef void(* | asRETURNCONTEXTFUNC_t) (asIScriptEngine *, asIScriptContext *, void *) |
The function signature for the return context callback. | |
typedef void(* | asCIRCULARREFFUNC_t) (asITypeInfo *, const void *, void *) |
The function signature for the callback used when detecting a circular reference in garbage. | |
typedef void(* | asJITFunction) (asSVMRegisters *registers, asPWORD jitArg) |
The function signature of a JIT compiled function. More... | |
Functions | |
AS_API asIScriptEngine * | asCreateScriptEngine (asDWORD version=ANGELSCRIPT_VERSION) |
Creates the script engine. More... | |
const AS_API char * | asGetLibraryVersion () |
Returns the version of the compiled library. More... | |
const AS_API char * | asGetLibraryOptions () |
Returns the options used to compile the library. More... | |
AS_API asIScriptContext * | asGetActiveContext () |
Returns the currently active context. More... | |
AS_API int | asPrepareMultithread (asIThreadManager *externalMgr=0) |
Sets up the internally shared resources for multithreading. More... | |
AS_API void | asUnprepareMultithread () |
Frees resources prepared for multithreading. More... | |
AS_API asIThreadManager * | asGetThreadManager () |
Get the thread manager used by the application. More... | |
AS_API void | asAcquireExclusiveLock () |
Acquire an exclusive lock. More... | |
AS_API void | asReleaseExclusiveLock () |
Release an exclusive lock. More... | |
AS_API void | asAcquireSharedLock () |
Acquire a shared lock. More... | |
AS_API void | asReleaseSharedLock () |
Release a shared lock. More... | |
AS_API int | asAtomicInc (int &value) |
Increments the value by one and returns the result as a single atomic instruction. More... | |
AS_API int | asAtomicDec (int &value) |
Decrements the value by one and returns the result as a single atomic instruction. More... | |
AS_API int | asThreadCleanup () |
Cleans up memory allocated for the current thread. More... | |
AS_API int | asSetGlobalMemoryFunctions (asALLOCFUNC_t allocFunc, asFREEFUNC_t freeFunc) |
Set the memory management functions that AngelScript should use. More... | |
AS_API int | asResetGlobalMemoryFunctions () |
Remove previously registered memory management functions. More... | |
AS_API void * | asAllocMem (size_t size) |
Allocate memory using the memory function registered with AngelScript. More... | |
AS_API void | asFreeMem (void *mem) |
Deallocates memory using the memory function registered with AngelScript. More... | |
AS_API asILockableSharedBool * | asCreateLockableSharedBool () |
Create a lockable shared boolean. More... | |
template<typename T > | |
asUINT | asGetTypeTraits () |
Returns the appropriate flags for use with RegisterObjectType. More... | |
Variables | |
const int | asBCTypeSize [21] |
Lookup table for determining the size of each type of bytecode instruction. | |
const asSBCInfo | asBCInfo [256] |
Information on each bytecode instruction. | |
This header file describes the complete application programming interface for AngelScript.
typedef void(* asJITFunction) (asSVMRegisters *registers, asPWORD jitArg) |
[in] | registers | A pointer to the virtual machine's registers. |
[in] | jitArg | The value defined by the JIT compiler for the current entry point in the JIT function. |
A JIT function receives a pointer to the virtual machine's registers when called and an argument telling it where in the script function to continue the execution. The JIT function must make sure to update the VM's registers according to the actions performed before returning control to the VM.
enum asEBCInstr |
Enumerator | |
---|---|
asBC_PopPtr | Removes a pointer from the stack. |
asBC_PshGPtr | Pushes a pointer from a global variable onto the stack. |
asBC_PshC4 | Push the 32bit value in the argument onto the stack. |
asBC_PshV4 | Push the 32bit value from a variable onto the stack. |
asBC_PSF | Push the address of the stack frame onto the stack. |
asBC_SwapPtr | Swap the top two pointers on the stack. |
asBC_NOT | Perform a boolean not on the value in a variable. |
asBC_PshG4 | Push the 32bit value from a global variable onto the stack. |
asBC_LdGRdR4 | |
asBC_CALL | Jump to a script function, indexed by the argument. |
asBC_RET | Return to the instruction after the last executed call. |
asBC_JMP | Unconditional jump to a relative position in this function. |
asBC_JZ | If the value register is 0 jump to a relative position in this function. |
asBC_JNZ | If the value register is not 0 jump to a relative position in this function. |
asBC_JS | If the value register is less than 0 jump to a relative position in this function. |
asBC_JNS | If the value register is greater than or equal to 0 jump to a relative position in this function. |
asBC_JP | If the value register is greater than 0 jump to a relative position in this function. |
asBC_JNP | If the value register is less than or equal to 0 jump to a relative position in this function. |
asBC_TZ | If the value register is 0 set it to 1. |
asBC_TNZ | If the value register is not 0 set it to 1. |
asBC_TS | If the value register is less than 0 set it to 1. |
asBC_TNS | If the value register is greater than or equal to 0 set it to 1. |
asBC_TP | If the value register is greater than 0 set it to 1. |
asBC_TNP | If the value register is less than or equal to 0 set it to 1. |
asBC_NEGi | Negate the 32bit integer value in the variable. |
asBC_NEGf | Negate the float value in the variable. |
asBC_NEGd | Negate the double value in the variable. |
asBC_INCi16 | Increment the 16bit integer value that is stored at the address pointed to by the reference in the value register. |
asBC_INCi8 | Increment the 8bit integer value that is stored at the address pointed to by the reference in the value register. |
asBC_DECi16 | Decrement the 16bit integer value that is stored at the address pointed to by the reference in the value register. |
asBC_DECi8 | Increment the 8bit integer value that is stored at the address pointed to by the reference in the value register. |
asBC_INCi | Increment the 32bit integer value that is stored at the address pointed to by the reference in the value register. |
asBC_DECi | Decrement the 32bit integer value that is stored at the address pointed to by the reference in the value register. |
asBC_INCf | Increment the float value that is stored at the address pointed to by the reference in the value register. |
asBC_DECf | Decrement the float value that is stored at the address pointed to by the reference in the value register. |
asBC_INCd | Increment the double value that is stored at the address pointed to by the reference in the value register. |
asBC_DECd | Decrement the double value that is stored at the address pointed to by the reference in the value register. |
asBC_IncVi | Increment the 32bit integer value in the variable. |
asBC_DecVi | Decrement the 32bit integer value in the variable. |
asBC_BNOT | Perform a bitwise complement on the 32bit value in the variable. |
asBC_BAND | Perform a bitwise and of two 32bit values and store the result in a third variable. |
asBC_BOR | Perform a bitwise or of two 32bit values and store the result in a third variable. |
asBC_BXOR | Perform a bitwise exclusive or of two 32bit values and store the result in a third variable. |
asBC_BSLL | Perform a logical left shift of a 32bit value and store the result in a third variable. |
asBC_BSRL | Perform a logical right shift of a 32bit value and store the result in a third variable. |
asBC_BSRA | Perform a arithmetical right shift of a 32bit value and store the result in a third variable. |
asBC_COPY | Pop the destination and source addresses from the stack. Perform a bitwise copy of the referred object. Push the destination address on the stack. |
asBC_PshC8 | Push a 64bit value on the stack. |
asBC_PshVPtr | Push a pointer from the variable on the stack. |
asBC_RDSPtr | Pop top address, read a pointer from it, and push the pointer onto the stack. |
asBC_CMPd | Compare two double variables and store the result in the value register. |
asBC_CMPu | Compare two unsigned 32bit integer variables and store the result in the value register. |
asBC_CMPf | Compare two float variables and store the result in the value register. |
asBC_CMPi | Compare two 32bit integer variables and store the result in the value register. |
asBC_CMPIi | Compare 32bit integer variable with constant and store the result in value register. |
asBC_CMPIf | Compare float variable with constant and store the result in value register. |
asBC_CMPIu | Compare unsigned 32bit integer variable with constant and store the result in value register. |
asBC_JMPP | Jump to relative position in the function where the offset is stored in a variable. |
asBC_PopRPtr | Pop a pointer from the stack and store it in the value register. |
asBC_PshRPtr | Push a pointer from the value register onto the stack. |
asBC_STR | Not used. |
asBC_CALLSYS | Call registered function. Suspend further execution if requested. |
asBC_CALLBND | Jump to an imported script function, indexed by the argument. |
asBC_SUSPEND | Call line callback function if set. Suspend execution if requested. |
asBC_ALLOC | Allocate the memory for the object. If the type is a script object then jump to the constructor, else call the registered constructor behaviour. Suspend further execution if requested. |
asBC_FREE | Pop the address of the object variable from the stack. If ref type, call the release method, else call the destructor then free the memory. Clear the pointer in the variable. |
asBC_LOADOBJ | Copy the object pointer from a variable to the object register. Clear the variable. |
asBC_STOREOBJ | Copy the object pointer from the object register to the variable. Clear the object register. |
asBC_GETOBJ | Move object pointer from variable onto stack location. |
asBC_REFCPY | Pop destination handle reference. Perform a handle assignment, while updating the reference count for both previous and new objects. |
asBC_CHKREF | Throw an exception if the pointer on the top of the stack is null. |
asBC_GETOBJREF | Replace a variable index on the stack with the object handle stored in that variable. |
asBC_GETREF | Replace a variable index on the stack with the address of the variable. |
asBC_PshNull | Push a null pointer on the stack. |
asBC_ClrVPtr | Clear pointer in a variable. |
asBC_OBJTYPE | Push the pointer argument onto the stack. The pointer is a pointer to an object type structure. |
asBC_TYPEID | Push the type id onto the stack. Equivalent to PshC4. |
asBC_SetV4 | Initialize the variable with a DWORD. |
asBC_SetV8 | Initialize the variable with a QWORD. |
asBC_ADDSi | Add a value to the top pointer on the stack, thus updating the address itself. |
asBC_CpyVtoV4 | Copy a DWORD from one variable to another. |
asBC_CpyVtoV8 | Copy a QWORD from one variable to another. |
asBC_CpyVtoR4 | Copy a DWORD from a variable into the value register. |
asBC_CpyVtoR8 | Copy a QWORD from a variable into the value register. |
asBC_CpyVtoG4 | Copy a DWORD from a local variable to a global variable. |
asBC_CpyRtoV4 | Copy a DWORD from the value register into a variable. |
asBC_CpyRtoV8 | Copy a QWORD from the value register into a variable. |
asBC_CpyGtoV4 | Copy a DWORD from a global variable to a local variable. |
asBC_WRTV1 | Copy a BYTE from a variable to the address held in the value register. |
asBC_WRTV2 | Copy a WORD from a variable to the address held in the value register. |
asBC_WRTV4 | Copy a DWORD from a variable to the address held in the value register. |
asBC_WRTV8 | Copy a QWORD from a variable to the address held in the value register. |
asBC_RDR1 | Copy a BYTE from address held in the value register to a variable. Clear the top bytes in the variable. |
asBC_RDR2 | Copy a WORD from address held in the value register to a variable. Clear the top word in the variable. |
asBC_RDR4 | Copy a DWORD from address held in the value register to a variable. |
asBC_RDR8 | Copy a QWORD from address held in the value register to a variable. |
asBC_LDG | Load the address of a global variable into the value register. |
asBC_LDV | Load the address of a local variable into the value register. |
asBC_PGA | Push the address of a global variable on the stack. |
asBC_CmpPtr | Compare two pointers. |
asBC_VAR | Push the index of the variable on the stack, with the size of a pointer. |
asBC_iTOf | Convert the 32bit integer value to a float in the variable. |
asBC_fTOi | Convert the float value to a 32bit integer in the variable. |
asBC_uTOf | Convert the unsigned 32bit integer value to a float in the variable. |
asBC_fTOu | Convert the float value to an unsigned 32bit integer in the variable. |
asBC_sbTOi | Expand the low byte as a signed value to a full 32bit integer in the variable. |
asBC_swTOi | Expand the low word as a signed value to a full 32bit integer in the variable. |
asBC_ubTOi | Expand the low byte as an unsigned value to a full 32bit integer in the variable. |
asBC_uwTOi | Expand the low word as an unsigned value to a full 32bit integer in the variable. |
asBC_dTOi | Convert the double value in one variable to a 32bit integer in another variable. |
asBC_dTOu | Convert the double value in one variable to a 32bit unsigned integer in another variable. |
asBC_dTOf | Convert the double value in one variable to a float in another variable. |
asBC_iTOd | Convert the 32bit integer value in one variable to a double in another variable. |
asBC_uTOd | Convert the 32bit unsigned integer value in one variable to a double in another variable. |
asBC_fTOd | Convert the float value in one variable to a double in another variable. |
asBC_ADDi | Add the values of two 32bit integer variables and store in a third variable. |
asBC_SUBi | Subtract the values of two 32bit integer variables and store in a third variable. |
asBC_MULi | Multiply the values of two 32bit integer variables and store in a third variable. |
asBC_DIVi | Divide the values of two 32bit integer variables and store in a third variable. |
asBC_MODi | Calculate the modulo of values of two 32bit integer variables and store in a third variable. |
asBC_ADDf | Add the values of two float variables and store in a third variable. |
asBC_SUBf | Subtract the values of two float variables and store in a third variable. |
asBC_MULf | Multiply the values of two float variables and store in a third variable. |
asBC_DIVf | Divide the values of two float variables and store in a third variable. |
asBC_MODf | Calculate the modulo of values of two float variables and store in a third variable. |
asBC_ADDd | Add the values of two double variables and store in a third variable. |
asBC_SUBd | Subtract the values of two double variables and store in a third variable. |
asBC_MULd | Multiply the values of two double variables and store in a third variable. |
asBC_DIVd | Divide the values of two double variables and store in a third variable. |
asBC_MODd | Calculate the modulo of values of two double variables and store in a third variable. |
asBC_ADDIi | Add a 32bit integer variable with a constant value and store the result in another variable. |
asBC_SUBIi | Subtract a 32bit integer variable with a constant value and store the result in another variable. |
asBC_MULIi | Multiply a 32bit integer variable with a constant value and store the result in another variable. |
asBC_ADDIf | Add a float variable with a constant value and store the result in another variable. |
asBC_SUBIf | Subtract a float variable with a constant value and store the result in another variable. |
asBC_MULIf | Multiply a float variable with a constant value and store the result in another variable. |
asBC_SetG4 | Set the value of global variable to a 32bit word. |
asBC_ChkRefS | Throw an exception if the address stored on the stack points to a null pointer. |
asBC_ChkNullV | Throw an exception if the variable is null. |
asBC_CALLINTF | Jump to an interface method, indexed by the argument. |
asBC_iTOb | Convert a 32bit integer in a variable to a byte, clearing the top bytes. |
asBC_iTOw | Convert a 32bit integer in a variable to a word, clearing the top word. |
asBC_SetV1 | Same as SetV4. |
asBC_SetV2 | Same as SetV4. |
asBC_Cast | Pop an object handle to a script class from the stack. Perform a dynamic cast on it and store the result in the object register. |
asBC_i64TOi | Convert the 64bit integer value in one variable to a 32bit integer in another variable. |
asBC_uTOi64 | Convert the 32bit unsigned integer value in one variable to a 64bit integer in another variable. |
asBC_iTOi64 | Convert the 32bit integer value in one variable to a 64bit integer in another variable. |
asBC_fTOi64 | Convert the float value in one variable to a 64bit integer in another variable. |
asBC_dTOi64 | Convert the double value in the variable to a 64bit integer. |
asBC_fTOu64 | Convert the float value in one variable to a 64bit unsigned integer in another variable. |
asBC_dTOu64 | Convert the double value in the variable to a 64bit unsigned integer. |
asBC_i64TOf | Convert the 64bit integer value in one variable to a float in another variable. |
asBC_u64TOf | Convert the 64bit unsigned integer value in one variable to a float in another variable. |
asBC_i64TOd | Convert the 32bit integer value in the variable to a double. |
asBC_u64TOd | Convert the 32bit unsigned integer value in the variable to a double. |
asBC_NEGi64 | Negate the 64bit integer value in the variable. |
asBC_INCi64 | Increment the 64bit integer value that is stored at the address pointed to by the reference in the value register. |
asBC_DECi64 | Decrement the 64bit integer value that is stored at the address pointed to by the reference in the value register. |
asBC_BNOT64 | Perform a bitwise complement on the 64bit value in the variable. |
asBC_ADDi64 | Perform an addition with two 64bit integer variables and store the result in a third variable. |
asBC_SUBi64 | Perform a subtraction with two 64bit integer variables and store the result in a third variable. |
asBC_MULi64 | Perform a multiplication with two 64bit integer variables and store the result in a third variable. |
asBC_DIVi64 | Perform a division with two 64bit integer variables and store the result in a third variable. |
asBC_MODi64 | Perform the modulo operation with two 64bit integer variables and store the result in a third variable. |
asBC_BAND64 | Perform a bitwise and of two 64bit values and store the result in a third variable. |
asBC_BOR64 | Perform a bitwise or of two 64bit values and store the result in a third variable. |
asBC_BXOR64 | Perform a bitwise exclusive or of two 64bit values and store the result in a third variable. |
asBC_BSLL64 | Perform a logical left shift of a 64bit value and store the result in a third variable. |
asBC_BSRL64 | Perform a logical right shift of a 64bit value and store the result in a third variable. |
asBC_BSRA64 | Perform a arithmetical right shift of a 64bit value and store the result in a third variable. |
asBC_CMPi64 | Compare two 64bit integer variables and store the result in the value register. |
asBC_CMPu64 | Compare two unsigned 64bit integer variables and store the result in the value register. |
asBC_ChkNullS | Check if a pointer on the stack is null, and if it is throw an exception. The argument is relative to the top of the stack. |
asBC_ClrHi | Clear the upper bytes of the value register so that only the value in the lowest byte is kept. |
asBC_JitEntry | If a JIT function is available and the argument is not 0 then call the JIT function. |
asBC_CallPtr | Call a function stored in a local function pointer. |
asBC_FuncPtr | Push a function pointer on the stack. |
asBC_LoadThisR | Load the address to a property of the local object into the stack. PshV4 0, ADDSi x, PopRPtr. |
asBC_PshV8 | Push the 64bit value from a variable onto the stack. |
asBC_DIVu | Divide the values of two 32bit unsigned integer variables and store in a third variable. |
asBC_MODu | Calculate the modulo of values of two 32bit unsigned integer variables and store in a third variable. |
asBC_DIVu64 | Divide the values of two 64bit unsigned integer variables and store in a third variable. |
asBC_MODu64 | Calculate the modulo of values of two 64bit unsigned integer variables and store in a third variable. |
asBC_LoadRObjR | Load address of member of reference object into register. |
asBC_LoadVObjR | Load address of member of value object into register. |
asBC_RefCpyV | Copies a handle to a variable. |
asBC_JLowZ | Jump if low byte of value register is 0. |
asBC_JLowNZ | Jump if low byte of value register is not 0. |
asBC_AllocMem | Allocates memory for an initialization list buffer. |
asBC_SetListSize | Sets a repeat count in the list buffer. |
asBC_PshListElmnt | Pushes the address of an element in the list buffer on the stack. |
asBC_SetListType | Sets the type of the next element in the list buffer. |
asBC_POWi | Computes the power of for two int values. |
asBC_POWu | Computes the power of for two uint values. |
asBC_POWf | Computes the power of for two float values. |
asBC_POWd | Computes the power of for two double values. |
asBC_POWdi | Computes the power of where base is a double and exponent is an int value. |
asBC_POWi64 | Computes the power of for two int64 values. |
asBC_POWu64 | Computes the power of for two uint64 values. |
asBC_Thiscall1 | Call registered function with single 32bit integer argument. Suspend further execution if requested. |
enum asEBCType |
enum asEBehaviours |
enum asECallConvTypes |
enum asECompileFlags |
enum asEContextState |
enum asEEngineProp |
enum asEFuncType |
enum asEGCFlags |
enum asEGMFlags |
enum asEMsgType |
enum asEObjTypeFlags |
enum asERetCodes |
enum asETokenClass |
enum asETypeIdFlags |
enum asETypeModifiers |
AS_API void asAcquireExclusiveLock | ( | ) |
This function will block the calling thread until there are no other threads that hold shared or exclusive locks.
AS_API void asAcquireSharedLock | ( | ) |
This function will block the calling thread until there are no other threads that hold exclusive locks. Other threads may hold shared locks.
AS_API void* asAllocMem | ( | size_t | size | ) |
[in] | size | The size of the buffer to allocate |
AS_API int asAtomicDec | ( | int & | value | ) |
[in] | value | A reference to the value that should be decremented |
This function is especially useful for implementing thread safe reference counters.
AS_API int asAtomicInc | ( | int & | value | ) |
[in] | value | A reference to the value that should be incremented |
This function is especially useful for implementing thread safe reference counters.
AS_API asILockableSharedBool* asCreateLockableSharedBool | ( | ) |
The lockable shared boolean will be created with an initial reference count of 1, and the boolean value false.
The object can be used for weak reference flags.
AS_API asIScriptEngine* asCreateScriptEngine | ( | asDWORD | version = ANGELSCRIPT_VERSION | ) |
[in] | version | The library version. Should always be ANGELSCRIPT_VERSION. |
Call this function to create a new script engine. When you're done with the script engine, i.e. after you've executed all your scripts, you should call ShutDownAndRelease on the pointer to cleanup any objects that may still be alive and free the engine object.
The version argument is there to allow AngelScript to validate that the application has been compiled with the correct interface. This is especially important when linking dynamically against the library. If the version is incorrect a null pointer is returned.
AS_API void asFreeMem | ( | void * | mem | ) |
[in] | mem | A pointer to the buffer to deallocate |
AS_API asIScriptContext* asGetActiveContext | ( | ) |
This function is most useful for registered functions, as it will allow them to obtain a pointer to the context that is calling the function, and through that get the engine, or custom user data.
If the script library is compiled with multithread support, this function will return the context that is currently active in the thread that is being executed. It will thus work even if there are multiple threads executing scripts at the same time.
This function does not increase the reference count of the context.
const AS_API char* asGetLibraryOptions | ( | ) |
This can be used to identify at run-time different ways to configure the engine. For example, if the returned string contain the identifier AS_MAX_PORTABILITY then functions and methods must be registered with the asCALL_GENERIC calling convention.
const AS_API char* asGetLibraryVersion | ( | ) |
The returned string can be used for presenting the library version in a log file, or in the GUI.
AS_API asIThreadManager* asGetThreadManager | ( | ) |
asUINT asGetTypeTraits | ( | ) |
T | The type for which the flags should be determined |
This template function uses C++11 STL template functions to determine the appropriate flags to use when registering the desired type as a value type with asIScriptEngine::RegisterObjectType.
It is capable to determine all the asOBJ_APP_xxx flags, except for asOBJ_APP_CLASS_ALLINTS, asOBJ_APP_CLASS_ALLFLOATS, and asOBJ_APP_CLASS_ALIGN8. These flags must still be informed manually when needed.
AS_API int asPrepareMultithread | ( | asIThreadManager * | externalMgr = 0 | ) |
[in] | externalMgr | Pre-existent thread manager (optional) |
asINVALID_ARG | externalMgr informed even though local manager already exists |
Call this function from the main thread to set up shared resources for multithreading if engines are to be created in multiple threads.
If multiple modules (dlls) are used it may be necessary to call this with the thread manager retrieved from asGetThreadManager() in the main module in order for all modules to share the same thread manager.
AS_API void asReleaseExclusiveLock | ( | ) |
Releases the previously acquired exclusive lock.
AS_API void asReleaseSharedLock | ( | ) |
Releases the previously acquired shared lock.
AS_API int asResetGlobalMemoryFunctions | ( | ) |
Call this method to restore the default memory management functions.
AS_API int asSetGlobalMemoryFunctions | ( | asALLOCFUNC_t | allocFunc, |
asFREEFUNC_t | freeFunc | ||
) |
[in] | allocFunc | The function that will be used to allocate memory. |
[in] | freeFunc | The function that will be used to free the memory. |
Call this method to register the global memory allocation and deallocation functions that AngelScript should use for memory management. This function Should be called before asCreateScriptEngine.
If not called, AngelScript will use the malloc and free functions from the standard C library.
AS_API int asThreadCleanup | ( | ) |
asCONTEXT_ACTIVE | A context is still active. |
Call this function before terminating a thread that has accessed the engine to clean up memory allocated for that thread.
It's not necessary to call this if only a single thread accesses the engine.
AS_API void asUnprepareMultithread | ( | ) |
If asPrepareMultithread() has been called, then this function should be called after the last engine has been released to free the resources prepared for multithreading.