chromium/base/base_paths_ios.mm

// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

// Defines base::PathProviderIOS which replaces base::PathProviderPosix for iOS
// in base/path_service.cc.

#import <Foundation/Foundation.h>

#include "base/apple/bundle_locations.h"
#include "base/apple/foundation_util.h"
#include "base/base_paths.h"
#include "base/base_paths_apple.h"
#include "base/files/file_path.h"
#include "base/files/file_util.h"
#include "base/path_service.h"

namespace base {

bool PathProviderIOS(int key, base::FilePath* result) {
  switch (key) {
    case base::FILE_EXE:
      *result = base::apple::internal::GetExecutablePath();
      return true;

    case base::DIR_APP_DATA: {
      base::FilePath path;
      if (!base::apple::GetUserDirectory(NSApplicationSupportDirectory,
                                         &path)) {
        return false;
      }

      // On iOS, this directory does not exist unless it is created explicitly.
      if (!base::PathExists(path) && !base::CreateDirectory(path)) {
        return false;
      }

      *result = path;
      return true;
    }

    case base::DIR_SRC_TEST_DATA_ROOT:
    case base::DIR_OUT_TEST_DATA_ROOT:
      // On iOS, there is no access to source root, nor build dir,
      // however, the necessary resources are packaged into the
      // test app as assets.
      [[fallthrough]];

    case base::DIR_ASSETS:
      // On iOS, the resources are located at the root of the framework bundle.
      *result = base::apple::FrameworkBundlePath();
#if BUILDFLAG(IS_IOS_MACCATALYST)
      // When running in the catalyst environment (i.e. building an iOS app
      // to run on macOS), the bundles have the same structure as macOS, so
      // the resources are in the "Contents/Resources" sub-directory.
      *result = result->Append(FILE_PATH_LITERAL("Contents"))
                    .Append(FILE_PATH_LITERAL("Resources"));
#endif  // BUILDFLAG(IS_IOS_MACCATALYST)
      return true;

    case base::DIR_CACHE:
      return base::apple::GetUserDirectory(NSCachesDirectory, result);

    default:
      return false;
  }
}

}  // namespace base