From 75284671f23cb0305a3a1a6a20bc2b1fca7e00e2 Mon Sep 17 00:00:00 2001 From: Benoit Giannangeli Date: Wed, 31 Jul 2024 08:25:42 +0200 Subject: [PATCH] feat: MIR is built by zig --- README.md | 7 ++++--- build.zig | 39 ++++----------------------------------- examples/fibonacci.buzz | 2 +- 3 files changed, 9 insertions(+), 39 deletions(-) diff --git a/README.md b/README.md index 85314ed5..5fe43ba5 100644 --- a/README.md +++ b/README.md @@ -42,10 +42,11 @@ _Latest zig version supported: 0.14.0-dev.121+ab4c461b7_ ### Build 1. Clone the project: `git clone https://github.com/buzz-language/buzz ` 2. Checkout submodules: `git submodule update --init` -3. Build MIR: +3. Run configure for pcre2: ```bash -cd vendors/mir -make +cd vendors/pcre2 +./configure +cd ../.. ``` 4. Have fun: `zig build run -- ` diff --git a/build.zig b/build.zig index be11bc55..432eda63 100644 --- a/build.zig +++ b/build.zig @@ -116,20 +116,14 @@ pub fn build(b: *Build) !void { .sha = std.posix.getenv("GIT_SHA") orelse std.posix.getenv("GITHUB_SHA") orelse std.mem.trim( u8, - (std.process.Child.run(.{ - .allocator = b.allocator, - .argv = &.{ + b.run( + &.{ "git", "rev-parse", "--short", "HEAD", }, - .cwd = b.pathFromRoot("."), - .expand_arg0 = .expand, - }) catch { - std.debug.print("Warning: failed to get git HEAD", .{}); - unreachable; - }).stdout, + ), "\n \t", ), .cycle_limit = b.option( @@ -731,28 +725,6 @@ pub fn buildMir(b: *Build, target: Build.ResolvedTarget, optimize: std.builtin.O ); lib.addIncludePath(b.path("./vendors/mir")); - lib.linkLibC(); - - if (lib.root_module.resolved_target.?.result.os.tag == .windows) { - lib.addSystemIncludePath( - b.path((std.process.Child.run(.{ - .allocator = b.allocator, - .argv = &.{ - "xcrun", - "--show-sdk-path", - }, - }) catch { - std.debug.print("Failed to get MacOSX sdk path", .{}); - unreachable; - }).stdout), - ); - // Github macos-12 runner (https://github.com/actions/runner-images/blob/main/images/macos/macos-12-Readme.md). - lib.addSystemIncludePath(b.path("/Applications/Xcode_14.0.1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include")); - lib.addSystemIncludePath(b.path("/Library/Developer/CommandLineTools/SDKs/MacOSX14.0.sdk/usr/include")); - lib.addSystemIncludePath(b.path("/Library/Developer/CommandLineTools/SDKs/MacOSX13.3.sdk/usr/include")); - lib.addSystemIncludePath(b.path("/Library/Developer/CommandLineTools/SDKs/MacOSX12.3.sdk/usr/include")); - lib.addSystemIncludePath(b.path("/Library/Developer/CommandLineTools/SDKs/MacOSX12.1.sdk/usr/include")); - } lib.addCSourceFiles( .{ @@ -766,13 +738,10 @@ pub fn buildMir(b: *Build, target: Build.ResolvedTarget, optimize: std.builtin.O "-O3", "-DNDEBUG=1", "-DMIR_PARALLEL_GEN=1", - // "-DADDITIONAL_INCLUDE_PATH=\"/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX.sdk/usr/include\"", + "-fno-sanitize=undefined", // MIR has some undefined behaviour somewhere so we need this }, }, ); - // lib.linkSystemLibrary("m"); - // lib.linkSystemLibrary("dl"); - return lib; } diff --git a/examples/fibonacci.buzz b/examples/fibonacci.buzz index 2b3abc89..556a1cd5 100644 --- a/examples/fibonacci.buzz +++ b/examples/fibonacci.buzz @@ -14,7 +14,7 @@ fun fibonacci(int n) > void *> int? { } fun main([str] args) > void { - const N = std.parseInt(args[?0] ?? '10') ?? 10; + const N = std.parseInt(args[?0] ?? "10") ?? 10; foreach (var n in &fibonacci(N)) { std.print("{n}");