- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
完整的错误是“IR 生成失败:程序太聪明:变量与现有符号 _TWPSaSs12SequenceType 发生冲突”。
我正在编写一堆函数作为学习 Swift 的练习,尤其是 Swift 泛型。我的最新函数 concatenate
是尝试实现 Haskell 的 Data.List.concat
。它是这样的:
protocol Concatenable {
func +(lhs: Self, rhs: Self) -> Self
init()
}
extension Array: Concatenable {}
func concatenate<S: SequenceType, C: Concatenable where S.Generator.Element == C>(seq: S) -> C {
var result = C()
for elem in seq {
result = result + elem
}
return result
}
这很好用。但是,作为实验,我想要求任何 Concatenable
也是 SequenceType
,因此我将代码更改如下:
protocol Concatenable: SequenceType {
// etc.
}
我一这样做,就得到了上面提到的错误。但是,如果您将这段代码粘贴到一个新的 Swift 项目中,一切都会正常进行。所以它与我项目中的其他内容冲突。因此——对于篇幅,我深表歉意——我将我的整个“函数库”粘贴在这里。
func foreach<S: SequenceType, T where T == S.Generator.Element>(seq: S, action: (T -> Void)) {
for elem in seq {
action(elem)
}
}
protocol Concatenable: SequenceType {
func +(lhs: Self, rhs: Self) -> Self
init()
}
extension Array: Concatenable {}
func concatenate<S: SequenceType, C: Concatenable where S.Generator.Element == C>(seq: S) -> C {
var result = C()
for elem in seq {
result = result + elem
}
return result
}
typealias AutoOptional = @autoclosure () -> Any?
func coalesce<S: SequenceType where S.Generator.Element == AutoOptional>(values: S) -> Any? {
for value: () -> Any? in values {
if let found = value() {
return found
}
}
return nil
}
func coalesce(values: @autoclosure () -> Any?...) -> Any? {
return coalesce(values)
}
func any(values: [() -> Any?]) -> Any? {
for value: () -> Any? in values {
if let found = value() {
if let truth = found as? Bool {
if truth {
return truth
}
} else {
return found
}
}
}
return nil
}
func any(values: @autoclosure () -> Any?...) -> Any? {
return any(values)
}
func any<T>(test: T -> Bool, values: [@autoclosure () -> T]) -> T? {
for value: () -> T in values {
let found = value()
if test(found) {
return found
}
}
return nil
}
func any<T>(values: [@autoclosure () -> T], test: T -> Bool) -> T? {
return any(test, values)
}
func any<T>(test: T -> Bool, values: @autoclosure () -> T...) -> T? {
return any(test, values)
}
func all(values: [@autoclosure () -> Any?]) -> Bool {
for value: () -> Any? in values {
if let found = value() {
if let truth = found as? Bool {
if !truth {
return false
}
}
} else {
return false
}
}
return true
}
func all(values: @autoclosure () -> Any?...) -> Bool {
return all(values)
}
func all<T>(test: T -> Bool, values: [@autoclosure () -> T]) -> Bool {
for value: () -> T in values {
if !test(value()) {
return false
}
}
return true
}
func all<T>(values: [@autoclosure () -> T], test: T -> Bool) -> Bool {
return all(test, values)
}
func all<T>(test: T -> Bool, values: @autoclosure () -> T...) -> Bool {
return all(test, values)
}
如果将以上所有内容粘贴到一个新项目中,就会出现我提到的编译错误。有人知道这是什么吗?
最佳答案
我遇到了同样的问题,我用一个也符合 CollectionType 的协议(protocol)扩展了一个数组。我认为错误的发生是因为 Swift 看到 Array 被要求遵守两个同名的协议(protocol),但不够聪明,无法确定它们是同一个协议(protocol)。
我刚刚下载了最新版本的 Xcode (6.3) 和最新版本的 Swift (1.2),问题似乎已解决,因此可能值得再试一次。
问题没有得到解决,它只是不再是编译时错误,而是在运行程序时崩溃了。
关于swift - swift 中的 "IR generation failure: program too clever",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27075520/
我已经设置了自定义 SSIS IR,但是从 IR 节点上的当前工作目录或临时文件夹读取文件时遇到问题 https://learn.microsoft.com/en-us/sql/integration
我已经编写了一个修改中间表示 (IR) 代码的 LLVM pass。为了增加可移植性,我还希望它与 gcc 编译器一起工作。所以我想知道是否有任何工具可以将 gcc 的某些中间表示 (IR) 转换为
我已经下载了 Sony Android Add-on IR SDK ( http://developer.sonymobile.com/knowledge-base/sdks/sony-add-on-
我在手机中使用其他应用程序,使用它的 IR。但是当我尝试在任何项目中使用 IREmitter 时,它会触发该错误! mCIR = (ConsumerIrManager)getSystemService
我想找到一些 Clang/LLVM 的调试选项,其工作方式类似于 GCC -fdump-tree-all-all , -fdump-rtl-all ,和 -fdump-ipa-all-all . 基本
我使用 LLVM opt 来运行一个传递,例如,opt -load libMyPass.so my-pass foo.ll > foo1.ll。 foo.ll 是一个 IR 文件,我希望 foo1.l
我在 Raspian jessie(无像素)(所有更新和升级)上安装了当前的 lirc 包(0.9.0~pre1-1.2)并连接到(lirc 默认)GPIO 端口: 到 gpio 端口 17 - 通过
在学习 Antlr4 时,我使用 Golang 作为目标语言,所以我的玩具语言中的语句如下: $myVar = 10 $myVar + 5 将转换为一些生成结果“15”的 Golang 代码 但是,据
我正在尝试使用 SSIS 脚本任务连接到本地 REST Web 服务,并在 Azure 数据工厂的 SSIS-IR 上运行它,该 SSIS-IR 具有自托管 IR 的代理,最终连接到本地服务器。可行吗
我正在尝试关注 this链接以便为 c 代码生成 IR 表示。我使用的c代码如下 void main() { int c1 = 17; int c2 = 25; int c3 = c1 + c2
在为 lto 链接后,有没有办法获得 llvm IR?例如,我有以下行: $ clang -flto -O2 a.c main.c -fuse-ld=gold -v -save-temps 所以我想获
我正在通过这个学习 LLVM IR LangRef . 如本引用所述: LLVM programs are composed of Modules, each of which is a transl
如果这个问题听起来很愚蠢,我很抱歉。 为什么inverse document frequency使用日志?日志在 tf/idf 中有何帮助? 最佳答案 AFAIK,使用日志有助于使用几何分布对数字进行
我建立了一个LLVM定位前端,该前端会产生一些IR。随后并且完全可以预期,在某些情况下,IR输出是不正确的(例如,它看起来正确,但是执行时结果程序崩溃)。但是,我还没有找到很多有用的工具来解决这一问题
我想将C#编译为LLVM IR。因此,我认为将编译的CIL转换为LLVM IR是我可以尝试的一种方法。 我可以使用一些工具,例如vmkit和mono-llvm。 有人在使用此工具吗?或者如何将CIL转
如何创建图像以及如何使用十六进制颜色代码逐像素为其着色? 例如。我想创建一个 100x100 像素的图像,并且我想要 1x1 区域的颜色为“$002125”,2x2 区域的颜色为“$125487”..
我正在测试一个 main 函数,它只返回 void 并且在使用 lli 运行位码时出现核心转储错误(信号 65 或 73)。 : define void @main() { entry: ret
我收到一个要求,其中我有一个 c 文件,并且我正在为其生成 LLVM IR。从为每条指令生成的 LLVM IR 中,我正在计算执行需要多少个周期,现在我的问题是如何追溯到 C 代码并显示特定的 C 代
我目前正在尝试运行其他人留下的 sql 命令/脚本来建立数据库。他们有这个脚本 BEGIN; \ir file.sql \ir file.sql END; 它在第一个反斜杠处给出错误。我正在使用 Po
我特别需要在我的 C++ 代码运行期间逐行解析 LLVM IR 代码,我需要知道每行的哪些操作数发生了什么操作。 例如,如果 IR 代码是: %0 = load i32* %a, align 4 我想
我是一名优秀的程序员,十分优秀!