如何将Scala宏作为项目进行分发?

Jim*_*ski 8 macros scala maven sbt

假设我有一个Scala编译时宏,我发现它很有用并且想要分享它(我这样做).如何创建一个JAR文件,当加载到另一个项目时,它会在编译新项目时执行宏?

具体来说,我已经创建了一个StaticAnnotation重写它在编译时包装的类的AST.这适用于我的Maven构建(在main目录中定义的宏,在目录中的测试用例上运行test),因为我有

<compilerPlugins>
    <compilerPlugin>
        <groupId>org.scalamacros</groupId>
        <artifactId>paradise_2.10.5</artifactId>
        <version>2.1.0-M5</version>
    </compilerPlugin>
</compilerPlugins>
Run Code Online (Sandbox Code Playgroud)

在我的scala-maven-plugin.(我从一个Scala 2.10项目开始,如果它有效,将同时提供2.10和2.11.)

但是,如果我将生成的JAR放在Scala控制台类路径,Scala脚本或另一个Maven项目(没有特殊的编译器插件)中,它只会忽略宏:AST不会被覆盖而我的编译时println语句不会执行.如果我@compileTimeOnly在我的宏上使用注释(Scala 2.11中的新增内容),那么它会报错@compileTimeOnly错误消息.

我是否真的需要告诉我的用户在他们的pom.xml文件中添加编译器插件,以及SBT和其他构建工具的替代指令?包含宏的其他软件包(MacWire,Log4s)没有复杂的构建指令:他们只是说,"指向Maven Central中的这种依赖".我无法在他们的构建过程中找到使这项工作变得神奇的魔力.我错过了什么?

lmm*_*lmm 5

如果您依赖于仅宏天堂的功能,那么是的,您确实需要告诉您的用户添加编译器插件。请参阅http://docs.scala-lang.org/overviews/macros/annotations.html。您提到的项目仅使用 Scala 编译器的内置(非天堂)宏功能,而不是宏注释。