如何将Scala宏作为项目进行分发?
假设我有一个
Scala编译时宏,我发现它很有用,并且想分享它(我这样做).如何创建一个JAR文件,当加载到另一个项目时,它会在编译新项目时执行宏?
具体来说,我已经创建了一个StaticAnnotation来重写它在编译时包装的类的AST.这适用于我的Maven构建(在主目录中定义的宏,在测试目录中的测试用例上运行),因为我有 <compilerPlugins> <compilerPlugin> <groupId>org.scalamacros</groupId> <artifactId>paradise_2.10.5</artifactId> <version>2.1.0-M5</version> </compilerPlugin> </compilerPlugins> 在我的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中的这种依赖”.我无法在他们的构建过程中找到使这项工作变得神奇的魔力.我错过了什么? 解决方法
如果您依赖于仅限宏天堂的功能,那么您需要告诉用户添加编译器插件.见
http://docs.scala-lang.org/overviews/macros/annotations.html.您提到的项目仅使用scala编译器的内置(非天堂)宏功能,而不是宏注释.
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |