File: image_writer_util_mac.cc

package info (click to toggle)
chromium 139.0.7258.127-2
  • links: PTS, VCS
  • area: main
  • in suites: forky
  • size: 6,122,156 kB
  • sloc: cpp: 35,100,771; ansic: 7,163,530; javascript: 4,103,002; python: 1,436,920; asm: 946,517; xml: 746,709; pascal: 187,653; perl: 88,691; sh: 88,436; objc: 79,953; sql: 51,488; cs: 44,583; fortran: 24,137; makefile: 22,147; tcl: 15,277; php: 13,980; yacc: 8,984; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (45 lines) | stat: -rw-r--r-- 1,435 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#include "chrome/common/extensions/image_writer/image_writer_util_mac.h"

#include <IOKit/storage/IOMedia.h>

#include "base/files/drive_info.h"

namespace extensions {

bool IsSuitableRemovableStorageDevice(io_object_t disk_obj,
                                      std::string* out_bsd_name,
                                      uint64_t* out_size_in_bytes,
                                      bool* out_removable) {
  std::optional<base::DriveInfo> info = base::GetIOObjectDriveInfo(disk_obj);
  if (!info.has_value()) {
    return false;
  }

  // Device must both be removable, and have USB. Do not allow APFS containers
  // or Core Storage volumes, even though they are marked as "whole media", as
  // they are entirely contained on a different volume.
  if (!info->is_removable.value_or(false) || !info->is_usb.value_or(false) ||
      info->is_apfs.value_or(false) || info->is_core_storage.value_or(false)) {
    return false;
  }

  if (out_size_in_bytes) {
    *out_size_in_bytes = info->size_bytes.value_or(0);
  }
  if (out_bsd_name) {
    *out_bsd_name = info->bsd_name.value_or(std::string());
  }

  if (out_removable) {
    // We already determined that removable has a value.
    *out_removable = *info->is_removable;
  }

  return true;
}

}  // namespace extensions