14 system = stdenv.hostPlatform.system;
16 buildBazelPackage rec {
19 # These environment variables are read in bazel/build-version.py to create
20 # a build string shown in the tools --version output.
21 # If env variables not set, it would attempt to extract it from .git/.
22 GIT_DATE = "2024-10-16";
23 GIT_VERSION = "v0.0-3836-g86ee9bab";
25 # Derive nix package version from GIT_VERSION: "v1.2-345-abcde" -> "1.2.345"
26 version = builtins.concatStringsSep "." (
27 lib.take 3 (lib.drop 1 (builtins.splitVersion GIT_VERSION))
30 src = fetchFromGitHub {
31 owner = "chipsalliance";
33 rev = "${GIT_VERSION}";
34 hash = "sha256-hV02x0b/taBqa6kyy3gvm3lomJrXBeelAbxrkC0s6EU=";
39 "--//bazel:use_local_flex_bison"
43 hash = "sha256-bKASgc5KftCWtMvJkGA4nweBAtgdnyC9uXIJxPjKYS0=";
47 jdk # bazel uses that.
48 bison # We use local flex and bison as WORKSPACE sources fail
49 flex # .. to compile with newer glibc
55 bazel/build-version.py \
56 bazel/sh_test_with_runfiles_lib.sh \
57 common/lsp/dummy-ls_test.sh \
58 common/tools/patch_tool_test.sh \
59 common/tools/verible-transform-interactive.sh \
60 common/tools/verible-transform-interactive-test.sh \
65 removeRulesCC = false;
66 bazelTargets = [ ":install-binaries" ];
67 bazelBuildFlags = [ "-c opt" ];
70 bazelTestTargets = [ "//..." ];
71 bazelTestFlags = [ "-c opt" ];
77 install bazel-bin/common/tools/verible-patch-tool "$out/bin"
79 V_TOOLS_DIR=bazel-bin/verilog/tools
80 install $V_TOOLS_DIR/diff/verible-verilog-diff "$out/bin"
81 install $V_TOOLS_DIR/formatter/verible-verilog-format "$out/bin"
82 install $V_TOOLS_DIR/kythe/verible-verilog-kythe-extractor "$out/bin"
83 install $V_TOOLS_DIR/lint/verible-verilog-lint "$out/bin"
84 install $V_TOOLS_DIR/ls/verible-verilog-ls "$out/bin"
85 install $V_TOOLS_DIR/obfuscator/verible-verilog-obfuscate "$out/bin"
86 install $V_TOOLS_DIR/preprocessor/verible-verilog-preprocessor "$out/bin"
87 install $V_TOOLS_DIR/project/verible-verilog-project "$out/bin"
88 install $V_TOOLS_DIR/syntax/verible-verilog-syntax "$out/bin"
93 description = "Suite of SystemVerilog developer tools. Including a style-linter, indexer, formatter, and language server";
94 homepage = "https://github.com/chipsalliance/verible";
95 license = licenses.asl20;
96 maintainers = with maintainers; [
100 # Platforms linux only currently; some LIBTOOL issue on Darwin w/ bazel
101 platforms = platforms.linux;