mirror of
https://github.com/google/flatbuffers.git
synced 2026-07-03 19:54:12 +00:00
This reverts commit 4172c3f0bd.
This commit is contained in:
@@ -1 +0,0 @@
|
|||||||
node_modules
|
|
||||||
26
BUILD.bazel
26
BUILD.bazel
@@ -1,5 +1,3 @@
|
|||||||
load("@aspect_rules_js//npm:defs.bzl", "npm_link_package")
|
|
||||||
load("@npm//:defs.bzl", "npm_link_all_packages")
|
|
||||||
load("@rules_cc//cc:defs.bzl", "cc_binary", "cc_library")
|
load("@rules_cc//cc:defs.bzl", "cc_binary", "cc_library")
|
||||||
|
|
||||||
licenses(["notice"])
|
licenses(["notice"])
|
||||||
@@ -8,13 +6,6 @@ package(
|
|||||||
default_visibility = ["//visibility:public"],
|
default_visibility = ["//visibility:public"],
|
||||||
)
|
)
|
||||||
|
|
||||||
npm_link_all_packages(name = "node_modules")
|
|
||||||
|
|
||||||
npm_link_package(
|
|
||||||
name = "node_modules/flatbuffers",
|
|
||||||
src = "//ts:flatbuffers",
|
|
||||||
)
|
|
||||||
|
|
||||||
exports_files([
|
exports_files([
|
||||||
"LICENSE",
|
"LICENSE",
|
||||||
"tsconfig.json",
|
"tsconfig.json",
|
||||||
@@ -34,23 +25,6 @@ config_setting(
|
|||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
filegroup(
|
|
||||||
name = "distribution",
|
|
||||||
srcs = [
|
|
||||||
"BUILD.bazel",
|
|
||||||
"WORKSPACE",
|
|
||||||
"build_defs.bzl",
|
|
||||||
"typescript.bzl",
|
|
||||||
"//grpc/src/compiler:distribution",
|
|
||||||
"//reflection:distribution",
|
|
||||||
"//src:distribution",
|
|
||||||
"//ts:distribution",
|
|
||||||
] + glob([
|
|
||||||
"include/flatbuffers/*.h",
|
|
||||||
]),
|
|
||||||
visibility = ["//visibility:public"],
|
|
||||||
)
|
|
||||||
|
|
||||||
# Public flatc library to compile flatbuffer files at runtime.
|
# Public flatc library to compile flatbuffer files at runtime.
|
||||||
cc_library(
|
cc_library(
|
||||||
name = "flatbuffers",
|
name = "flatbuffers",
|
||||||
|
|||||||
84
WORKSPACE
84
WORKSPACE
@@ -1,6 +1,6 @@
|
|||||||
workspace(name = "com_github_google_flatbuffers")
|
workspace(name = "com_github_google_flatbuffers")
|
||||||
|
|
||||||
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive", "http_file")
|
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
|
||||||
|
|
||||||
http_archive(
|
http_archive(
|
||||||
name = "platforms",
|
name = "platforms",
|
||||||
@@ -76,80 +76,30 @@ load("@com_github_grpc_grpc//bazel:grpc_extra_deps.bzl", "grpc_extra_deps")
|
|||||||
grpc_extra_deps()
|
grpc_extra_deps()
|
||||||
|
|
||||||
# rules_go from https://github.com/bazelbuild/rules_go/releases/tag/v0.34.0
|
# rules_go from https://github.com/bazelbuild/rules_go/releases/tag/v0.34.0
|
||||||
|
|
||||||
http_archive(
|
http_archive(
|
||||||
name = "aspect_rules_js",
|
name = "build_bazel_rules_nodejs",
|
||||||
sha256 = "124ed29fb0b3d0cba5b44f8f8e07897cf61b34e35e33b1f83d1a943dfd91b193",
|
sha256 = "965ee2492a2b087cf9e0f2ca472aeaf1be2eb650e0cfbddf514b9a7d3ea4b02a",
|
||||||
strip_prefix = "rules_js-1.24.0",
|
urls = ["https://github.com/bazelbuild/rules_nodejs/releases/download/5.2.0/rules_nodejs-5.2.0.tar.gz"],
|
||||||
url = "https://github.com/aspect-build/rules_js/releases/download/v1.24.0/rules_js-v1.24.0.tar.gz",
|
|
||||||
)
|
)
|
||||||
|
|
||||||
load("@aspect_rules_js//js:repositories.bzl", "rules_js_dependencies")
|
load("@build_bazel_rules_nodejs//:repositories.bzl", "build_bazel_rules_nodejs_dependencies")
|
||||||
|
|
||||||
rules_js_dependencies()
|
build_bazel_rules_nodejs_dependencies()
|
||||||
|
|
||||||
load("@aspect_rules_js//npm:npm_import.bzl", "npm_translate_lock", "pnpm_repository")
|
load("@build_bazel_rules_nodejs//:index.bzl", "node_repositories", "yarn_install")
|
||||||
|
|
||||||
pnpm_repository(name = "pnpm")
|
node_repositories()
|
||||||
|
|
||||||
http_archive(
|
yarn_install(
|
||||||
name = "aspect_rules_ts",
|
|
||||||
sha256 = "8eb25d1fdafc0836f5778d33fb8eaac37c64176481d67872b54b0a05de5be5c0",
|
|
||||||
strip_prefix = "rules_ts-1.3.3",
|
|
||||||
url = "https://github.com/aspect-build/rules_ts/releases/download/v1.3.3/rules_ts-v1.3.3.tar.gz",
|
|
||||||
)
|
|
||||||
|
|
||||||
load("@aspect_rules_ts//ts:repositories.bzl", "rules_ts_dependencies")
|
|
||||||
|
|
||||||
rules_ts_dependencies(
|
|
||||||
# Since rules_ts doesn't always have the newest integrity hashes, we
|
|
||||||
# compute it manually here.
|
|
||||||
# $ curl --silent https://registry.npmjs.org/typescript/5.0.4 | jq ._integrity
|
|
||||||
ts_integrity = "sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw==",
|
|
||||||
ts_version_from = "//:package.json",
|
|
||||||
)
|
|
||||||
|
|
||||||
load("@rules_nodejs//nodejs:repositories.bzl", "DEFAULT_NODE_VERSION", "nodejs_register_toolchains")
|
|
||||||
|
|
||||||
nodejs_register_toolchains(
|
|
||||||
name = "nodejs",
|
|
||||||
node_version = DEFAULT_NODE_VERSION,
|
|
||||||
)
|
|
||||||
|
|
||||||
npm_translate_lock(
|
|
||||||
name = "npm",
|
name = "npm",
|
||||||
npmrc = "//:.npmrc",
|
exports_directories_only = False,
|
||||||
pnpm_lock = "//:pnpm-lock.yaml",
|
# Unfreeze to add/remove packages.
|
||||||
# Set this to True when the lock file needs to be updated, commit the
|
frozen_lockfile = False,
|
||||||
# changes, then set to False again.
|
package_json = "//:package.json",
|
||||||
update_pnpm_lock = False,
|
symlink_node_modules = False,
|
||||||
verify_node_modules_ignored = "//:.bazelignore",
|
yarn_lock = "//:yarn.lock",
|
||||||
)
|
)
|
||||||
|
|
||||||
load("@npm//:repositories.bzl", "npm_repositories")
|
load("@build_bazel_rules_nodejs//toolchains/esbuild:esbuild_repositories.bzl", "esbuild_repositories")
|
||||||
|
|
||||||
npm_repositories()
|
esbuild_repositories(npm_repository = "npm")
|
||||||
|
|
||||||
http_archive(
|
|
||||||
name = "aspect_rules_esbuild",
|
|
||||||
sha256 = "2ea31bd97181a315e048be693ddc2815fddda0f3a12ca7b7cc6e91e80f31bac7",
|
|
||||||
strip_prefix = "rules_esbuild-0.14.4",
|
|
||||||
url = "https://github.com/aspect-build/rules_esbuild/releases/download/v0.14.4/rules_esbuild-v0.14.4.tar.gz",
|
|
||||||
)
|
|
||||||
|
|
||||||
# Register a toolchain containing esbuild npm package and native bindings
|
|
||||||
load("@aspect_rules_esbuild//esbuild:repositories.bzl", "LATEST_VERSION", "esbuild_register_toolchains")
|
|
||||||
|
|
||||||
esbuild_register_toolchains(
|
|
||||||
name = "esbuild",
|
|
||||||
esbuild_version = LATEST_VERSION,
|
|
||||||
)
|
|
||||||
|
|
||||||
http_file(
|
|
||||||
name = "bazel_linux_x86_64",
|
|
||||||
downloaded_file_path = "bazel",
|
|
||||||
sha256 = "e89747d63443e225b140d7d37ded952dacea73aaed896bca01ccd745827c6289",
|
|
||||||
urls = [
|
|
||||||
"https://github.com/bazelbuild/bazel/releases/download/6.1.2/bazel-6.1.2-linux-x86_64",
|
|
||||||
],
|
|
||||||
)
|
|
||||||
|
|||||||
@@ -48,10 +48,7 @@ def flatbuffer_library_public(
|
|||||||
restricted_to = None,
|
restricted_to = None,
|
||||||
target_compatible_with = None,
|
target_compatible_with = None,
|
||||||
flatc_path = "@com_github_google_flatbuffers//:flatc",
|
flatc_path = "@com_github_google_flatbuffers//:flatc",
|
||||||
output_to_bindir = False,
|
output_to_bindir = False):
|
||||||
tools = None,
|
|
||||||
extra_env = None,
|
|
||||||
**kwargs):
|
|
||||||
"""Generates code files for reading/writing the given flatbuffers in the requested language using the public compiler.
|
"""Generates code files for reading/writing the given flatbuffers in the requested language using the public compiler.
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
@@ -76,11 +73,6 @@ def flatbuffer_library_public(
|
|||||||
to use.
|
to use.
|
||||||
flatc_path: Bazel target corresponding to the flatc compiler to use.
|
flatc_path: Bazel target corresponding to the flatc compiler to use.
|
||||||
output_to_bindir: Passed to genrule for output to bin directory.
|
output_to_bindir: Passed to genrule for output to bin directory.
|
||||||
tools: Optional, passed to genrule for list of tools to make available
|
|
||||||
during the action.
|
|
||||||
extra_env: Optional, must be a string of "VAR1=VAL1 VAR2=VAL2". These get
|
|
||||||
set as environment variables that "flatc_path" sees.
|
|
||||||
**kwargs: Passed to the underlying genrule.
|
|
||||||
|
|
||||||
|
|
||||||
This rule creates a filegroup(name) with all generated source files, and
|
This rule creates a filegroup(name) with all generated source files, and
|
||||||
@@ -91,8 +83,6 @@ def flatbuffer_library_public(
|
|||||||
include_paths = default_include_paths(flatc_path)
|
include_paths = default_include_paths(flatc_path)
|
||||||
include_paths_cmd = ["-I %s" % (s) for s in include_paths]
|
include_paths_cmd = ["-I %s" % (s) for s in include_paths]
|
||||||
|
|
||||||
extra_env = extra_env or ""
|
|
||||||
|
|
||||||
# '$(@D)' when given a single source target will give the appropriate
|
# '$(@D)' when given a single source target will give the appropriate
|
||||||
# directory. Appending 'out_prefix' is only necessary when given a build
|
# directory. Appending 'out_prefix' is only necessary when given a build
|
||||||
# target with multiple sources.
|
# target with multiple sources.
|
||||||
@@ -102,7 +92,7 @@ def flatbuffer_library_public(
|
|||||||
genrule_cmd = " ".join([
|
genrule_cmd = " ".join([
|
||||||
"SRCS=($(SRCS));",
|
"SRCS=($(SRCS));",
|
||||||
"for f in $${SRCS[@]:0:%s}; do" % len(srcs),
|
"for f in $${SRCS[@]:0:%s}; do" % len(srcs),
|
||||||
"OUTPUT_FILE=\"$(OUTS)\" %s $(location %s)" % (extra_env, flatc_path),
|
"OUTPUT_FILE=\"$(OUTS)\" $(location %s)" % (flatc_path),
|
||||||
" ".join(include_paths_cmd),
|
" ".join(include_paths_cmd),
|
||||||
" ".join(flatc_args),
|
" ".join(flatc_args),
|
||||||
language_flag,
|
language_flag,
|
||||||
@@ -115,13 +105,12 @@ def flatbuffer_library_public(
|
|||||||
srcs = srcs + includes,
|
srcs = srcs + includes,
|
||||||
outs = outs,
|
outs = outs,
|
||||||
output_to_bindir = output_to_bindir,
|
output_to_bindir = output_to_bindir,
|
||||||
tools = (tools or []) + [flatc_path],
|
tools = [flatc_path],
|
||||||
cmd = genrule_cmd,
|
cmd = genrule_cmd,
|
||||||
compatible_with = compatible_with,
|
compatible_with = compatible_with,
|
||||||
target_compatible_with = target_compatible_with,
|
target_compatible_with = target_compatible_with,
|
||||||
restricted_to = restricted_to,
|
restricted_to = restricted_to,
|
||||||
message = "Generating flatbuffer files for %s:" % (name),
|
message = "Generating flatbuffer files for %s:" % (name),
|
||||||
**kwargs
|
|
||||||
)
|
)
|
||||||
if reflection_name:
|
if reflection_name:
|
||||||
reflection_genrule_cmd = " ".join([
|
reflection_genrule_cmd = " ".join([
|
||||||
|
|||||||
@@ -4,16 +4,6 @@ package(
|
|||||||
default_visibility = ["//visibility:public"],
|
default_visibility = ["//visibility:public"],
|
||||||
)
|
)
|
||||||
|
|
||||||
filegroup(
|
|
||||||
name = "distribution",
|
|
||||||
srcs = [
|
|
||||||
"BUILD.bazel",
|
|
||||||
] + glob([
|
|
||||||
"*.cc",
|
|
||||||
"*.h",
|
|
||||||
]),
|
|
||||||
)
|
|
||||||
|
|
||||||
filegroup(
|
filegroup(
|
||||||
name = "common_headers",
|
name = "common_headers",
|
||||||
srcs = [
|
srcs = [
|
||||||
|
|||||||
@@ -36,11 +36,12 @@
|
|||||||
"homepage": "https://google.github.io/flatbuffers/",
|
"homepage": "https://google.github.io/flatbuffers/",
|
||||||
"dependencies": {},
|
"dependencies": {},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
|
"@bazel/typescript": "5.2.0",
|
||||||
"@types/node": "18.15.11",
|
"@types/node": "18.15.11",
|
||||||
"@typescript-eslint/eslint-plugin": "^5.57.0",
|
"@typescript-eslint/eslint-plugin": "^5.57.0",
|
||||||
"@typescript-eslint/parser": "^5.57.0",
|
"@typescript-eslint/parser": "^5.57.0",
|
||||||
"esbuild": "^0.17.14",
|
"esbuild": "^0.17.14",
|
||||||
"eslint": "^8.37.0",
|
"eslint": "^8.37.0",
|
||||||
"typescript": "5.0.4"
|
"typescript": "^5.0.3"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
1184
pnpm-lock.yaml
generated
1184
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load Diff
@@ -1,12 +1,3 @@
|
|||||||
filegroup(
|
|
||||||
name = "distribution",
|
|
||||||
srcs = [
|
|
||||||
"BUILD.bazel",
|
|
||||||
"reflection.fbs",
|
|
||||||
],
|
|
||||||
visibility = ["//visibility:public"],
|
|
||||||
)
|
|
||||||
|
|
||||||
filegroup(
|
filegroup(
|
||||||
name = "reflection_fbs_schema",
|
name = "reflection_fbs_schema",
|
||||||
srcs = ["reflection.fbs"],
|
srcs = ["reflection.fbs"],
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ genrule(
|
|||||||
|
|
||||||
flatbuffer_ts_library(
|
flatbuffer_ts_library(
|
||||||
name = "reflection_ts_fbs",
|
name = "reflection_ts_fbs",
|
||||||
|
package_name = "flatbuffers_reflection",
|
||||||
srcs = [":reflection.fbs"],
|
srcs = [":reflection.fbs"],
|
||||||
visibility = ["//visibility:public"],
|
visibility = ["//visibility:public"],
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -5,17 +5,6 @@ package(
|
|||||||
default_visibility = ["//visibility:private"],
|
default_visibility = ["//visibility:private"],
|
||||||
)
|
)
|
||||||
|
|
||||||
filegroup(
|
|
||||||
name = "distribution",
|
|
||||||
srcs = [
|
|
||||||
"BUILD.bazel",
|
|
||||||
] + glob([
|
|
||||||
"*.cpp",
|
|
||||||
"*.h",
|
|
||||||
]),
|
|
||||||
visibility = ["//visibility:public"],
|
|
||||||
)
|
|
||||||
|
|
||||||
# Public flatc library to compile flatbuffer files at runtime.
|
# Public flatc library to compile flatbuffer files at runtime.
|
||||||
cc_library(
|
cc_library(
|
||||||
name = "flatbuffers",
|
name = "flatbuffers",
|
||||||
|
|||||||
@@ -1,20 +1,8 @@
|
|||||||
load("@aspect_bazel_lib//lib:copy_to_bin.bzl", "copy_to_bin")
|
|
||||||
load("@rules_cc//cc:defs.bzl", "cc_test")
|
load("@rules_cc//cc:defs.bzl", "cc_test")
|
||||||
load("//:build_defs.bzl", "flatbuffer_cc_library")
|
load("//:build_defs.bzl", "flatbuffer_cc_library")
|
||||||
|
|
||||||
package(default_visibility = ["//visibility:private"])
|
package(default_visibility = ["//visibility:private"])
|
||||||
|
|
||||||
# rules_js works around various JS tooling limitations by copying everything
|
|
||||||
# into the output directory. Make the test data available to the tests this way.
|
|
||||||
copy_to_bin(
|
|
||||||
name = "test_data_copied_to_bin",
|
|
||||||
srcs = glob([
|
|
||||||
"*.mon",
|
|
||||||
"*.json",
|
|
||||||
]),
|
|
||||||
visibility = ["//tests/ts:__subpackages__"],
|
|
||||||
)
|
|
||||||
|
|
||||||
# Test binary.
|
# Test binary.
|
||||||
cc_test(
|
cc_test(
|
||||||
name = "flatbuffers_test",
|
name = "flatbuffers_test",
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
load("@aspect_rules_js//js:defs.bzl", "js_test")
|
|
||||||
load("//:typescript.bzl", "flatbuffer_ts_library")
|
load("//:typescript.bzl", "flatbuffer_ts_library")
|
||||||
|
|
||||||
package(default_visibility = ["//visibility:private"])
|
package(default_visibility = ["//visibility:private"])
|
||||||
@@ -11,68 +10,3 @@ flatbuffer_ts_library(
|
|||||||
"//tests/ts/test_dir:typescript_transitive_ts_fbs",
|
"//tests/ts/test_dir:typescript_transitive_ts_fbs",
|
||||||
],
|
],
|
||||||
)
|
)
|
||||||
|
|
||||||
TEST_DATA = glob([
|
|
||||||
"my-game/*.js",
|
|
||||||
"my-game/example/*.js",
|
|
||||||
"my-game/example2/*.js",
|
|
||||||
])
|
|
||||||
|
|
||||||
TEST_UNION_VECTOR_DATA = glob([
|
|
||||||
"union_vector/*.js",
|
|
||||||
])
|
|
||||||
|
|
||||||
TEST_COMPLEX_ARRAYS_DATA = glob([
|
|
||||||
"arrays_test_complex/**/*.js",
|
|
||||||
])
|
|
||||||
|
|
||||||
# Here we're running the tests against the checked-in generated files. These
|
|
||||||
# are kept up-to-date with a CI-based mechanism. The intent of running these
|
|
||||||
# tests here via bazel is not to validate that they're up-to-date. Instead, we
|
|
||||||
# just want to make it easy to run these tests while making other changes. For
|
|
||||||
# example, this is useful when making changes to the rules_js setup to validate
|
|
||||||
# that the basic infrastructure is still working.
|
|
||||||
[js_test(
|
|
||||||
name = "%s_test" % test,
|
|
||||||
chdir = package_name(),
|
|
||||||
data = data + [
|
|
||||||
"package.json",
|
|
||||||
"//:node_modules/flatbuffers",
|
|
||||||
"//tests:test_data_copied_to_bin",
|
|
||||||
],
|
|
||||||
entry_point = "%s.js" % test,
|
|
||||||
) for test, data in (
|
|
||||||
("JavaScriptTest", TEST_DATA),
|
|
||||||
("JavaScriptUnionVectorTest", TEST_UNION_VECTOR_DATA),
|
|
||||||
# TODO(philsc): Figure out how to run this test with flexbuffers available.
|
|
||||||
# At the moment the flexbuffer library is not exposed as a bazel target.
|
|
||||||
#("JavaScriptFlexBuffersTest", TBD_DATA)
|
|
||||||
("JavaScriptComplexArraysTest", TEST_COMPLEX_ARRAYS_DATA),
|
|
||||||
)]
|
|
||||||
|
|
||||||
sh_test(
|
|
||||||
name = "bazel_repository_test",
|
|
||||||
srcs = ["bazel_repository_test.sh"],
|
|
||||||
data = [
|
|
||||||
"//:distribution",
|
|
||||||
"@bazel_linux_x86_64//file",
|
|
||||||
] + glob(
|
|
||||||
[
|
|
||||||
"bazel_repository_test_dir/**/*",
|
|
||||||
],
|
|
||||||
exclude = [
|
|
||||||
"bazel_repository_test_dir/bazel-*/**",
|
|
||||||
],
|
|
||||||
),
|
|
||||||
tags = [
|
|
||||||
# Since we have bazel downloading external repositories inside this
|
|
||||||
# test, we need to give it access to the internet.
|
|
||||||
"requires-network",
|
|
||||||
],
|
|
||||||
# We only have x86_64 Linux bazel exposed so restrict the test to that.
|
|
||||||
target_compatible_with = [
|
|
||||||
"@platforms//cpu:x86_64",
|
|
||||||
"@platforms//os:linux",
|
|
||||||
],
|
|
||||||
deps = ["@bazel_tools//tools/bash/runfiles"],
|
|
||||||
)
|
|
||||||
|
|||||||
@@ -1,29 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# This test makes sure that a separate repository can import the flatbuffers
|
|
||||||
# repository and use it in their JavaScript code.
|
|
||||||
|
|
||||||
# --- begin runfiles.bash initialization v3 ---
|
|
||||||
# Copy-pasted from the Bazel Bash runfiles library v3.
|
|
||||||
set -uo pipefail; set +e; f=bazel_tools/tools/bash/runfiles/runfiles.bash
|
|
||||||
source "${RUNFILES_DIR:-/dev/null}/$f" 2>/dev/null || \
|
|
||||||
source "$(grep -sm1 "^$f " "${RUNFILES_MANIFEST_FILE:-/dev/null}" | cut -f2- -d' ')" 2>/dev/null || \
|
|
||||||
source "$0.runfiles/$f" 2>/dev/null || \
|
|
||||||
source "$(grep -sm1 "^$f " "$0.runfiles_manifest" | cut -f2- -d' ')" 2>/dev/null || \
|
|
||||||
source "$(grep -sm1 "^$f " "$0.exe.runfiles_manifest" | cut -f2- -d' ')" 2>/dev/null || \
|
|
||||||
{ echo>&2 "ERROR: cannot find $f"; exit 1; }; f=; set -e
|
|
||||||
# --- end runfiles.bash initialization v3 ---
|
|
||||||
|
|
||||||
BAZEL_BIN="$(rlocation bazel_linux_x86_64/file/bazel)"
|
|
||||||
readonly BAZEL_BIN
|
|
||||||
|
|
||||||
if [[ ! -e "${BAZEL_BIN}" ]]; then
|
|
||||||
echo "Failed to find the bazel binary." >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
export PATH="$(dirname "${BAZEL_BIN}"):${PATH}"
|
|
||||||
|
|
||||||
cd tests/ts/bazel_repository_test_dir/
|
|
||||||
|
|
||||||
bazel test //...
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
node_modules
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
build --symlink_prefix=/
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
bazel-*
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
../../../.npmrc
|
|
||||||
@@ -1,32 +0,0 @@
|
|||||||
load("@aspect_rules_js//js:defs.bzl", "js_test")
|
|
||||||
load("@com_github_google_flatbuffers//:typescript.bzl", "flatbuffer_ts_library")
|
|
||||||
load("@aspect_rules_js//npm:defs.bzl", "npm_link_package")
|
|
||||||
load("@npm//:defs.bzl", "npm_link_all_packages")
|
|
||||||
|
|
||||||
npm_link_all_packages(name = "node_modules")
|
|
||||||
|
|
||||||
npm_link_package(
|
|
||||||
name = "node_modules/flatbuffers",
|
|
||||||
src = "@com_github_google_flatbuffers//ts:flatbuffers",
|
|
||||||
)
|
|
||||||
|
|
||||||
flatbuffer_ts_library(
|
|
||||||
name = "one_fbs",
|
|
||||||
srcs = ["one.fbs"],
|
|
||||||
)
|
|
||||||
|
|
||||||
flatbuffer_ts_library(
|
|
||||||
name = "two_fbs",
|
|
||||||
srcs = ["two.fbs"],
|
|
||||||
deps = [":one_fbs"],
|
|
||||||
)
|
|
||||||
|
|
||||||
js_test(
|
|
||||||
name = "import_test",
|
|
||||||
data = [
|
|
||||||
"package.json",
|
|
||||||
":node_modules/flatbuffers",
|
|
||||||
":two_fbs",
|
|
||||||
],
|
|
||||||
entry_point = "import_test.js",
|
|
||||||
)
|
|
||||||
@@ -1,71 +0,0 @@
|
|||||||
workspace(name = "bazel_repository_test")
|
|
||||||
|
|
||||||
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
|
|
||||||
|
|
||||||
local_repository(
|
|
||||||
name = "com_github_google_flatbuffers",
|
|
||||||
path = "../../../",
|
|
||||||
)
|
|
||||||
|
|
||||||
http_archive(
|
|
||||||
name = "aspect_rules_js",
|
|
||||||
sha256 = "124ed29fb0b3d0cba5b44f8f8e07897cf61b34e35e33b1f83d1a943dfd91b193",
|
|
||||||
strip_prefix = "rules_js-1.24.0",
|
|
||||||
url = "https://github.com/aspect-build/rules_js/releases/download/v1.24.0/rules_js-v1.24.0.tar.gz",
|
|
||||||
)
|
|
||||||
|
|
||||||
load("@aspect_rules_js//js:repositories.bzl", "rules_js_dependencies")
|
|
||||||
|
|
||||||
rules_js_dependencies()
|
|
||||||
|
|
||||||
load("@aspect_rules_js//npm:npm_import.bzl", "npm_translate_lock", "pnpm_repository")
|
|
||||||
|
|
||||||
pnpm_repository(name = "pnpm")
|
|
||||||
|
|
||||||
http_archive(
|
|
||||||
name = "aspect_rules_ts",
|
|
||||||
sha256 = "8eb25d1fdafc0836f5778d33fb8eaac37c64176481d67872b54b0a05de5be5c0",
|
|
||||||
strip_prefix = "rules_ts-1.3.3",
|
|
||||||
url = "https://github.com/aspect-build/rules_ts/releases/download/v1.3.3/rules_ts-v1.3.3.tar.gz",
|
|
||||||
)
|
|
||||||
|
|
||||||
load("@aspect_rules_ts//ts:repositories.bzl", "rules_ts_dependencies")
|
|
||||||
|
|
||||||
rules_ts_dependencies(
|
|
||||||
# curl --silent https://registry.npmjs.org/typescript/5.0.3 | jq ._integrity
|
|
||||||
ts_integrity = "sha512-xv8mOEDnigb/tN9PSMTwSEqAnUvkoXMQlicOb0IUVDBSQCgBSaAAROUZYy2IcUy5qU6XajK5jjjO7TMWqBTKZA==",
|
|
||||||
ts_version = "5.0.3",
|
|
||||||
)
|
|
||||||
|
|
||||||
load("@rules_nodejs//nodejs:repositories.bzl", "DEFAULT_NODE_VERSION", "nodejs_register_toolchains")
|
|
||||||
|
|
||||||
nodejs_register_toolchains(
|
|
||||||
name = "nodejs",
|
|
||||||
node_version = DEFAULT_NODE_VERSION,
|
|
||||||
)
|
|
||||||
|
|
||||||
npm_translate_lock(
|
|
||||||
name = "npm",
|
|
||||||
npmrc = "//:.npmrc",
|
|
||||||
pnpm_lock = "//:pnpm-lock.yaml",
|
|
||||||
verify_node_modules_ignored = "//:.bazelignore",
|
|
||||||
)
|
|
||||||
|
|
||||||
load("@npm//:repositories.bzl", "npm_repositories")
|
|
||||||
|
|
||||||
npm_repositories()
|
|
||||||
|
|
||||||
http_archive(
|
|
||||||
name = "aspect_rules_esbuild",
|
|
||||||
sha256 = "2ea31bd97181a315e048be693ddc2815fddda0f3a12ca7b7cc6e91e80f31bac7",
|
|
||||||
strip_prefix = "rules_esbuild-0.14.4",
|
|
||||||
url = "https://github.com/aspect-build/rules_esbuild/releases/download/v0.14.4/rules_esbuild-v0.14.4.tar.gz",
|
|
||||||
)
|
|
||||||
|
|
||||||
# Register a toolchain containing esbuild npm package and native bindings
|
|
||||||
load("@aspect_rules_esbuild//esbuild:repositories.bzl", "LATEST_VERSION", "esbuild_register_toolchains")
|
|
||||||
|
|
||||||
esbuild_register_toolchains(
|
|
||||||
name = "esbuild",
|
|
||||||
esbuild_version = LATEST_VERSION,
|
|
||||||
)
|
|
||||||
@@ -1,28 +0,0 @@
|
|||||||
import assert from 'assert'
|
|
||||||
import * as flatbuffers from 'flatbuffers'
|
|
||||||
|
|
||||||
import two_cjs from './two_generated.cjs'
|
|
||||||
|
|
||||||
const bazel_repository_test = two_cjs.bazel_repository_test;
|
|
||||||
|
|
||||||
function main() {
|
|
||||||
// Validate building a table with a table field.
|
|
||||||
var fbb = new flatbuffers.Builder(1);
|
|
||||||
|
|
||||||
bazel_repository_test.One.startOne(fbb);
|
|
||||||
bazel_repository_test.One.addInformation(fbb, 42);
|
|
||||||
var one = bazel_repository_test.One.endOne(fbb);
|
|
||||||
|
|
||||||
bazel_repository_test.Two.startTwo(fbb);
|
|
||||||
bazel_repository_test.Two.addOne(fbb, one);
|
|
||||||
var two = bazel_repository_test.Two.endTwo(fbb);
|
|
||||||
|
|
||||||
fbb.finish(two);
|
|
||||||
|
|
||||||
// Call as a sanity check. Would be better to validate actual output here.
|
|
||||||
fbb.asUint8Array();
|
|
||||||
|
|
||||||
console.log('FlatBuffers bazel repository test: completed successfully');
|
|
||||||
}
|
|
||||||
|
|
||||||
main();
|
|
||||||
@@ -1,7 +0,0 @@
|
|||||||
namespace bazel_repository_test;
|
|
||||||
|
|
||||||
table One {
|
|
||||||
information:int;
|
|
||||||
}
|
|
||||||
|
|
||||||
root_type One;
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "bazel_repository_test",
|
|
||||||
"type": "module",
|
|
||||||
"private": true,
|
|
||||||
"devDependencies": {
|
|
||||||
"@types/node": "18.15.11"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
12
tests/ts/bazel_repository_test_dir/pnpm-lock.yaml
generated
12
tests/ts/bazel_repository_test_dir/pnpm-lock.yaml
generated
@@ -1,12 +0,0 @@
|
|||||||
lockfileVersion: '6.0'
|
|
||||||
|
|
||||||
devDependencies:
|
|
||||||
'@types/node':
|
|
||||||
specifier: 18.15.11
|
|
||||||
version: 18.15.11
|
|
||||||
|
|
||||||
packages:
|
|
||||||
|
|
||||||
/@types/node@18.15.11:
|
|
||||||
resolution: {integrity: sha512-E5Kwq2n4SbMzQOn6wnmBjuK9ouqlURrcZDVfbo9ftDDTFt3nk7ZKK4GMOzoYgnpQJKcxwQw+lGaBvvlMo0qN/Q==}
|
|
||||||
dev: true
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
include 'one.fbs';
|
|
||||||
|
|
||||||
namespace bazel_repository_test;
|
|
||||||
|
|
||||||
table Two {
|
|
||||||
one:One;
|
|
||||||
}
|
|
||||||
|
|
||||||
root_type Two;
|
|
||||||
@@ -1,6 +1,7 @@
|
|||||||
{
|
{
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"@grpc/grpc-js": "^1.7.0",
|
||||||
"flatbuffers": "../../"
|
"flatbuffers": "../../"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
load("@aspect_rules_js//js:defs.bzl", "js_test")
|
|
||||||
load("//:typescript.bzl", "flatbuffer_ts_library")
|
load("//:typescript.bzl", "flatbuffer_ts_library")
|
||||||
|
|
||||||
flatbuffer_ts_library(
|
flatbuffer_ts_library(
|
||||||
@@ -13,14 +12,3 @@ flatbuffer_ts_library(
|
|||||||
visibility = ["//visibility:public"],
|
visibility = ["//visibility:public"],
|
||||||
deps = [":typescript_transitive_ts_fbs"],
|
deps = [":typescript_transitive_ts_fbs"],
|
||||||
)
|
)
|
||||||
|
|
||||||
js_test(
|
|
||||||
name = "import_test",
|
|
||||||
chdir = package_name(),
|
|
||||||
data = [
|
|
||||||
"package.json",
|
|
||||||
":include_ts_fbs",
|
|
||||||
"//:node_modules/flatbuffers",
|
|
||||||
],
|
|
||||||
entry_point = "import_test.js",
|
|
||||||
)
|
|
||||||
|
|||||||
@@ -1,31 +0,0 @@
|
|||||||
import assert from 'assert'
|
|
||||||
import * as flatbuffers from 'flatbuffers'
|
|
||||||
|
|
||||||
import typescript_include from './typescript_include_generated.cjs'
|
|
||||||
|
|
||||||
const foobar = typescript_include.foobar;
|
|
||||||
|
|
||||||
function main() {
|
|
||||||
// Validate the enums.
|
|
||||||
assert.strictEqual(foobar.Abc.a, 0);
|
|
||||||
assert.strictEqual(foobar.class_.arguments_, 0);
|
|
||||||
|
|
||||||
// Validate building a table.
|
|
||||||
var fbb = new flatbuffers.Builder(1);
|
|
||||||
var name = fbb.createString("Foo Bar");
|
|
||||||
|
|
||||||
foobar.Tab.startTab(fbb);
|
|
||||||
foobar.Tab.addAbc(fbb, foobar.Abc.a);
|
|
||||||
foobar.Tab.addArg(fbb, foobar.class_.arguments_);
|
|
||||||
foobar.Tab.addName(fbb, name);
|
|
||||||
var tab = foobar.Tab.endTab(fbb);
|
|
||||||
|
|
||||||
fbb.finish(tab);
|
|
||||||
|
|
||||||
// Call as a sanity check. Would be better to validate actual output here.
|
|
||||||
fbb.asUint8Array();
|
|
||||||
|
|
||||||
console.log('FlatBuffers Bazel Import test: completed successfully');
|
|
||||||
}
|
|
||||||
|
|
||||||
main();
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
{
|
|
||||||
"type": "module",
|
|
||||||
"dependencies": {
|
|
||||||
"flatbuffers": "../../../"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,13 +1,6 @@
|
|||||||
include 'typescript_transitive_include.fbs';
|
include 'typescript_transitive_include.fbs';
|
||||||
|
|
||||||
namespace foobar;
|
namespace foobar;
|
||||||
|
|
||||||
enum class: int {
|
enum class: int {
|
||||||
arguments,
|
arguments,
|
||||||
}
|
}
|
||||||
|
|
||||||
table Tab {
|
|
||||||
abc:Abc;
|
|
||||||
arg:class;
|
|
||||||
name:string;
|
|
||||||
}
|
|
||||||
|
|||||||
@@ -1,23 +1,5 @@
|
|||||||
load("@aspect_rules_ts//ts:defs.bzl", "ts_project")
|
load("@npm//@bazel/typescript:index.bzl", "ts_project")
|
||||||
load("@aspect_rules_js//npm:defs.bzl", "npm_package")
|
load("@build_bazel_rules_nodejs//:index.bzl", "js_library")
|
||||||
|
|
||||||
filegroup(
|
|
||||||
name = "distribution",
|
|
||||||
srcs = [
|
|
||||||
"BUILD.bazel",
|
|
||||||
"compile_flat_file.sh",
|
|
||||||
] + glob([
|
|
||||||
"*.ts",
|
|
||||||
]),
|
|
||||||
visibility = ["//visibility:public"],
|
|
||||||
)
|
|
||||||
|
|
||||||
# Add an index to emulate the top-level package.json's "main" entry.
|
|
||||||
genrule(
|
|
||||||
name = "generate_index.ts",
|
|
||||||
outs = ["index.ts"],
|
|
||||||
cmd = """echo "export * from './flatbuffers.js'" > $(OUTS)""",
|
|
||||||
)
|
|
||||||
|
|
||||||
ts_project(
|
ts_project(
|
||||||
name = "flatbuffers_ts",
|
name = "flatbuffers_ts",
|
||||||
@@ -29,7 +11,6 @@ ts_project(
|
|||||||
"flatbuffers.ts",
|
"flatbuffers.ts",
|
||||||
"types.ts",
|
"types.ts",
|
||||||
"utils.ts",
|
"utils.ts",
|
||||||
":index.ts",
|
|
||||||
],
|
],
|
||||||
declaration = True,
|
declaration = True,
|
||||||
tsconfig = {
|
tsconfig = {
|
||||||
@@ -47,19 +28,14 @@ ts_project(
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
visibility = ["//visibility:public"],
|
visibility = ["//visibility:public"],
|
||||||
deps = [
|
deps = ["@npm//@types/node"],
|
||||||
# Because the main repository instantiates the @npm repository, we need
|
|
||||||
# to depend on the main repository's node import.
|
|
||||||
"@//:node_modules/@types/node",
|
|
||||||
],
|
|
||||||
)
|
)
|
||||||
|
|
||||||
npm_package(
|
js_library(
|
||||||
name = "flatbuffers",
|
name = "flatbuffers",
|
||||||
srcs = [":flatbuffers_ts"],
|
package_name = "flatbuffers",
|
||||||
include_external_repositories = ["*"],
|
|
||||||
package = "flatbuffers",
|
|
||||||
visibility = ["//visibility:public"],
|
visibility = ["//visibility:public"],
|
||||||
|
deps = [":flatbuffers_ts"],
|
||||||
)
|
)
|
||||||
|
|
||||||
sh_binary(
|
sh_binary(
|
||||||
@@ -68,6 +44,7 @@ sh_binary(
|
|||||||
data = [
|
data = [
|
||||||
"@com_github_google_flatbuffers//:flatc",
|
"@com_github_google_flatbuffers//:flatc",
|
||||||
"@nodejs_linux_amd64//:node_bin",
|
"@nodejs_linux_amd64//:node_bin",
|
||||||
|
"@npm//esbuild/bin:esbuild",
|
||||||
],
|
],
|
||||||
# We just depend directly on the linux amd64 nodejs binary, so only support
|
# We just depend directly on the linux amd64 nodejs binary, so only support
|
||||||
# running this script on amd64 for now.
|
# running this script on amd64 for now.
|
||||||
|
|||||||
@@ -14,9 +14,10 @@ source "${RUNFILES_DIR:-/dev/null}/$f" 2>/dev/null || \
|
|||||||
source "$(grep -sm1 "^$f " "$0.exe.runfiles_manifest" | cut -f2- -d' ')" 2>/dev/null || \
|
source "$(grep -sm1 "^$f " "$0.exe.runfiles_manifest" | cut -f2- -d' ')" 2>/dev/null || \
|
||||||
{ echo>&2 "ERROR: cannot find $f"; exit 1; }; f=; set -e
|
{ echo>&2 "ERROR: cannot find $f"; exit 1; }; f=; set -e
|
||||||
# --- end runfiles.bash initialization v2 ---
|
# --- end runfiles.bash initialization v2 ---
|
||||||
set -eu
|
set -e
|
||||||
runfiles_export_envvars
|
runfiles_export_envvars
|
||||||
FLATC=$(rlocation com_github_google_flatbuffers/flatc)
|
FLATC=$(rlocation com_github_google_flatbuffers/flatc)
|
||||||
|
ESBUILD=$(rlocation npm/node_modules/esbuild/bin/esbuild)
|
||||||
TS_FILE=$(${FLATC} $@ | grep "Entry point.*generated" | grep -o "bazel-out.*ts")
|
TS_FILE=$(${FLATC} $@ | grep "Entry point.*generated" | grep -o "bazel-out.*ts")
|
||||||
export PATH="$(rlocation nodejs_linux_amd64/bin/nodejs/bin):${PATH}"
|
export PATH=$(rlocation nodejs_linux_amd64/bin/nodejs/bin)
|
||||||
${ESBUILD_BIN} ${TS_FILE} --format=cjs --bundle --outfile="${OUTPUT_FILE}" --external:flatbuffers --log-level=warning
|
${ESBUILD} ${TS_FILE} --format=cjs --bundle --outfile="${OUTPUT_FILE}" --external:flatbuffers --log-level=warning
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
Rules for building typescript flatbuffers with Bazel.
|
Rules for building typescript flatbuffers with Bazel.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
load("@aspect_rules_js//js:defs.bzl", "js_library")
|
load("@build_bazel_rules_nodejs//:index.bzl", "js_library")
|
||||||
load(":build_defs.bzl", "flatbuffer_library_public")
|
load(":build_defs.bzl", "flatbuffer_library_public")
|
||||||
|
|
||||||
DEFAULT_FLATC_TS_ARGS = [
|
DEFAULT_FLATC_TS_ARGS = [
|
||||||
@@ -24,7 +24,8 @@ def flatbuffer_ts_library(
|
|||||||
flatc_args = DEFAULT_FLATC_TS_ARGS,
|
flatc_args = DEFAULT_FLATC_TS_ARGS,
|
||||||
visibility = None,
|
visibility = None,
|
||||||
restricted_to = None,
|
restricted_to = None,
|
||||||
gen_reflections = False):
|
gen_reflections = False,
|
||||||
|
package_name = None):
|
||||||
"""Generates a ts_library rule for a given flatbuffer definition.
|
"""Generates a ts_library rule for a given flatbuffer definition.
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
@@ -45,6 +46,7 @@ def flatbuffer_ts_library(
|
|||||||
to use.
|
to use.
|
||||||
gen_reflections: Optional, if true this will generate the flatbuffer
|
gen_reflections: Optional, if true this will generate the flatbuffer
|
||||||
reflection binaries for the schemas.
|
reflection binaries for the schemas.
|
||||||
|
package_name: Optional, Package name to use for the generated code.
|
||||||
"""
|
"""
|
||||||
srcs_lib = "%s_srcs" % (name)
|
srcs_lib = "%s_srcs" % (name)
|
||||||
out_base = [s.replace(".fbs", "").split("/")[-1].split(":")[-1] for s in srcs]
|
out_base = [s.replace(".fbs", "").split("/")[-1].split(":")[-1] for s in srcs]
|
||||||
@@ -62,7 +64,6 @@ def flatbuffer_ts_library(
|
|||||||
language_flag = "--ts",
|
language_flag = "--ts",
|
||||||
includes = includes,
|
includes = includes,
|
||||||
include_paths = include_paths,
|
include_paths = include_paths,
|
||||||
extra_env = "ESBUILD_BIN=$(ESBUILD_BIN)",
|
|
||||||
flatc_args = flatc_args + ["--filename-suffix _generated"],
|
flatc_args = flatc_args + ["--filename-suffix _generated"],
|
||||||
compatible_with = compatible_with,
|
compatible_with = compatible_with,
|
||||||
restricted_to = restricted_to,
|
restricted_to = restricted_to,
|
||||||
@@ -70,8 +71,6 @@ def flatbuffer_ts_library(
|
|||||||
reflection_visibility = visibility,
|
reflection_visibility = visibility,
|
||||||
target_compatible_with = target_compatible_with,
|
target_compatible_with = target_compatible_with,
|
||||||
flatc_path = "@com_github_google_flatbuffers//ts:compile_flat_file",
|
flatc_path = "@com_github_google_flatbuffers//ts:compile_flat_file",
|
||||||
toolchains = ["@aspect_rules_esbuild//esbuild:resolved_toolchain"],
|
|
||||||
tools = ["@aspect_rules_esbuild//esbuild:resolved_toolchain"],
|
|
||||||
)
|
)
|
||||||
js_library(
|
js_library(
|
||||||
name = name,
|
name = name,
|
||||||
@@ -80,6 +79,7 @@ def flatbuffer_ts_library(
|
|||||||
restricted_to = restricted_to,
|
restricted_to = restricted_to,
|
||||||
target_compatible_with = target_compatible_with,
|
target_compatible_with = target_compatible_with,
|
||||||
srcs = outs,
|
srcs = outs,
|
||||||
|
package_name = package_name,
|
||||||
)
|
)
|
||||||
native.filegroup(
|
native.filegroup(
|
||||||
name = "%s_includes" % (name),
|
name = "%s_includes" % (name),
|
||||||
|
|||||||
Reference in New Issue
Block a user