FinderSync 上下文菜单项发出蜂鸣声,从不调用操作
FinderSync context menu items beep, never call action
我想生成一个菜单,该菜单将调用 class 上的函数,而不是生成该菜单的菜单,然后将其放在 Finder 中。但是,当我单击菜单项时,会发出系统错误蜂鸣声,而且我的函数永远不会被调用。
这是一个 SSCCE:
import Cocoa
import FinderSync
@objc(FinderSync)
class FinderSync: FIFinderSync {
var observedFolder = URL(fileURLWithPath: "/")
override init() {
super.init()
NSLog("\(FinderSync.self.className()) launched from \(Bundle.main.bundlePath)")
// Set up the directory we are syncing.
FIFinderSyncController.default().directoryURLs = [self.observedFolder]
}
// MARK: - Menu and toolbar item support
override var toolbarItemName: String {
return "Wonderful Test App"
}
override var toolbarItemToolTip: String {
return "This is wonderful"
}
override var toolbarItemImage: NSImage {
return NSImage(named: NSImage.cautionName)!
}
override func menu(for menuKind: FIMenuKind) -> NSMenu {
let menu = NSMenu(title: "")
let menuItem = NSMenuItem(title: "Click me!", action: #selector(SomeOtherClass.remoteAction), keyEquivalent: "")
menuItem.target = SomeOtherClass.shared
menuItem.action = #selector(SomeOtherClass.remoteAction)
menu.addItem(menuItem)
return menu
}
}
@objc(SomeOtherClass)
public class SomeOtherClass: NSObject {
public static let shared = SomeOtherClass()
deinit {
NSLog("Deallocated!")
preconditionFailure("Shared instance should never be deallocated!")
}
@IBAction
@objc(remoteAction:)
public func remoteAction(_ sender: Any?) {
NSLog("Remote!")
}
}
我已经通过内存调试器验证 SomeOtherClass.shared
在菜单项被单击之前、期间和之后仍在内存中,因此它没有被释放或其他任何事情。
您似乎无法添加除 FinderSync 扩展程序主体 class 之外的任何 class 内的操作。这和 NSMenuItem
的其他一切一样愚蠢,所以我并不感到惊讶。
因此,您必须将操作移到您的 FinderSync
class 中,尽管这对组织来说可能有多么丑陋。
我想生成一个菜单,该菜单将调用 class 上的函数,而不是生成该菜单的菜单,然后将其放在 Finder 中。但是,当我单击菜单项时,会发出系统错误蜂鸣声,而且我的函数永远不会被调用。
这是一个 SSCCE:
import Cocoa
import FinderSync
@objc(FinderSync)
class FinderSync: FIFinderSync {
var observedFolder = URL(fileURLWithPath: "/")
override init() {
super.init()
NSLog("\(FinderSync.self.className()) launched from \(Bundle.main.bundlePath)")
// Set up the directory we are syncing.
FIFinderSyncController.default().directoryURLs = [self.observedFolder]
}
// MARK: - Menu and toolbar item support
override var toolbarItemName: String {
return "Wonderful Test App"
}
override var toolbarItemToolTip: String {
return "This is wonderful"
}
override var toolbarItemImage: NSImage {
return NSImage(named: NSImage.cautionName)!
}
override func menu(for menuKind: FIMenuKind) -> NSMenu {
let menu = NSMenu(title: "")
let menuItem = NSMenuItem(title: "Click me!", action: #selector(SomeOtherClass.remoteAction), keyEquivalent: "")
menuItem.target = SomeOtherClass.shared
menuItem.action = #selector(SomeOtherClass.remoteAction)
menu.addItem(menuItem)
return menu
}
}
@objc(SomeOtherClass)
public class SomeOtherClass: NSObject {
public static let shared = SomeOtherClass()
deinit {
NSLog("Deallocated!")
preconditionFailure("Shared instance should never be deallocated!")
}
@IBAction
@objc(remoteAction:)
public func remoteAction(_ sender: Any?) {
NSLog("Remote!")
}
}
我已经通过内存调试器验证 SomeOtherClass.shared
在菜单项被单击之前、期间和之后仍在内存中,因此它没有被释放或其他任何事情。
您似乎无法添加除 FinderSync 扩展程序主体 class 之外的任何 class 内的操作。这和 NSMenuItem
的其他一切一样愚蠢,所以我并不感到惊讶。
因此,您必须将操作移到您的 FinderSync
class 中,尽管这对组织来说可能有多么丑陋。