2021-11-19 16:10:07 +00:00
|
|
|
// This file is part of the Luau programming language and is licensed under MIT License; see LICENSE.txt for details
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stddef.h>
|
|
|
|
|
2024-12-13 21:02:30 +00:00
|
|
|
// can be used to reconfigure visibility/exports for public APIs
|
2021-11-19 16:10:07 +00:00
|
|
|
#ifndef LUACODE_API
|
|
|
|
#define LUACODE_API extern
|
|
|
|
#endif
|
|
|
|
|
|
|
|
typedef struct lua_CompileOptions lua_CompileOptions;
|
2024-12-13 21:02:30 +00:00
|
|
|
typedef void* lua_CompileConstant;
|
|
|
|
|
|
|
|
// return a type identifier for a global library member
|
|
|
|
// values are defined by 'enum LuauBytecodeType' in Bytecode.h
|
|
|
|
typedef int (*lua_LibraryMemberTypeCallback)(const char* library, const char* member);
|
|
|
|
|
|
|
|
// setup a value of a constant for a global library member
|
|
|
|
// use luau_set_compile_constant_*** set of functions for values
|
|
|
|
typedef void (*lua_LibraryMemberConstantCallback)(const char* library, const char* member, lua_CompileConstant* constant);
|
2021-11-19 16:10:07 +00:00
|
|
|
|
|
|
|
struct lua_CompileOptions
|
|
|
|
{
|
|
|
|
// 0 - no optimization
|
|
|
|
// 1 - baseline optimization level that doesn't prevent debuggability
|
|
|
|
// 2 - includes optimizations that harm debuggability such as inlining
|
|
|
|
int optimizationLevel; // default=1
|
|
|
|
|
|
|
|
// 0 - no debugging support
|
|
|
|
// 1 - line info & function names only; sufficient for backtraces
|
|
|
|
// 2 - full debug info with local & upvalue names; necessary for debugger
|
|
|
|
int debugLevel; // default=1
|
|
|
|
|
2024-04-25 23:26:09 +01:00
|
|
|
// type information is used to guide native code generation decisions
|
|
|
|
// information includes testable types for function arguments, locals, upvalues and some temporaries
|
|
|
|
// 0 - generate for native modules
|
|
|
|
// 1 - generate for all modules
|
|
|
|
int typeInfoLevel; // default=0
|
|
|
|
|
2021-11-19 16:10:07 +00:00
|
|
|
// 0 - no code coverage support
|
|
|
|
// 1 - statement coverage
|
|
|
|
// 2 - statement and expression coverage (verbose)
|
|
|
|
int coverageLevel; // default=0
|
|
|
|
|
2024-11-01 19:06:07 +00:00
|
|
|
// alternative global builtin to construct vectors, in addition to default builtin 'vector.create'
|
2021-11-19 16:10:07 +00:00
|
|
|
const char* vectorLib;
|
|
|
|
const char* vectorCtor;
|
|
|
|
|
2024-11-01 19:06:07 +00:00
|
|
|
// alternative vector type name for type tables, in addition to default type 'vector'
|
2023-07-14 19:08:53 +01:00
|
|
|
const char* vectorType;
|
|
|
|
|
2021-11-19 16:10:07 +00:00
|
|
|
// null-terminated array of globals that are mutable; disables the import optimization for fields accessed through these
|
2023-08-07 21:45:04 +01:00
|
|
|
const char* const* mutableGlobals;
|
2024-05-31 20:18:18 +01:00
|
|
|
|
|
|
|
// null-terminated array of userdata types that will be included in the type information
|
2024-06-29 01:34:49 +01:00
|
|
|
const char* const* userdataTypes;
|
2024-12-13 21:02:30 +00:00
|
|
|
|
|
|
|
// null-terminated array of globals which act as libraries and have members with known type and/or constant value
|
|
|
|
// when an import of one of these libraries is accessed, callbacks below will be called to receive that information
|
|
|
|
const char* const* librariesWithKnownMembers;
|
|
|
|
lua_LibraryMemberTypeCallback libraryMemberTypeCb;
|
|
|
|
lua_LibraryMemberConstantCallback libraryMemberConstantCb;
|
|
|
|
|
|
|
|
// null-terminated array of library functions that should not be compiled into a built-in fastcall ("name" "lib.name")
|
|
|
|
const char* const* disabledBuiltins;
|
2021-11-19 16:10:07 +00:00
|
|
|
};
|
|
|
|
|
2022-08-04 23:35:33 +01:00
|
|
|
// compile source to bytecode; when source compilation fails, the resulting bytecode contains the encoded error. use free() to destroy
|
2021-11-19 16:10:07 +00:00
|
|
|
LUACODE_API char* luau_compile(const char* source, size_t size, lua_CompileOptions* options, size_t* outsize);
|
2024-12-13 21:02:30 +00:00
|
|
|
|
|
|
|
// when libraryMemberConstantCb is called, these methods can be used to set a value of the opaque lua_CompileConstant struct
|
|
|
|
// vector component 'w' is not visible to VM runtime configured with LUA_VECTOR_SIZE == 3, but can affect constant folding during compilation
|
|
|
|
// string storage must outlive the invocation of 'luau_compile' which used the callback
|
|
|
|
LUACODE_API void luau_set_compile_constant_nil(lua_CompileConstant* constant);
|
|
|
|
LUACODE_API void luau_set_compile_constant_boolean(lua_CompileConstant* constant, int b);
|
|
|
|
LUACODE_API void luau_set_compile_constant_number(lua_CompileConstant* constant, double n);
|
|
|
|
LUACODE_API void luau_set_compile_constant_vector(lua_CompileConstant* constant, float x, float y, float z, float w);
|
|
|
|
LUACODE_API void luau_set_compile_constant_string(lua_CompileConstant* constant, const char* s, size_t l);
|