2021-10-29 21:25:12 +01:00
|
|
|
// This file is part of the Luau programming language and is licensed under MIT License; see LICENSE.txt for details
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "Luau/ParseOptions.h"
|
|
|
|
#include "Luau/Location.h"
|
|
|
|
#include "Luau/StringUtils.h"
|
|
|
|
#include "Luau/Common.h"
|
|
|
|
|
|
|
|
namespace Luau
|
|
|
|
{
|
|
|
|
class AstNameTable;
|
2022-07-14 23:39:35 +01:00
|
|
|
struct ParseResult;
|
2021-10-29 21:25:12 +01:00
|
|
|
class BytecodeBuilder;
|
|
|
|
class BytecodeEncoder;
|
|
|
|
|
2021-11-18 22:21:07 +00:00
|
|
|
// Note: this structure is duplicated in luacode.h, don't forget to change these in sync!
|
2021-10-29 21:25:12 +01:00
|
|
|
struct CompileOptions
|
|
|
|
{
|
|
|
|
// 0 - no optimization
|
|
|
|
// 1 - baseline optimization level that doesn't prevent debuggability
|
|
|
|
// 2 - includes optimizations that harm debuggability such as inlining
|
|
|
|
int optimizationLevel = 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 = 1;
|
|
|
|
|
2024-04-25 21:57:23 +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 = 0;
|
|
|
|
|
2021-10-29 21:25:12 +01:00
|
|
|
// 0 - no code coverage support
|
|
|
|
// 1 - statement coverage
|
|
|
|
// 2 - statement and expression coverage (verbose)
|
|
|
|
int coverageLevel = 0;
|
|
|
|
|
2024-11-01 16:47:10 +00:00
|
|
|
// alternative global builtin to construct vectors, in addition to default builtin 'vector.create'
|
2021-10-29 21:25:12 +01:00
|
|
|
const char* vectorLib = nullptr;
|
|
|
|
const char* vectorCtor = nullptr;
|
2021-11-12 02:12:39 +00:00
|
|
|
|
2024-11-01 16:47:10 +00:00
|
|
|
// alternative vector type name for type tables, in addition to default type 'vector'
|
2023-07-14 16:57:16 +01:00
|
|
|
const char* vectorType = nullptr;
|
|
|
|
|
2021-11-12 02:12:39 +00:00
|
|
|
// null-terminated array of globals that are mutable; disables the import optimization for fields accessed through these
|
2023-08-11 13:55:30 +01:00
|
|
|
const char* const* mutableGlobals = nullptr;
|
2024-05-31 18:46:33 +01:00
|
|
|
|
|
|
|
// null-terminated array of userdata types that will be included in the type information
|
|
|
|
const char* const* userdataTypes = nullptr;
|
2021-10-29 21:25:12 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
class CompileError : public std::exception
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
CompileError(const Location& location, const std::string& message);
|
|
|
|
|
|
|
|
virtual ~CompileError() throw();
|
|
|
|
|
|
|
|
virtual const char* what() const throw();
|
|
|
|
|
|
|
|
const Location& getLocation() const;
|
|
|
|
|
|
|
|
static LUAU_NORETURN void raise(const Location& location, const char* format, ...) LUAU_PRINTF_ATTR(2, 3);
|
|
|
|
|
|
|
|
private:
|
|
|
|
Location location;
|
|
|
|
std::string message;
|
|
|
|
};
|
|
|
|
|
|
|
|
// compiles bytecode into bytecode builder using either a pre-parsed AST or parsing it from source; throws on errors
|
2022-07-14 23:39:35 +01:00
|
|
|
void compileOrThrow(BytecodeBuilder& bytecode, const ParseResult& parseResult, const AstNameTable& names, const CompileOptions& options = {});
|
2021-10-29 21:25:12 +01:00
|
|
|
void compileOrThrow(BytecodeBuilder& bytecode, const std::string& source, const CompileOptions& options = {}, const ParseOptions& parseOptions = {});
|
|
|
|
|
|
|
|
// compiles bytecode into a bytecode blob, that either contains the valid bytecode or an encoded error that luau_load can decode
|
|
|
|
std::string compile(
|
2024-08-02 00:25:12 +01:00
|
|
|
const std::string& source,
|
|
|
|
const CompileOptions& options = {},
|
|
|
|
const ParseOptions& parseOptions = {},
|
|
|
|
BytecodeEncoder* encoder = nullptr
|
|
|
|
);
|
2021-10-29 21:25:12 +01:00
|
|
|
|
|
|
|
} // namespace Luau
|