通过getter函数提供属性,符合协议时Swift编译器错误

时间:2014-06-05 21:41:49

标签: swift

我有一个试图符合NSFilePresenter协议的类。我可以说,只有两个要求,它们都是两个属性:

var presentedItemURL: NSURL! { get }
var presentedItemOperationQueue: NSOperationQueue! { get }

因为我将现有的Objective-C项目迁移到Swift,所以我已经将其中一个项目保存为我想要维护的ivar:

var _trackingURL: NSURL! = ...

var presentedItemURL: NSURL! {
    return _trackingURL
}

var presentedItemOperationQueue: NSOperationQueue! {
    return NSOperationQueue.mainQueue()
}

但是,由于“Swift编译器错误”导致此版本失败。在Xcode中,但没有说明我做错了什么。我有编译器的堆栈跟踪,但我无法解释根本问题:

0  swift                    0x000000010b10b608 llvm::sys::PrintStackTrace(__sFILE*) + 40
1  swift                    0x000000010b10baf4 SignalHandler(int) + 452
2  libsystem_platform.dylib 0x00007fff92578f1a _sigtramp + 26
3  libsystem_platform.dylib 0x00007fd0c225e968 _sigtramp + 802052712
4  swift                    0x000000010a74797a (anonymous namespace)::ObjCPrinter::visitVarDecl(swift::VarDecl*) + 762
5  swift                    0x000000010a746f7d swift::ASTVisitor<(anonymous namespace)::ObjCPrinter, void, void, void, void, void, void>::visit(swift::Decl*) + 125
6  swift                    0x000000010a74abcb (anonymous namespace)::ObjCPrinter::printMembers(swift::IteratorRange<swift::DeclIterator>) + 251
7  swift                    0x000000010a747603 swift::ASTVisitor<(anonymous namespace)::ObjCPrinter, void, void, void, void, void, void>::visit(swift::Decl*) + 1795
8  swift                    0x000000010a74638e swift::printAsObjC(llvm::raw_ostream&, swift::Module*) + 1934
9  swift                    0x000000010a4d0b6e printAsObjC(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, swift::Module*) + 286
10 swift                    0x000000010a4d0178 frontend_main(llvm::ArrayRef<char const*>, char const*, void*) + 3592
11 swift                    0x000000010a4cf35d main + 1533
12 libdyld.dylib            0x00007fff978e45c9 start + 1

...

<unknown>:0: error: unable to execute command: Segmentation fault: 11
<unknown>:0: error: merge-module command failed due to signal (use -v to see invocation)

如果编译器能够在我完成的任何工作中生存下去,那将是很好的,我宁愿在我的代码中解决问题,无论它是什么。

1 个答案:

答案 0 :(得分:0)

当我在类扩展中编写这样的动态属性时,我遇到了类似的问题:

class MyClass {
  func test() {
    let myVar = myProperty
  }
}

extension MyClass {
  var myProperty: String { return "TEST" }
}

MyClass().test()

当放置在游乐场时,这会导致XCode崩溃,并且当我的项目中的.swift文件中包含此类代码时,它会导致构建失败并显示神秘的“Swift编译器错误”。

可能有关系,无论如何我报告了它(我想是rdar:// 17527780)。