// Copyright 2012 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef BASE_MAC_MAC_UTIL_H_ #define BASE_MAC_MAC_UTIL_H_ #include #import #include #include #include #include #include "base/base_export.h" namespace base { class FilePath; } namespace base::mac { // Returns an sRGB color space. The return value is a static value; do not // release it! BASE_EXPORT CGColorSpaceRef GetSRGBColorSpace(); // Adds the specified application to the set of Login Items with specified // "hide" flag. This has the same effect as adding/removing the application in // SystemPreferences->Accounts->LoginItems or marking Application in the Dock // as "Options->Open on Login". // Does nothing if the application is already set up as Login Item with // specified hide flag. BASE_EXPORT void AddToLoginItems(const FilePath& app_bundle_file_path, bool hide_on_startup); // Removes the specified application from the list of Login Items. BASE_EXPORT void RemoveFromLoginItems(const FilePath& app_bundle_file_path); // Returns true if the current process was automatically launched as a // 'Login Item' or via Lion's Resume. Used to suppress opening windows. BASE_EXPORT bool WasLaunchedAsLoginOrResumeItem(); // Returns true if the current process was automatically launched as a // 'Login Item' or via Resume, and the 'Reopen windows when logging back in' // checkbox was selected by the user. This indicates that the previous // session should be restored. BASE_EXPORT bool WasLaunchedAsLoginItemRestoreState(); // Returns true if the current process was automatically launched as a // 'Login Item' with 'hide on startup' flag. Used to suppress opening windows. BASE_EXPORT bool WasLaunchedAsHiddenLoginItem(); // Remove the quarantine xattr from the given file. Returns false if there was // an error, or true otherwise. BASE_EXPORT bool RemoveQuarantineAttribute(const FilePath& file_path); // Sets the tags on a given file or folder. BASE_EXPORT void SetFileTags(const FilePath& file_path, const std::vector& file_tags); // The following two functions return the version of the macOS currently // running. MacOSVersion() returns the full trio of version numbers, packed into // one int (e.g. macOS 12.6.5 returns 12'06'05), and MacOSMajorVersion() returns // only the major version number (e.g. macOS 12.6.5 returns 12). Use for runtime // OS version checking. Prefer to use @available in Objective-C files. Note that // this does not include any Rapid Security Response (RSR) suffixes (the "(a)" // at the end of version numbers.) BASE_EXPORT __attribute__((const)) int MacOSVersion(); inline __attribute__((const)) int MacOSMajorVersion() { return MacOSVersion() / 1'00'00; } enum class CPUType { kIntel, kTranslatedIntel, // Rosetta kArm, }; // Returns the type of CPU this is being executed on. BASE_EXPORT CPUType GetCPUType(); // Returns an OS name + version string. e.g.: // // "macOS Version 10.14.3 (Build 18D109)" // // Parts of this string change based on OS locale, so it's only useful for // displaying to the user. BASE_EXPORT std::string GetOSDisplayName(); // Returns the serial number of the macOS device. BASE_EXPORT std::string GetPlatformSerialNumber(); // System Settings (née System Preferences) pane or subpanes to open via // `OpenSystemSettingsPane()`, below. The naming is based on the naming in the // System Settings app in the latest macOS release, macOS 13 Ventura. enum class SystemSettingsPane { // Accessibility > Captions kAccessibility_Captions, // Date & Time kDateTime, // Network > Proxies kNetwork_Proxies, // Notifications; optionally pass a bundle identifier as `id_param` to // directly open the notification settings page for the given app. kNotifications, // Printers & Scanners kPrintersScanners, // Privacy & Security > Accessibility kPrivacySecurity_Accessibility, // Privacy & Security > Bluetooth // Available on macOS 11 and later. kPrivacySecurity_Bluetooth, // Privacy & Security > Camera kPrivacySecurity_Camera, // Privacy & Security > Extensions > Sharing kPrivacySecurity_Extensions_Sharing, // Privacy & Security > Location Services kPrivacySecurity_LocationServices, // Privacy & Security > Microphone kPrivacySecurity_Microphone, // Privacy & Security > Screen Recording kPrivacySecurity_ScreenRecording, // Trackpad kTrackpad, }; // Opens the specified System Settings pane. If the specified subpane does not // exist on the release of macOS that is running, the parent pane will open // instead. For some panes, `id_param` can be used to specify a subpane. See the // various SystemSettingsPane values for details. BASE_EXPORT void OpenSystemSettingsPane(SystemSettingsPane pane, const std::string& id_param = ""); // ------- For testing -------- // An implementation detail of `MacOSVersion()` above, exposed for testing. BASE_EXPORT int ParseOSProductVersionForTesting( const std::string_view& version); } // namespace base::mac #endif // BASE_MAC_MAC_UTIL_H_