sbt 2.0 の変更点
互換性に影響のある変更点
- Scala 3 in metabuild. sbt 2.x build.sbt DSL, used for build definitions and plugins, is based on Scala 3.x (currently 3.8.1) (Both sbt 1.x and 2.x are capable of building Scala 2.x and 3.x) by @eed3si9n, @adpi2, and others.
- コモン・セッティング。build.sbt に直書きされたセッティングは、ルートサブプロジェクトだけではなく、全てのサブプロジェクトに追加され、これまで
ThisBuildが受け持ってきた役目を果たすことができる。 - 差分テスト。
testは、テスト結果をキャッシュする差分テストへと変更された。全テストを走らせたい場合はtestFullを使う by @eed3si9n in #7686 - キャッシュ化されたタスク。全てのタスクはデフォルトで、キャッシュ化されている。詳細はキャッシュ化を参照。
- 依存性のツリー表示。
dependencyTree関連のタスク群は 1つのインプット・タスクに統一された by @eed3si9n in #8199 testタスクの形がUnitからTestResultへと変更された by @eed3si9n in #8181- 以前
URLに型付けされていたデフォルトのセッティングやタスクキー (apiMappings,apiURL,homepage,organizationHomepage,releaseNotesURLなど) はURIに変更された in #7927 licenseキーの型がSeq[(String, URL)]からSeq[License]へと変更された in #7927- sbt 2.x プラグインは
_sbt2_3という suffix を用いて公開される by @eed3si9n in #7671 - sbt 2.x は、
platformセッティングを追加して、ModuleIDの%%%演算子を使わなくても、%%演算子だけで JVM、JS、Native のクロスビルドができるようにした by @eed3si9n in #6746 useCoursierセッティングを廃止して、Coursier をオプトアウトできないようにした by @eed3si9n in #7712Key.Classpath型は、Seq[Attributed[File]]からSeq[Attributed[xsbti.HashedVirtualFileRef]]型のへのエイリアスへと変更された。同様に、以前Fileを返していたタスクキーのいくつかはHashedVirtualFileRefを返すように変更された。ファイルのキャッシュ化も参照。- In sbt 2.x
targetdefaults totarget/out/jvm/scala-3.8.1/<subproject>/, as opposed to<subproject>/target/. - sbt 2.x は
build.sbtに変更があると、デフォルトで自動的リロードされるようになった @eed3si9n in #8211 - 自動的タスク集約を行う
Project#autoAggregateが追加された @eed3si9n in #8290
勧告どおり廃止された機能
新機能
- project matrix。sbt 1.x からプラグインで使用可能だった project matrix が本体に取り込まれ、並列クロスビルドができるようになった。
- sbt クエリ。sbt 2.x は統一スラッシュ構文を拡張してサブプロジェクトのクエリを可能とする。詳細は下記参照。
- ローカル/リモート兼用のキャッシュ・システム。詳細は下記参照。
- クライアントサイド・ラン。詳細は下記参照。
コモン・セッティング
sbt 2.x では、build.sbt に直書きされたセッティングはコモン・セッティングとして解釈され、全サブプロジェクトに注入される。そのため、ThisBuild スコープ付けを使わずに scalaVersion を設定できる:
scalaVersion := "3.8.1"
さらに、これはいわゆる動的ディスパッチ問題を解決する:
lazy val hi = taskKey[String]("")
hi := name.value + "!"
sbt 1.x では hi タスクはルートプロジェクトの名前を捕捉してしまっていたが、sbt 2.x は各サブプロジェクトの name に ! を追加する:
$ sbt show hi
[info] entering *experimental* thin client - BEEP WHIRR
[info] terminate the server with `shutdown`
> show hi
[info] foo / hi
[info] foo!
[info] hi
[info] root!
これは、@eed3si9n によって #6746 としてコントリされた。
sbt クエリ
サブプロジェクトが複数あるとき、選択範囲を狭めるのに sbt 2.x は sbt クエリを導入する。
$ sbt foo.../test
上の例では、foo から始まる全てのサブプロジェクトを実行する。
$ sbt ...@scalaBinaryVersion=3/test
上の例では、scalaBinaryVersion が 3 の全てのサブプロジェクトを実行する。これは、@eed3si9n によって #7699 としてコントリされた。
差分テスト
sbt 2.x では、test タスクはインプット・タスクとなって、実行するテスト・スイートをフィルターできるようになった:
> test *Example*
さらに、test はキャッシュ化された差分テストとなった。そのため、以前にテストが失敗したか、前回の実行から何かが変更されないと実行されないようになった。
詳細はtestを参照
ローカル/リモート兼用のキャッシュ・システム
sbt 2.x は、デフォルトでキャッシュ化されたタスクを実装するため、自動的にタスクの結果をローカルのディスクもしくは Bazel 互換のリモートキャッシュにてキャッシュ化することができる。
lazy val task1 = taskKey[String]("doc for task1")
task1 := name.value + version.value + "!"
これは task1 への入力を追跡してマシン・ワイドなディスクキャッシュを作成する。これはリモート・キャッシュとしても設定できるようになっている。sbt タスクはファイルを生成することがよくあるので、ファイルのコンテンツをキャッシュ化できる仕組みも提供する。
lazy val task1 = taskKey[String]("doc for task1")
task1 := {
val converter = fileConverter.value
....
val output = converter.toVirtualFile(somefile)
Def.declareOutput(output)
name.value + version.value + "!"
}
詳細はキャッシュ化を参照。これは @eed3si9n によって #7464 / #7525 としてコントリされた。
クライアントサイド・ラン
sbt runner 1.10.10 以降は sbt 2.x を起動するのに、デフォルトで sbtn (GraalVM native-image のクライアント) を使う。sbt 2.0 は run タスクを sbtn に送り返して、sbtn 側で新しい JVM にフォークさせる。以下のように実行するだけでいい:
sbt run
これは、sbt server をブロックしてしまうことを回避し、かつ複数の実行を行うことができる。これは @eed3si9n によって#8060 としてコントリされた。run ドキュメンテーション参照。
性能の改善
Adrien Piquerez さんが Scala Center に在籍していたときに、性能改善に関連するコントリをいくつか行った。
- perf: 長生きするオブジェクトの数を削減して、2.0.0-M2 比較で起動を 20% 高速化した by @adpi2 in #7866
- perf:
SettingとInitializeが作成される数を削減した by @adpi2 in #7880 - perf:
Settingsをリファクタリングして、集約キーのインデックス化を最適化した @adpi2 in #7879 - perf:
InfoとBasicAttributeMapのインスタンスを削除した by @adpi2 in #7882
過去の変更点
以下も参照: