- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个宏注释,旨在应用于类定义。它的目的是一个几乎但不完全序列化的工具。它检查类的构造函数参数,然后在伴随对象上创建一个工厂方法,该方法反过来为参数提供值。它需要知道参数的类型才能做到这一点,所以我一直在对它们调用 Context.typeCheck。
当被注解的类的构造函数接受一个与自身类型相同的参数时,或者在其他类似的情况下(例如,如果类型 A 和类型 B 都被注解,并且 A 具有 B 的参数,并且 B 具有参数),则会出现问题A. 应用于形式参数的类型参数也算)。这些情况中的任何一种都会导致注释被递归调用,直到发生 StackOverflowError。
我尝试使用“withMacrosDisabled=true”作为 c.typeCheck 的参数,虽然这解决了问题,但它引入了一个不同的问题。如果之前没有看到被检查的类型,那么编译器会记住它的定义,并且它的宏根本不会被调用。这对于自引用情况来说不是问题,但在相互引用情况下确实会发生。
所以我被困住了。有解决方法吗?我可以用 c.openMacros 解决这个问题吗?
另一个选项(如果可用)是我并不严格需要类型的完整定义,我可以只使用它的完全限定名称(scala.xml.NodeSeq 而不是 NodeSeq)。我在 AST 中获得了 TypeName,但这些很少是完全限定的,而且我不知道如何在不进行完整类型检查的情况下获得完全限定的名称。
作为一个附带问题,“withMacrosDisabled”有什么用?如果使用它阻止在传递的树中找到的类型上的所有宏扩展,而不仅仅是当前的 c.typeCheck,那似乎太大了。即使这实际上是您想要的,您也不能真正使用它,因为宏评估将取决于类型在它们自己的源中遇到的顺序。
编辑 : 想想看,我觉得编译器应该保证每个宏只被展开一次。在循环的情况下,就像在我的例子中一样,至少一个涉及的宏仍然会看到一个未完全处理的类,这在这种情况下似乎是不可避免的,因为它实际上是循环依赖。我想,结果 Type 上的标志表明宏处理不是最终的将是处理它的最佳方法,但这可能无法在 Paradise 中完成。
最佳答案
这似乎与 Can't access Parent's Members while dealing with Macro Annotations 中开始的讨论有关。 (另请参阅我在那边的回答中更详细阐述的链接)。
如果可能的话,我想避免宏看到半扩展或半填充类型的情况,以减少混淆的可能性。上个月我一直在考虑避免这种情况的方法,但是出现了一些更高优先级的干扰,所以我还没有走多远。
我正在考虑的两个可能的想法是:1)提出一个符号来指定宏注释的效果,这样我们就不必扩展宏来知道哪些类和成员组成了我们的程序(如果可行的话,然后宏引擎可以首先预先计算成员列表,然后才启动宏扩展),2)找出指定宏如何依赖程序元素的机制,以便正确排序扩展。就在昨天,我还了解了 Backstage Java 和 David Herman 在类型化卫生宏方面的工作——这也应该是相关的。你如何看待这些思想方向?
与此同时,当我试图找出解决依赖问题的原则性解决方案时,我也有兴趣通过提供一种立即有用的解决方法或天堂补丁来解除您的用例。您能否详细说明您的项目,以便我们提出解决方案?
关于Scala 宏注释 : c. 注释类型的 TypeCheck 导致 StackOverflowError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19954776/
我有一些 Scala 代码,它用两个不同版本的类型参数化函数做了一些漂亮的事情。我已经从我的应用程序中简化了很多,但最后我的代码充满了形式 w(f[Int],f[Double]) 的调用。哪里w()是
如果我在同一目录中有两个单独的未编译的 scala 文件: // hello.scala object hello { def world() = println("hello world") }
val schema = df.schema val x = df.flatMap(r => (0 until schema.length).map { idx => ((idx, r.g
环境: Play 2.3.0/Scala 2.11.1/IntelliJ 13.1 我使用 Typesafe Activator 1.2.1 用 Scala 2.11.1 创建一个新项目。项目创建好后
我只是想知道如何使用我自己的类扩展 Scala 控制台和“脚本”运行程序,以便我可以通过使用实际的 Scala 语言与其通信来实际使用我的代码?我应将 jar 放在哪里,以便无需临时配置即可从每个 S
我已经根据 README.md 文件安装了 ensime,但是,我在低级 ensime-server 缓冲区中出现以下错误: 信息: fatal error :scala.tools.nsc.Miss
我正在阅读《Scala 编程》一书。在书中,它说“一个函数文字被编译成一个类,当在运行时实例化时它是一个函数值”。并且它提到“函数值是对象,因此您可以根据需要将它们存储在变量中”。 所以我尝试检查函数
我有 hello world scala native 应用程序,想对此应用程序运行小型 scala 测试我使用通常的测试命令,但它抛出异常: NativeMain.scala object Nati
有few resources在网络上,在编写与代码模式匹配的 Scala 编译器插件方面很有指导意义,但这些对生成代码(构建符号树)没有帮助。我应该从哪里开始弄清楚如何做到这一点? (如果有比手动构建
我是 Scala 的新手。但是,我用 创建了一个中等大小的程序。斯卡拉 2.9.0 .现在我想使用一个仅适用于 的开源库斯卡拉 2.7.7 . 是吗可能 在我的 Scala 2.9.0 程序中使用这个
有没有办法在 Scala 2.11 中使用 scala-pickling? 我在 sonatype 存储库中尝试了唯一的 scala-pickling_2.11 工件,但它似乎不起作用。我收到消息:
这与命令行编译器选项无关。如何以编程方式获取代码内的 Scala 版本? 或者,Eclipse Scala 插件 v2 在哪里存储 scalac 的路径? 最佳答案 这无需访问 scala-compi
我正在阅读《Scala 编程》一书,并在第 6 章中的类 Rational 实现中遇到了一些问题。 这是我的 Rational 类的初始版本(基于本书) class Rational(numerato
我是 Scala 新手,我正在尝试开发一个使用自定义库的小项目。我在库内创建了一个mysql连接池。这是我的库的build.sbt organization := "com.learn" name :
我正在尝试运行一些 Scala 代码,只是暂时打印出“Hello”,但我希望在 SBT 项目中编译 Scala 代码之前运行 Scala 代码。我发现在 build.sbt 中有以下工作。 compi
Here链接到 maven Scala 插件使用。但没有提到它使用的究竟是什么 Scala 版本。我创建了具有以下配置的 Maven Scala 项目: org.scala-tools
我对 Scala 还很陌生,请多多包涵。我有一堆包裹在一个大数组中的 future 。 future 已经完成了查看几 TB 数据的辛勤工作,在我的应用程序结束时,我想总结上述 future 的所有结
我有一个 scala 宏,它依赖于通过包含其位置的静态字符串指定的任意 xml 文件。 def myMacro(path: String) = macro myMacroImpl def myMacr
这是我的功能: def sumOfSquaresOfOdd(in: Seq[Int]): Int = { in.filter(_%2==1).map(_*_).reduce(_+_) } 为什么我
这个问题在这里已经有了答案: Calculating the difference between two Java date instances (45 个答案) 关闭 5 年前。 所以我有一个这
我是一名优秀的程序员,十分优秀!