Starlark 로드맵

문제 신고 소스 보기 Nightly · 8.0 7.4 . 7.3 · 7.2 · 7.1 · 7.0 · 6.5

최종 확인: 2020년 4월 21일(업데이트 내역)

담당자: 로랑르블

목표

Google의 목표는 Bazel의 확장성을 높이는 것입니다. 사용자는 자체 규칙을 쉽게 구현하고 새로운 언어와 도구를 지원할 수 있어야 합니다. Google은 이러한 규칙을 작성하고 유지 관리하는 환경을 개선하고자 합니다.

Google은 다음 두 가지 영역에 중점을 둡니다.

  • 언어와 API를 간단하면서도 강력하게 만듭니다.
  • 코드 읽기, 쓰기, 업데이트, 디버깅, 테스트를 위한 더 나은 도구를 제공합니다.

2020년 2분기

빌드 상태 및 권장사항:

  • P0. 이름이 없는 매크로는 권장하지 않으며 이름이 고유한 문자열 리터럴인지 확인합니다. 이 작업은 Google 코드베이스에 중점을 두지만 공개적으로 사용 가능한 도구에도 영향을 줄 수 있습니다.
  • P0. 선택 항목 및 변수와 관련하여 Buildozer 명령어를 안정적으로 만듭니다.
  • P1. Buildifier가 주석으로 인해 정렬하지 않는 목록에서 중복을 삭제하도록 합니다.
  • P1. Buildifier 린터를 업데이트하여 사소한 표현식의 인라인화를 권장합니다.
  • P2. native.existing_rules의 사용 사례를 연구하고 대안을 제안합니다.
  • P2. 프렐류드 파일의 사용 사례를 연구하고 대안을 제안합니다.

성능:

  • P1. 평면 환경과 바이트코드 컴파일을 사용하여 Starlark 인터프리터를 최적화합니다.

기술 부채 감소:

  • P0. @bazel_tools 아래에서 네이티브 기호를 Starlark로 포팅하는 기능을 추가했습니다.
  • P1. 더 이상 사용되지 않는 플래그를 삭제합니다 (일부는 Google에서 계속 사용되므로 먼저 코드베이스를 정리해야 함). incompatible_always_check_depset_elements, incompatible_disable_deprecated_attr_params, incompatible_no_support_tools_in_action_inputs, incompatible_new_actions_api
  • P1. Bazel 4.0에서 다음 플래그를 전환할 수 있는지 확인합니다. incompatible_disable_depset_items, incompatible_no_implicit_file_export, incompatible_run_shell_command_string, incompatible_restrict_string_escapes
  • P1. lib.syntax 작업 (API 정리, Bazel과의 분리)을 완료합니다.
  • P2. Bazel의 Java 패키지에 대한 사소한 수정의 빌드 + 테스트 지연 시간을 50% 줄입니다.

커뮤니티:

  • rules_python 커뮤니티에서 활발하게 운영하고 잘 관리하고 있습니다.
  • rules_jvm_external에 대한 지속적인 지원 (대기 중인 풀 리퀘스트, 문제 분류, 출시 없음)
  • Bazel 문서 인프라 유지관리: bazel-website, bazel-blog, docs에서 CSS 스타일을 중앙 집중화하고 표준화
  • Bazel 문서: 회귀를 방지하기 위해 e2e 문서 사이트 빌드용 CI 테스트를 추가했습니다.

2020년 1분기

빌드 상태 및 권장사항:

  • bazel query를 통한 내보내기를 위해 타겟이 매크로 호출 스택을 추적하도록 허용
  • --incompatible_no_implicit_file_export 구현
  • 지원 중단된 depset API (#5817, #10313, #9017)를 삭제합니다.
  • Buildifier에 교차 파일 분석 도구를 추가하고 지원 중단된 함수 검사를 구현합니다.

성능:

  • Bazel 자체 Java 기반 테스트를 2배 더 빠르게 실행합니다.
  • Starlark CPU 프로파일러를 구현합니다.

기술 부채 감소:

  • 호환되지 않는 8개의 플래그를 삭제합니다 (플립한 후).
  • lib.syntax 정리 작업을 완료합니다 (종속 항목 중단).
  • Starlark 최적화: 평면 환경, 바이트 코드 컴파일
  • 가능한 경우 분석 단계에서 모든 직렬화를 삭제합니다.
  • lib.packages 간소화/최적화 계획 수립

커뮤니티:

  • 모든 Bazel 관련 용어의 정의가 포함된 용어집 게시