로컬 저장소 규칙

문제 신고하기 소스 보기

다음 함수는 @bazel_tools//tools/build_defs/repo:local.bzl에서 로드할 수 있습니다.

로컬 파일 시스템에서 디렉터리를 저장소로 사용하기 위한 규칙입니다.

설정

이러한 규칙을 모듈 확장 프로그램에서 사용하려면 .bzl 파일에 로드한 다음 확장 프로그램의 구현 함수에서 규칙을 호출하세요. 예를 들어 local_repository를 사용하려면 다음을 실행합니다.

load("@bazel_tools//tools/build_defs/repo:local.bzl", "local_repository")

def _my_extension_impl(mctx):
  local_repository(name = "foo", path = "foo")

my_extension = module_extension(implementation = _my_extension_impl)

또는 use_repo_rule를 사용하여 MODULE.bazel 파일에서 이러한 저장소 규칙을 직접 호출할 수 있습니다.

local_repository = use_repo_rule("@bazel_tools//tools/build_defs/repo:local.bzl", "local_repository")
local_repository(name = "foo", path = "foo")

local_repository

local_repository(name, path, repo_mapping)

Bazel 파일이 이미 포함된 로컬 디렉터리를 저장소로 제공합니다. 이 디렉터리에는 Bazel BUILD 파일과 저장소 경계 파일이 이미 포함되어 있습니다. 이러한 파일이 포함되어 있지 않으면 <a href="#new_local_repository"><code>new_local_repository</code></a>를 대신 사용해 보세요.

특성

name 이름. 필수 항목입니다.

이 저장소의 고유한 이름입니다.

path 문자열, 필수

저장소로 제공할 디렉터리의 경로입니다.

경로는 절대적이거나 작업공간 루트를 기준으로 할 수 있습니다.

repo_mapping 사전: 문자열 -> 문자열, 필수

로컬 저장소 이름에서 전역 저장소 이름으로의 사전입니다. 이렇게 하면 이 저장소의 종속 항목에 대한 작업공간 종속 항목 해결을 제어할 수 있습니다.

예를 들어 항목"@foo": "@bar"`는 이 저장소가 항상 `@foo`에 종속될 때마다 (예: `@foo//some:target`의 종속 항목) 전역적으로 선언된 `@bar` (`@bar//some:target`) 내에서 이 종속 항목을 실제로 해결해야 한다고 선언합니다.

new_local_repository

new_local_repository(name, build_file, build_file_content, path, repo_mapping)

Bazel 파일이 포함되지 않은 로컬 디렉터리를 저장소로 제공합니다. 이 디렉터리에는 Bazel BUILD 파일이나 저장소 경계 파일이 포함되지 않아도 됩니다. 이 저장소 규칙으로 생성됩니다. 디렉터리에 Bazel 파일이 이미 포함되어 있으면 <a href="#local_repository"><code>local_repository</code></a>를 대신 사용해 보세요.

특성

name 이름. 필수 항목입니다.

이 저장소의 고유한 이름입니다.

build_file 라벨, 선택사항

이 저장소의 BUILD 파일로 사용할 파일입니다.

build_filebuild_file_content 중 정확히 하나를 지정해야 합니다.

이 라벨로 주소를 지정하는 파일은 이름을 BUILD로 지정할 필요가 없지만 그렇게 할 수 있습니다. BUILD.new-repo-name와 같은 것이 실제 BUILD 파일과 구별하는 데 적합할 수 있습니다.

build_file_content 문자열, 선택사항

이 저장소용으로 만들 BUILD 파일의 콘텐츠입니다.

build_filebuild_file_content 중 정확히 하나를 지정해야 합니다.

path 문자열, 필수

저장소로 제공할 디렉터리의 경로입니다.

경로는 절대적이거나 작업공간 루트를 기준으로 할 수 있습니다.

repo_mapping 사전: 문자열 -> 문자열, 필수

로컬 저장소 이름에서 전역 저장소 이름으로의 사전입니다. 이렇게 하면 이 저장소의 종속 항목에 대한 작업공간 종속 항목 해결을 제어할 수 있습니다.

예를 들어 항목"@foo": "@bar"`는 이 저장소가 항상 `@foo`에 종속될 때마다 (예: `@foo//some:target`의 종속 항목) 전역적으로 선언된 `@bar` (`@bar//some:target`) 내에서 이 종속 항목을 실제로 해결해야 한다고 선언합니다.