From 3ca2e70edf468dcde057df4dd9922ba75e09f614 Mon Sep 17 00:00:00 2001 From: Zhao Date: Tue, 7 Jun 2022 03:20:21 +0800 Subject: [PATCH] Use Zig to build aarch64 binaries (#1249) --- .github/workflows/make-plugin-arm.yml | 41 ++++ .github/workflows/make-plugin-linux.yml | 4 +- .github/workflows/make-plugin-mac-os.yml | 4 +- .github/workflows/make-plugin-windows.yml | 4 +- .gitignore | 2 + javascript/net/grpc/web/generator/build.zig | 215 ++++++++++++++++++++ 6 files changed, 264 insertions(+), 6 deletions(-) create mode 100644 .github/workflows/make-plugin-arm.yml create mode 100644 javascript/net/grpc/web/generator/build.zig diff --git a/.github/workflows/make-plugin-arm.yml b/.github/workflows/make-plugin-arm.yml new file mode 100644 index 00000000..dbc37ed1 --- /dev/null +++ b/.github/workflows/make-plugin-arm.yml @@ -0,0 +1,41 @@ +name: Make ARM Plugins (Windows/macOS/Linux) + +on: + workflow_dispatch: + inputs: + version_number: + description: 'Version number' + required: true + default: '1.x.x' + +jobs: + build: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + with: + submodules: 'recursive' + - name: Setup Zig + run: | + mkdir /zig + curl 'https://ziglang.org/download/0.9.1/zig-linux-x86_64-0.9.1.tar.xz' | tar xJ --strip-components=1 --directory=/zig + ln -s /zig/zig /usr/bin/zig + - name: Build plugin + env: + VERSION: ${{ github.event.inputs.version_number }} + run: | + cd javascript/net/grpc/web/generator + zig build -Drelease-fast + - name: gen and verify sha256 + run: | + cd javascript/net/grpc/web/generator/zig-out/bin + for exe in $(ls) + do + openssl dgst -sha256 -r -out $exe'.sha256' $exe + sha256sum -c $exe'.sha256' + done + - name: Upload artifacts + uses: actions/upload-artifact@v3 + with: + name: plugin + path: javascript/net/grpc/web/generator/zig-out/bin/ diff --git a/.github/workflows/make-plugin-linux.yml b/.github/workflows/make-plugin-linux.yml index 99cd53ad..b14c032a 100644 --- a/.github/workflows/make-plugin-linux.yml +++ b/.github/workflows/make-plugin-linux.yml @@ -12,7 +12,7 @@ jobs: build: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v3 - name: Build plugin docker image run: docker-compose build prereqs protoc-plugin - name: Copy binary from Docker image @@ -26,7 +26,7 @@ jobs: - name: verify sha256 run: sha256sum -c protoc-gen-grpc-web-${{ github.event.inputs.version_number }}-linux-x86_64.sha256 - name: Upload artifacts - uses: actions/upload-artifact@v2 + uses: actions/upload-artifact@v3 with: name: plugin path: protoc-gen-grpc-web* diff --git a/.github/workflows/make-plugin-mac-os.yml b/.github/workflows/make-plugin-mac-os.yml index 442e52c5..89e4a068 100644 --- a/.github/workflows/make-plugin-mac-os.yml +++ b/.github/workflows/make-plugin-mac-os.yml @@ -12,7 +12,7 @@ jobs: build: runs-on: macos-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v3 - name: Install build utils run: brew install coreutils automake - name: Checkout protobuf code @@ -42,7 +42,7 @@ jobs: - name: verify sha256 run: sha256sum -c protoc-gen-grpc-web-${{ github.event.inputs.version_number }}-darwin-x86_64.sha256 - name: Upload artifacts - uses: actions/upload-artifact@v2 + uses: actions/upload-artifact@v3 with: name: plugin path: protoc-gen-grpc-web* diff --git a/.github/workflows/make-plugin-windows.yml b/.github/workflows/make-plugin-windows.yml index 067aded5..bfcda7af 100644 --- a/.github/workflows/make-plugin-windows.yml +++ b/.github/workflows/make-plugin-windows.yml @@ -12,7 +12,7 @@ jobs: build: runs-on: windows-latest steps: - - uses: actions/checkout@v2 + - uses: actions/checkout@v3 - name: Print Bazel version run: | bazel version @@ -31,7 +31,7 @@ jobs: # TODO: Check sha256 (sha256sum not available for now. ) #- name: verify sha256 - name: Upload artifacts - uses: actions/upload-artifact@v2 + uses: actions/upload-artifact@v3 with: name: plugin path: protoc-gen-grpc-web* diff --git a/.gitignore b/.gitignore index 197f868b..4d01b95d 100644 --- a/.gitignore +++ b/.gitignore @@ -11,3 +11,5 @@ target .project .classpath .settings +zig-out +zig-cache diff --git a/javascript/net/grpc/web/generator/build.zig b/javascript/net/grpc/web/generator/build.zig new file mode 100644 index 00000000..669ab044 --- /dev/null +++ b/javascript/net/grpc/web/generator/build.zig @@ -0,0 +1,215 @@ +const std = @import("std"); +const CrossTarget = std.zig.CrossTarget; + +fn format(comptime fmt: []const u8, args: anytype) []const u8 { + return std.fmt.allocPrint(std.testing.allocator, fmt, args) catch unreachable; +} + +const BinaryTarget = struct { + name: []const u8, + arch: []const u8, +}; + +pub fn build(b: *std.build.Builder) void { + // Standard release options allow the person running `zig build` to select + // between Debug, ReleaseSafe, ReleaseFast, and ReleaseSmall. + const mode = b.standardReleaseOptions(); + + var version = if (std.os.getenv("VERSION")) |v| v else "unknown"; + + var targets = [_]BinaryTarget{ + // for now, let's only build aarch64 binaries + // .{ .name = format("protoc-gen-grpc-web-{s}-linux-x86_64", .{version}), .arch = "x86_64-linux" }, + // .{ .name = format("protoc-gen-grpc-web-{s}-darwin-x86_64", .{version}), .arch = "x86_64-macos" }, + // .{ .name = format("protoc-gen-grpc-web-{s}-windows-x86_64", .{version}), .arch = "x86_64-windows" }, + + .{ .name = format("protoc-gen-grpc-web-{s}-linux-aarch64", .{version}), .arch = "aarch64-linux" }, + .{ .name = format("protoc-gen-grpc-web-{s}-darwin-aarch64", .{version}), .arch = "aarch64-macos" }, + .{ .name = format("protoc-gen-grpc-web-{s}-windows-aarch64", .{version}), .arch = "aarch64-windows" }, + }; + + for (targets) |target| { + const exe = b.addExecutable(target.name, "grpc_generator.cc"); + exe.linkLibCpp(); + exe.linkSystemLibrary("pthread"); + exe.linkSystemLibrary("dl"); + exe.addIncludeDir("../../../../../third_party/protobuf/src"); + exe.defineCMacro("HAVE_PTHREAD", "1"); + exe.addCSourceFiles(&[_][]const u8{ + // libprotobuf_lite source files (copied from third_party/protobuf/cmake/libprotobuf-lite.cmake) + "../../../../../third_party/protobuf/src/google/protobuf/any_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/arena.cc", + "../../../../../third_party/protobuf/src/google/protobuf/arenastring.cc", + "../../../../../third_party/protobuf/src/google/protobuf/extension_set.cc", + "../../../../../third_party/protobuf/src/google/protobuf/generated_enum_util.cc", + "../../../../../third_party/protobuf/src/google/protobuf/generated_message_table_driven_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/generated_message_util.cc", + "../../../../../third_party/protobuf/src/google/protobuf/implicit_weak_message.cc", + "../../../../../third_party/protobuf/src/google/protobuf/io/coded_stream.cc", + "../../../../../third_party/protobuf/src/google/protobuf/io/io_win32.cc", + "../../../../../third_party/protobuf/src/google/protobuf/io/strtod.cc", + "../../../../../third_party/protobuf/src/google/protobuf/io/zero_copy_stream.cc", + "../../../../../third_party/protobuf/src/google/protobuf/io/zero_copy_stream_impl.cc", + "../../../../../third_party/protobuf/src/google/protobuf/io/zero_copy_stream_impl_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/map.cc", + "../../../../../third_party/protobuf/src/google/protobuf/message_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/parse_context.cc", + "../../../../../third_party/protobuf/src/google/protobuf/repeated_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/stubs/bytestream.cc", + "../../../../../third_party/protobuf/src/google/protobuf/stubs/common.cc", + "../../../../../third_party/protobuf/src/google/protobuf/stubs/int128.cc", + "../../../../../third_party/protobuf/src/google/protobuf/stubs/status.cc", + "../../../../../third_party/protobuf/src/google/protobuf/stubs/statusor.cc", + "../../../../../third_party/protobuf/src/google/protobuf/stubs/stringpiece.cc", + "../../../../../third_party/protobuf/src/google/protobuf/stubs/stringprintf.cc", + "../../../../../third_party/protobuf/src/google/protobuf/stubs/structurally_valid.cc", + "../../../../../third_party/protobuf/src/google/protobuf/stubs/strutil.cc", + "../../../../../third_party/protobuf/src/google/protobuf/stubs/time.cc", + "../../../../../third_party/protobuf/src/google/protobuf/wire_format_lite.cc", + + // libprotobuf ssource files (copied from third_party/protobuf/cmake/libprotobuf.cmake) + "../../../../../third_party/protobuf/src/google/protobuf/any.cc", + "../../../../../third_party/protobuf/src/google/protobuf/any.pb.cc", + "../../../../../third_party/protobuf/src/google/protobuf/api.pb.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/importer.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/parser.cc", + "../../../../../third_party/protobuf/src/google/protobuf/descriptor.cc", + "../../../../../third_party/protobuf/src/google/protobuf/descriptor.pb.cc", + "../../../../../third_party/protobuf/src/google/protobuf/descriptor_database.cc", + "../../../../../third_party/protobuf/src/google/protobuf/duration.pb.cc", + "../../../../../third_party/protobuf/src/google/protobuf/dynamic_message.cc", + "../../../../../third_party/protobuf/src/google/protobuf/empty.pb.cc", + "../../../../../third_party/protobuf/src/google/protobuf/extension_set_heavy.cc", + "../../../../../third_party/protobuf/src/google/protobuf/field_mask.pb.cc", + "../../../../../third_party/protobuf/src/google/protobuf/generated_message_reflection.cc", + "../../../../../third_party/protobuf/src/google/protobuf/generated_message_table_driven.cc", + "../../../../../third_party/protobuf/src/google/protobuf/io/gzip_stream.cc", + "../../../../../third_party/protobuf/src/google/protobuf/io/printer.cc", + "../../../../../third_party/protobuf/src/google/protobuf/io/tokenizer.cc", + "../../../../../third_party/protobuf/src/google/protobuf/map_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/message.cc", + "../../../../../third_party/protobuf/src/google/protobuf/reflection_ops.cc", + "../../../../../third_party/protobuf/src/google/protobuf/service.cc", + "../../../../../third_party/protobuf/src/google/protobuf/source_context.pb.cc", + "../../../../../third_party/protobuf/src/google/protobuf/struct.pb.cc", + "../../../../../third_party/protobuf/src/google/protobuf/stubs/substitute.cc", + "../../../../../third_party/protobuf/src/google/protobuf/text_format.cc", + "../../../../../third_party/protobuf/src/google/protobuf/timestamp.pb.cc", + "../../../../../third_party/protobuf/src/google/protobuf/type.pb.cc", + "../../../../../third_party/protobuf/src/google/protobuf/unknown_field_set.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/delimited_message_util.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/field_comparator.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/field_mask_util.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/datapiece.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/default_value_objectwriter.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/error_listener.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/field_mask_utility.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/json_escaping.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/json_objectwriter.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/json_stream_parser.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/object_writer.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/proto_writer.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/protostream_objectsource.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/protostream_objectwriter.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/type_info.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/type_info_test_helper.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/internal/utility.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/json_util.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/message_differencer.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/time_util.cc", + "../../../../../third_party/protobuf/src/google/protobuf/util/type_resolver_util.cc", + "../../../../../third_party/protobuf/src/google/protobuf/wire_format.cc", + "../../../../../third_party/protobuf/src/google/protobuf/wrappers.pb.cc", + + // libprotoc source files (copied from third_party/protobuf/cmake/libprotoc.cmake) + "../../../../../third_party/protobuf/src/google/protobuf/compiler/code_generator.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/command_line_interface.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_enum.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_enum_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_extension.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_file.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_generator.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_helpers.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_map_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_message.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_message_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_padding_optimizer.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_primitive_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_service.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/cpp/cpp_string_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_doc_comment.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_enum.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_enum_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_field_base.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_generator.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_helpers.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_map_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_message.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_message_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_primitive_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_reflection_class.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_repeated_enum_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_repeated_message_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_repeated_primitive_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_source_generator_base.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/csharp/csharp_wrapper_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_context.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_doc_comment.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_enum.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_enum_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_enum_field_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_enum_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_extension.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_extension_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_file.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_generator.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_generator_factory.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_helpers.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_map_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_map_field_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_message.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_message_builder.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_message_builder_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_message_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_message_field_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_message_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_name_resolver.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_primitive_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_primitive_field_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_service.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_shared_code_generator.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_string_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/java/java_string_field_lite.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/js/js_generator.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/js/well_known_types_embed.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/objectivec/objectivec_enum.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/objectivec/objectivec_enum_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/objectivec/objectivec_extension.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/objectivec/objectivec_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/objectivec/objectivec_file.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/objectivec/objectivec_generator.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/objectivec/objectivec_helpers.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/objectivec/objectivec_map_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/objectivec/objectivec_message.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/objectivec/objectivec_message_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/objectivec/objectivec_oneof.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/objectivec/objectivec_primitive_field.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/php/php_generator.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/plugin.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/plugin.pb.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/python/python_generator.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/ruby/ruby_generator.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/subprocess.cc", + "../../../../../third_party/protobuf/src/google/protobuf/compiler/zip_writer.cc", + }, &[_][]const u8{ + "-pthread", + }); + + exe.setTarget(CrossTarget.parse(.{ .arch_os_abi = target.arch }) catch unreachable); + exe.setBuildMode(mode); + exe.strip = true; + exe.install(); + } +}