Vavr 注释处理工具无法启动
Vavr annotation procession tool doesn't kick-in
我正在尝试从 here 复制一个简单的对象分解示例。我已将以下依赖项添加到我的项目中:
<dependency>
<groupId>io.vavr</groupId>
<artifactId>vavr</artifactId>
<version>${vavr.version}</version>
</dependency>
<dependency>
<groupId>io.vavr</groupId>
<artifactId>vavr-match</artifactId>
<version>${vavr.version}</version>
</dependency>
<dependency>
<groupId>io.vavr</groupId>
<artifactId>vavr-match-processor</artifactId>
<version>${vavr.version}</version>
</dependency>
...其中 vavr.version
是 0.10.3
并从上面的来源复制粘贴示例:
import io.vavr.Tuple;
import io.vavr.Tuple2;
import io.vavr.match.annotation.Patterns;
import io.vavr.match.annotation.Unapply;
import lombok.AllArgsConstructor;
import lombok.Getter;
import static io.vavr.API.$;
import static io.vavr.API.Match;
import static io.vavr.API.Match.*;
public class Example {
@Getter
@AllArgsConstructor
public static class Employee {
private String name;
private String id;
}
@Patterns
public static class Demo {
@Unapply
static Tuple2<String, String> Employee(Employee Employee) {
return Tuple.of(Employee.getName(), Employee.getId());
}
}
public static void main(String[] args) {
Employee person = new Employee("Carl", "89696D8");
String result = Match(person).of(
Case(Demo.Employee($("Carl"), $()), (name, id) -> ""),
Case($(), () -> "notfound")
);
}
}
然而,第一个 Case
产生了一个编译错误 Expected 1 argument but found 2
,这向我表明注释处理没有工作,并且没有生成相应的模式。如果我错了,请纠正我。
我正在使用 Intellij 2020.1 并在其中启用了注释处理
原因是您在此行中使用了生成的 class 的无效名称:
Case(Demo.Employee($("Carl"), $()), (name, id) -> "")
应替换为:
Case(Example_DemoPatterns.$Employee($("Carl"), $()), (name, id) -> name + " " + id)
因为 Demo
是一个静态嵌套的 class 它需要以 Example_
为前缀并且因为这是生成器的工作方式所以它需要以 Patterns
为后缀。
Here 是一个完整的、可构建的示例,您可以克隆并试用它。它包含 Maven 和 gradle 的示例。要验证它是如何工作的,请将提到的行更改为例如:
Case(Example_DemoPatternsWhatever.$Employee($("Carl"), $()), (name, id) -> name + " " + id)
然后 运行:
mvn exec:java
它失败了(没有这样的 class 生成)但是当你 运行 tree target/
你会得到类似的东西:
target
├── classes
├── generated-sources
│ └── annotations
│ └── Example_DemoPatterns.java
└── maven-status
└── maven-compiler-plugin
└── compile
└── default-compile
├── createdFiles.lst
└── inputFiles.lst
表示确实生成了class。这是您需要使用的class。
我正在尝试从 here 复制一个简单的对象分解示例。我已将以下依赖项添加到我的项目中:
<dependency>
<groupId>io.vavr</groupId>
<artifactId>vavr</artifactId>
<version>${vavr.version}</version>
</dependency>
<dependency>
<groupId>io.vavr</groupId>
<artifactId>vavr-match</artifactId>
<version>${vavr.version}</version>
</dependency>
<dependency>
<groupId>io.vavr</groupId>
<artifactId>vavr-match-processor</artifactId>
<version>${vavr.version}</version>
</dependency>
...其中 vavr.version
是 0.10.3
并从上面的来源复制粘贴示例:
import io.vavr.Tuple;
import io.vavr.Tuple2;
import io.vavr.match.annotation.Patterns;
import io.vavr.match.annotation.Unapply;
import lombok.AllArgsConstructor;
import lombok.Getter;
import static io.vavr.API.$;
import static io.vavr.API.Match;
import static io.vavr.API.Match.*;
public class Example {
@Getter
@AllArgsConstructor
public static class Employee {
private String name;
private String id;
}
@Patterns
public static class Demo {
@Unapply
static Tuple2<String, String> Employee(Employee Employee) {
return Tuple.of(Employee.getName(), Employee.getId());
}
}
public static void main(String[] args) {
Employee person = new Employee("Carl", "89696D8");
String result = Match(person).of(
Case(Demo.Employee($("Carl"), $()), (name, id) -> ""),
Case($(), () -> "notfound")
);
}
}
然而,第一个 Case
产生了一个编译错误 Expected 1 argument but found 2
,这向我表明注释处理没有工作,并且没有生成相应的模式。如果我错了,请纠正我。
我正在使用 Intellij 2020.1 并在其中启用了注释处理
原因是您在此行中使用了生成的 class 的无效名称:
Case(Demo.Employee($("Carl"), $()), (name, id) -> "")
应替换为:
Case(Example_DemoPatterns.$Employee($("Carl"), $()), (name, id) -> name + " " + id)
因为 Demo
是一个静态嵌套的 class 它需要以 Example_
为前缀并且因为这是生成器的工作方式所以它需要以 Patterns
为后缀。
Here 是一个完整的、可构建的示例,您可以克隆并试用它。它包含 Maven 和 gradle 的示例。要验证它是如何工作的,请将提到的行更改为例如:
Case(Example_DemoPatternsWhatever.$Employee($("Carl"), $()), (name, id) -> name + " " + id)
然后 运行:
mvn exec:java
它失败了(没有这样的 class 生成)但是当你 运行 tree target/
你会得到类似的东西:
target
├── classes
├── generated-sources
│ └── annotations
│ └── Example_DemoPatterns.java
└── maven-status
└── maven-compiler-plugin
└── compile
└── default-compile
├── createdFiles.lst
└── inputFiles.lst
表示确实生成了class。这是您需要使用的class。