SAM-with-receiverコンパイラプラグイン
sam-with-receiver コンパイラプラグインは、アノテーションが付与されたJavaの「単一抽象メソッド」(SAM)インターフェースのメソッドの最初のパラメータを、Kotlinにおけるレシーバーにします。この変換は、SAMインターフェースがKotlinラムダとして渡される場合にのみ機能し、SAMアダプターとSAMコンストラクターの両方に適用されます(詳細は SAM変換のドキュメント を参照してください)。
以下に例を示します:
java
public @interface SamWithReceiver {}
@SamWithReceiver
public interface TaskRunner {
void run(Task task);
}kotlin
fun test(context: TaskContext) {
val runner = TaskRunner {
// ここで 'this' は 'Task' のインスタンスです
println("$name is started")
context.executeTask(this)
println("$name is finished")
}
}Gradle
使用方法は all-open や no-arg と同様ですが、sam-with-receiver には組み込みのプリセットがなく、特別に処理するアノテーションのリストを独自に指定する必要がある点が異なります。
kotlin
plugins {
kotlin("plugin.sam.with.receiver") version "2.3.0"
}groovy
plugins {
id "org.jetbrains.kotlin.plugin.sam.with.receiver" version "2.3.0"
}次に、SAM-with-receiverアノテーションのリストを指定します:
groovy
samWithReceiver {
annotation("com.my.SamWithReceiver")
}Maven
xml
<plugin>
<artifactId>kotlin-maven-plugin</artifactId>
<groupId>org.jetbrains.kotlin</groupId>
<version>${kotlin.version}</version>
<configuration>
<compilerPlugins>
<plugin>sam-with-receiver</plugin>
</compilerPlugins>
<pluginOptions>
<option>
sam-with-receiver:annotation=com.my.SamWithReceiver
</option>
</pluginOptions>
</configuration>
<dependencies>
<dependency>
<groupId>org.jetbrains.kotlin</groupId>
<artifactId>kotlin-maven-sam-with-receiver</artifactId>
<version>${kotlin.version}</version>
</dependency>
</dependencies>
</plugin>コマンドラインコンパイラ
コンパイラプラグインのクラスパスにプラグインのJARファイルを追加し、sam-with-receiverアノテーションのリストを指定します:
bash
-Xplugin=$KOTLIN_HOME/lib/sam-with-receiver-compiler-plugin.jar
-P plugin:org.jetbrains.kotlin.samWithReceiver:annotation=com.my.SamWithReceiver