From 6bcc74ea791c2e499456295efd97df665d184a43 Mon Sep 17 00:00:00 2001 From: Guillaume Bouchard Date: Fri, 21 Feb 2020 18:05:33 +0100 Subject: [PATCH] Only create BUILD file if needed If the nix derivation already contains a BUILD file, we won't create it. This allows a workflow where the nix derivation is bazel aware and provides a BUILD file suited for its content. In this case, using the default BUILD file leads to a failure. --- nixpkgs/nixpkgs.bzl | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/nixpkgs/nixpkgs.bzl b/nixpkgs/nixpkgs.bzl index 96d9b950c..28262a15d 100644 --- a/nixpkgs/nixpkgs.bzl +++ b/nixpkgs/nixpkgs.bzl @@ -74,6 +74,10 @@ def _nixpkgs_package_impl(repository_ctx): elif repository: repositories = {repository_ctx.attr.repository: "nixpkgs"} + # If true, a BUILD file will be created from a template if it does not + # exits. + # However this will happen AFTER the nix-build command. + create_build_file_if_needed = False if repository_ctx.attr.build_file and repository_ctx.attr.build_file_content: fail("Specify one of 'build_file' or 'build_file_content', but not both.") elif repository_ctx.attr.build_file: @@ -81,7 +85,8 @@ def _nixpkgs_package_impl(repository_ctx): elif repository_ctx.attr.build_file_content: repository_ctx.file("BUILD", content = repository_ctx.attr.build_file_content) else: - repository_ctx.template("BUILD", Label("@io_tweag_rules_nixpkgs//nixpkgs:BUILD.pkg")) + # No user supplied build file, we may create the default one. + create_build_file_if_needed = True strFailureImplicitNixpkgs = ( "One of 'repositories', 'nix_file' or 'nix_file_content' must be provided. " + @@ -176,6 +181,13 @@ def _nixpkgs_package_impl(repository_ctx): basename = target.rpartition("/")[-1] repository_ctx.symlink(target, basename) + # Create a default BUILD file only if it does not exists and is not + # provided by `build_file` or `build_file_content`. + if create_build_file_if_needed: + p = repository_ctx.path("BUILD") + if not p.exists: + repository_ctx.template("BUILD", Label("@io_tweag_rules_nixpkgs//nixpkgs:BUILD.pkg")) + _nixpkgs_package = repository_rule( implementation = _nixpkgs_package_impl, attrs = {