What is the easiest way with Swift 4 for a macOS application to find the important users directories like: Desktop, Documents, Downloads etc.?
TLDR:
let desktopDir = try? FileManager.default.url(for: .desktopDirectory, in: .userDomainMask, appropriateFor: nil, create: false)
let documentDir = try? FileManager.default.url(for: .documentDirectory, in: .userDomainMask, appropriateFor: nil, create: false)
let downloadsDir = try? FileManager.default.url(for: .downloadsDirectory, in: .userDomainMask, appropriateFor: nil, create: false)
There are two methods to get this information, both from the FileManager class:
func urls(for directory: FileManager.SearchPathDirectory,
in domainMask: FileManager.SearchPathDomainMask) -> [URL]
Returns an array of URLs for the specified common directory in the requested domains. […] The directories are ordered according to the order of the domain mask constants, with items in the user domain first and items in the system domain last.
Documentation: https://developer.apple.com/documentation/foundation/filemanager/1407726-urls
(already mentioned in @leo-dabus' answer)
(which I prefer since it's more versatile and returns a single URL)
func url(for directory: FileManager.SearchPathDirectory,
in domain: FileManager.SearchPathDomainMask,
appropriateFor url: URL?,
create shouldCreate: Bool) throws -> URL
Locates and optionally creates the specified common directory in a domain.
Documentation: https://developer.apple.com/documentation/foundation/filemanager/1407693-url
The valid domains, defined in https://developer.apple.com/documentation/foundation/filemanager.searchpathdomainmask are:
.userDomainMask: The user’s home directory—the place to install user’s personal items (~).
.localDomainMask: Local to the current machine—the place to install items available to everyone on this machine.
.networkDomainMask: Publicly available location in the local area network—the place to install items available on the network (/Network).
.systemDomainMask: Provided by Apple—can’t be modified (/System) .
.allDomainsMask: All domains.
There are lots of possibilities for the directory parameter, defined in https://developer.apple.com/documentation/foundation/filemanager.searchpathdirectory :
.applicationDirectory: Supported applications (/Applications).
.demoApplicationDirectory: Unsupported applications and demonstration versions.
.developerApplicationDirectory: Developer applications (/Developer/Applications).
.adminApplicationDirectorySystem and network administration applications.
.libraryDirectory: Various user-visible documentation, support, and configuration files (/Library).
.developerDirectory: Developer resources (/Developer).
.userDirectory: User home directories (/Users).
.documentationDirectory: Documentation.
.documentDirectory: Document directory.
.coreServiceDirectory: Location of core services (System/Library/CoreServices).
.autosavedInformationDirectory: Location of user’s autosaved documents (Library/Autosave Information).
.desktopDirectory: Location of user’s desktop directory.
.cachesDirectory: Location of discardable cache files (Library/Caches).
.applicationSupportDirectory: Location of application support files (Library/Application Support).
.downloadsDirectory: Location of the user’s downloads directory.
.inputMethodsDirectory: Location of Input Methods (Library/Input Methods).
.moviesDirectory: Location of user's Movies directory (~/Movies).
.musicDirectory: Location of user's Music directory (~/Music).
.picturesDirectory: Location of user's Pictures directory (~/Pictures).
.printerDescriptionDirectory: Location of system's PPDs directory (Library/Printers/PPDs).
.sharedPublicDirectory: Location of user's Public sharing directory (~/Public).
.preferencePanesDirectory: Location of the PreferencePanes directory for use with System Preferences (Library/PreferencePanes).
.applicationScriptsDirectory: Location of the user scripts folder for the calling application (~/Library/Application Scripts/),
.itemReplacementDirectory: Passed to the FileManager methodurl(for:in:appropriateFor:create:)in order to create a temporary directory.
.allApplicationsDirectory: All directories where applications can occur.
.allLibrariesDirectory: All directories where resources can occur.
.trashDirectory: Location of the trash directory.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With