Compare commits
1 Commits
2bfc16c662
...
da33604123
Author | SHA1 | Date | |
---|---|---|---|
da33604123 |
@ -18284,7 +18284,7 @@ compile_file = fn (arena: &Arena, compile_options: CompileFile, envp: &&u8) []u8
|
|||||||
{
|
{
|
||||||
>builder: ArgumentBuilder = zero;
|
>builder: ArgumentBuilder = zero;
|
||||||
|
|
||||||
add_argument(&builder, arena_join_string(module.arena, [ CMAKE_PREFIX_PATH, "/bin/llvm-config"][..]);
|
add_argument(&builder, "/home/david/dev/llvm/install/llvm_20.1.3_x86_64-linux-Release/bin/llvm-config");
|
||||||
add_argument(&builder, "--libdir");
|
add_argument(&builder, "--libdir");
|
||||||
add_argument(&builder, "--libs");
|
add_argument(&builder, "--libs");
|
||||||
add_argument(&builder, "--system-libs");
|
add_argument(&builder, "--system-libs");
|
||||||
|
@ -93,7 +93,6 @@ fn void compile(Arena* arena, Options options)
|
|||||||
.name = options.name,
|
.name = options.name,
|
||||||
.path = options.path,
|
.path = options.path,
|
||||||
.executable = options.executable,
|
.executable = options.executable,
|
||||||
.definitions = options.definitions,
|
|
||||||
.objects = options.objects,
|
.objects = options.objects,
|
||||||
.library_directories = options.library_directories,
|
.library_directories = options.library_directories,
|
||||||
.library_names = options.library_names,
|
.library_names = options.library_names,
|
||||||
@ -175,13 +174,6 @@ fn String compile_file(Arena* arena, Compile options)
|
|||||||
auto file_content = file_read(arena, relative_file_path);
|
auto file_content = file_read(arena, relative_file_path);
|
||||||
auto file_path = path_absolute(arena, relative_file_path);
|
auto file_path = path_absolute(arena, relative_file_path);
|
||||||
|
|
||||||
Slice<Definition> definitions = {};
|
|
||||||
auto cmake_prefix_path = string_literal(CMAKE_PREFIX_PATH);
|
|
||||||
auto cmake_prefix_path_definition = Definition{
|
|
||||||
.name = string_literal("CMAKE_PREFIX_PATH"),
|
|
||||||
.value = cmake_prefix_path,
|
|
||||||
};
|
|
||||||
|
|
||||||
String objects[] = {
|
String objects[] = {
|
||||||
output_object_path,
|
output_object_path,
|
||||||
};
|
};
|
||||||
@ -198,11 +190,9 @@ fn String compile_file(Arena* arena, Compile options)
|
|||||||
|
|
||||||
if (is_compiler)
|
if (is_compiler)
|
||||||
{
|
{
|
||||||
definitions = { .pointer = &cmake_prefix_path_definition, .length = 1 };
|
|
||||||
|
|
||||||
ArgBuilder builder = {};
|
ArgBuilder builder = {};
|
||||||
String llvm_config_parts[] = {
|
String llvm_config_parts[] = {
|
||||||
cmake_prefix_path,
|
string_literal(CMAKE_PREFIX_PATH),
|
||||||
string_literal("/bin/llvm-config"),
|
string_literal("/bin/llvm-config"),
|
||||||
};
|
};
|
||||||
builder.add(arena, arena_join_string(arena, array_to_slice(llvm_config_parts)));
|
builder.add(arena, arena_join_string(arena, array_to_slice(llvm_config_parts)));
|
||||||
@ -310,7 +300,6 @@ fn String compile_file(Arena* arena, Compile options)
|
|||||||
.path = file_path,
|
.path = file_path,
|
||||||
.executable = output_executable_path,
|
.executable = output_executable_path,
|
||||||
.name = base_name,
|
.name = base_name,
|
||||||
.definitions = definitions,
|
|
||||||
.objects = object_slice,
|
.objects = object_slice,
|
||||||
.library_paths = library_paths,
|
.library_paths = library_paths,
|
||||||
.library_names = library_names,
|
.library_names = library_names,
|
||||||
|
@ -1296,12 +1296,6 @@ struct ModuleLLVM
|
|||||||
u32 debug_tag;
|
u32 debug_tag;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Definition
|
|
||||||
{
|
|
||||||
String name;
|
|
||||||
String value;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct Module
|
struct Module
|
||||||
{
|
{
|
||||||
Arena* arena;
|
Arena* arena;
|
||||||
@ -1336,7 +1330,6 @@ struct Module
|
|||||||
String path;
|
String path;
|
||||||
String executable;
|
String executable;
|
||||||
|
|
||||||
Slice<Definition> definitions;
|
|
||||||
Slice<String> objects;
|
Slice<String> objects;
|
||||||
Slice<String> library_directories;
|
Slice<String> library_directories;
|
||||||
Slice<String> library_names;
|
Slice<String> library_names;
|
||||||
@ -1415,7 +1408,6 @@ struct Options
|
|||||||
String path;
|
String path;
|
||||||
String executable;
|
String executable;
|
||||||
String name;
|
String name;
|
||||||
Slice<Definition> definitions;
|
|
||||||
Slice<String> objects;
|
Slice<String> objects;
|
||||||
Slice<String> library_paths;
|
Slice<String> library_paths;
|
||||||
Slice<String> library_names;
|
Slice<String> library_names;
|
||||||
|
@ -3166,25 +3166,6 @@ fn Block* parse_block(Module* module, Scope* parent_scope)
|
|||||||
void parse(Module* module)
|
void parse(Module* module)
|
||||||
{
|
{
|
||||||
auto scope = &module->scope;
|
auto scope = &module->scope;
|
||||||
|
|
||||||
for (auto definition: module->definitions)
|
|
||||||
{
|
|
||||||
auto definition_global = new_global(module);
|
|
||||||
auto definition_value = new_value(module);
|
|
||||||
*definition_value = {
|
|
||||||
.string_literal = definition.value,
|
|
||||||
.id = ValueId::string_literal,
|
|
||||||
};
|
|
||||||
*definition_global = Global{
|
|
||||||
.variable = {
|
|
||||||
.initial_value = definition_value,
|
|
||||||
.type = get_slice_type(module, uint8(module)),
|
|
||||||
.scope = scope,
|
|
||||||
.name = definition.name,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
{
|
{
|
||||||
skip_space(module);
|
skip_space(module);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user