81

Just upgraded to Xcode 13.3 beta 3 (from Xcode 13.2.1) and ran swift package init. It generated a deprecation warning, I have not seen this before:

warning: Usage of /Users/sajjon/Library/org.swift.swiftpm/collections.json has been deprecated. Please delete it and use the new /Users/sajjon/Library/org.swift.swiftpm/configuration/collections.json instead.

But I do not know HOW to "use the new ... instead"? In fact I don't even know how or when org.swift.swiftpm/collections.json was created.

What to do?

Full print:

~/Developer/DeleteMe ⌚ 13:57:37
$ swift package init
2022-02-25 13:57:42.211 xcodebuild[54679:13318505] Requested but did not find extension point with identifier Xcode.IDEKit.ExtensionSentinelHostApplications for extension Xcode.DebuggerFoundation.AppExtensionHosts.watchOS of plug-in com.apple.dt.IDEWatchSupportCore
2022-02-25 13:57:42.212 xcodebuild[54679:13318505] Requested but did not find extension point with identifier Xcode.IDEKit.ExtensionPointIdentifierToBundleIdentifier for extension Xcode.DebuggerFoundation.AppExtensionToBundleIdentifierMap.watchOS of plug-in com.apple.dt.IDEWatchSupportCore
2022-02-25 13:57:43.052 xcodebuild[54754:13318823] Requested but did not find extension point with identifier Xcode.IDEKit.ExtensionSentinelHostApplications for extension Xcode.DebuggerFoundation.AppExtensionHosts.watchOS of plug-in com.apple.dt.IDEWatchSupportCore
2022-02-25 13:57:43.053 xcodebuild[54754:13318823] Requested but did not find extension point with identifier Xcode.IDEKit.ExtensionPointIdentifierToBundleIdentifier for extension Xcode.DebuggerFoundation.AppExtensionToBundleIdentifierMap.watchOS of plug-in com.apple.dt.IDEWatchSupportCore
warning: Usage of /Users/sajjon/Library/org.swift.swiftpm/collections.json has been deprecated. Please delete it and use the new /Users/sajjon/Library/org.swift.swiftpm/configuration/collections.json instead.
Creating library package: DeleteMe
Sajjon
  • 8,938
  • 5
  • 60
  • 94

5 Answers5

123

I faced this problem after I installed Xcode 14.0. Deleting org.swift.swiftpm worked for me:

  1. Make sure that anything related to SPM is not running including Xcode. Close them all before you delete anything.

  2. Go to directory and delete the entire org.swift.swiftpm directory (Not only collection directory, but the whole org.swift.swiftpm directory) and if there is also a org.swift.swiftpm.lock, delete that one as well.

enter image description here

superus8r
  • 751
  • 1
  • 11
  • 24
Mehdi
  • 1,340
  • 1
  • 10
  • 5
22

The warning says that you need to delete the file.

Please delete it and use the new /Users/sajjon/Library/org.swift.swiftpm/configuration/collections.json instead.

So please delete it and it will help.

NikR
  • 628
  • 4
  • 14
  • This is not the same problem. The core issue is `xcodebuild` error, not deprecation warning. – Daumantas Versockas Mar 16 '22 at 11:57
  • @DaumantasVersockas there's no `xcodebuild` error in OP's question. It's clear about referring to the deprecation warning. – Jonathan Cabrera Jun 14 '22 at 20:32
  • Yes, that's what I did, remove the file is enough. – Medhi Oct 07 '22 at 13:01
  • I believe this should be the accepted answer. Deleting this file worked for me also. We don't have to create the file it says to use instead, because it's already there and has the exact same contents. I can't see any other steps required for how to "use" the file it says to use instead. It seems it uses the file automatically in the absence of the one it says to delete. Xcode 14.2. MacOS Ventura 13.2 – DavidT Jan 30 '23 at 21:43
13

Based on a comment from @jalone, this may cause Xcode to crash upon opening the project. It did not do that in my case but all I had was the generic Apple collections: https://developer.apple.com/swift/packages/collections/apple.json

Proceed with caution

It looks like all I needed to do is run this to get rid of the warning.

rm ~/.swiftpm/config/collections.json

There should be an additional collections.json located at ~/.swiftpm/config/configuration/collections.json that is where the packages are now stored when you use

swift package-collection add <package.json>

For more information see the SE proposal documentation here

Jav Solo
  • 576
  • 1
  • 6
  • 15
  • 5
    BEWARE after removal of the file xcode 13.3 crashes continuosly upon opening the project on my instance. I had to clean up a lot of caches and files to make the project open again (and the warning at least was gone). I suggest you find an alternative solution for this sadly. – jalone Mar 22 '22 at 15:11
  • Does this still happen with Xcode 13.4? – Fatlad Aug 31 '22 at 21:18
  • 1
    Back up just in case ... worked fine otherwise. mv ~/.swiftpm/config/collections.json ~/.swiftpm/config/collections.json.bak – jat Oct 10 '22 at 09:06
4

go to the path and open org.swift.swiftpm file, it will be open into IDE then remove collection.json that is available outside of the configuration folder. warning will be resolved.

3

I saw this warning in Xcode 14 RC and was able to resolve it by removing and re-adding one of my packages (under Project > Package Dependencies).

Greg Brown
  • 3,168
  • 1
  • 27
  • 37