如何启用和调试 macOS 文件提供程序扩展?
How to enable and debug a macOS file provider extension?
我正在尝试在 macOS Big Sur 11.2.2 上使用 Xcode 12.5 Beta 3 构建一个带有文件提供程序扩展的准系统应用程序。我使用 Xcode 的测试版,因为以前的版本不提供文件提供程序扩展的模板 (example project on GitHub)。
该应用程序及其扩展程序在其权利中设置了一个通用应用程序组,并由我的个人团队和开发证书自动签名。
我构建了 运行 我的应用程序和扩展程序。但是,据我所知,我现在可以控制何时(卸载)加载它,因为这取决于系统。
观察
- 文件提供者扩展从未出现在系统首选项中。
- 除了“lsd (LaunchServices)”检查应用程序是否受管理外,控制台应用程序不提供任何具有不同项目名称的有意义的信息。
- 扩展没有出现在 Activity 监视器中。
- Pluginkit 报告要找到的扩展名,但会在前面加上感叹号(当 运行
pluginkit -vvvvmi SomeOrganization.SomeProduct.SomeProvider
时)。
$ pluginkit -vvvvmi SomeOrganization.SomeProduct.SomeProvider
! SomeOrganization.SomeProduct.SomeProvider(1.0)
Path = /Users/peter/Library/Developer/Xcode/DerivedData/SomeProduct-gyyunhpcbweleidtluxpslpciwjj/Build/Products/Debug/SomeProduct.app/Contents/PlugIns/SomeProvider.appex
UUID = E2FDC7AB-3CDD-4AEE-A2B2-CC2BA0CBC409
Timestamp = 2021-03-09 16:49:57 +0000
SDK = com.apple.fileprovider-nonui
Parent Bundle = /Users/peter/Library/Developer/Xcode/DerivedData/SomeProduct-gyyunhpcbweleidtluxpslpciwjj/Build/Products/Debug/SomeProduct.app
Display Name = SomeProvider
Short Name = SomeProvider
Parent Name = SomeProduct
(1 plug-in)
- 通过
com.apple.FileProvider
子系统过滤系统控制台 我在构建扩展后偶然发现了这些消息(我不得不透露私有值 as described in this answer):
[ERROR] could not load the domain properties
[WARNING] found directory with no domain plist in it: ~/L{5}y/A{17}t/F{10}r/S{26}t.SomeProvider
还有另外两个关于 PhotosFileProvider
和 com.apple.CloudDocs.MobileDocumentsFileProvider
的(我猜)是不相关的。 PhotosFileProvider
报告相同的警告。上面的路径可以展开为:
~/Library/Application Support/FileProvider/SomeOrganization.SomeProduct.SomeProvider
其中包含 Domains.plist
具有以下(二进制)内容:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>NSFileProviderDomainDefaultIdentifier</key>
<dict>
<key>Connected</key>
<false/>
<key>Enabled</key>
<false/>
</dict>
</dict>
</plist>
问题
我没有找到关于感叹号的含义或如何找出实际问题的任何信息。我该如何调试呢?控制台中的错误很可疑。在我看来,我好像遗漏了一些文档中没有提到的部分,比如操作方法中的秘密步骤。
您是从您的应用程序调用 +[NSFileProviderManager addDomain:completionHandler:]
吗? https://developer.apple.com/documentation/fileprovider/nsfileprovidermanager/2890934-adddomain?language=objc
在 macOS 上,与 iOS 不同,系统没有创建默认的 FileProvider 域。您的应用程序必须明确注册域。
我正在尝试在 macOS Big Sur 11.2.2 上使用 Xcode 12.5 Beta 3 构建一个带有文件提供程序扩展的准系统应用程序。我使用 Xcode 的测试版,因为以前的版本不提供文件提供程序扩展的模板 (example project on GitHub)。
该应用程序及其扩展程序在其权利中设置了一个通用应用程序组,并由我的个人团队和开发证书自动签名。
我构建了 运行 我的应用程序和扩展程序。但是,据我所知,我现在可以控制何时(卸载)加载它,因为这取决于系统。
观察
- 文件提供者扩展从未出现在系统首选项中。
- 除了“lsd (LaunchServices)”检查应用程序是否受管理外,控制台应用程序不提供任何具有不同项目名称的有意义的信息。
- 扩展没有出现在 Activity 监视器中。
- Pluginkit 报告要找到的扩展名,但会在前面加上感叹号(当 运行
pluginkit -vvvvmi SomeOrganization.SomeProduct.SomeProvider
时)。
$ pluginkit -vvvvmi SomeOrganization.SomeProduct.SomeProvider
! SomeOrganization.SomeProduct.SomeProvider(1.0)
Path = /Users/peter/Library/Developer/Xcode/DerivedData/SomeProduct-gyyunhpcbweleidtluxpslpciwjj/Build/Products/Debug/SomeProduct.app/Contents/PlugIns/SomeProvider.appex
UUID = E2FDC7AB-3CDD-4AEE-A2B2-CC2BA0CBC409
Timestamp = 2021-03-09 16:49:57 +0000
SDK = com.apple.fileprovider-nonui
Parent Bundle = /Users/peter/Library/Developer/Xcode/DerivedData/SomeProduct-gyyunhpcbweleidtluxpslpciwjj/Build/Products/Debug/SomeProduct.app
Display Name = SomeProvider
Short Name = SomeProvider
Parent Name = SomeProduct
(1 plug-in)
- 通过
com.apple.FileProvider
子系统过滤系统控制台 我在构建扩展后偶然发现了这些消息(我不得不透露私有值 as described in this answer):
[ERROR] could not load the domain properties
[WARNING] found directory with no domain plist in it: ~/L{5}y/A{17}t/F{10}r/S{26}t.SomeProvider
还有另外两个关于 PhotosFileProvider
和 com.apple.CloudDocs.MobileDocumentsFileProvider
的(我猜)是不相关的。 PhotosFileProvider
报告相同的警告。上面的路径可以展开为:
~/Library/Application Support/FileProvider/SomeOrganization.SomeProduct.SomeProvider
其中包含 Domains.plist
具有以下(二进制)内容:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>NSFileProviderDomainDefaultIdentifier</key>
<dict>
<key>Connected</key>
<false/>
<key>Enabled</key>
<false/>
</dict>
</dict>
</plist>
问题
我没有找到关于感叹号的含义或如何找出实际问题的任何信息。我该如何调试呢?控制台中的错误很可疑。在我看来,我好像遗漏了一些文档中没有提到的部分,比如操作方法中的秘密步骤。
您是从您的应用程序调用 +[NSFileProviderManager addDomain:completionHandler:]
吗? https://developer.apple.com/documentation/fileprovider/nsfileprovidermanager/2890934-adddomain?language=objc
在 macOS 上,与 iOS 不同,系统没有创建默认的 FileProvider 域。您的应用程序必须明确注册域。