File: port_chromium.h

package info (click to toggle)
chromium 139.0.7258.127-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 6,122,068 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 (99 lines) | stat: -rw-r--r-- 3,087 bytes parent folder | download | duplicates (11)
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
// Copyright (c) 2011 The LevelDB Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. See the AUTHORS file for names of contributors.
//
// See port_example.h for documentation for the following types/functions.

#ifndef STORAGE_LEVELDB_PORT_PORT_CHROMIUM_H_
#define STORAGE_LEVELDB_PORT_PORT_CHROMIUM_H_

#include <cstddef>
#include <cstdint>
#include <string>

#include "base/check.h"
#include "base/synchronization/condition_variable.h"
#include "base/synchronization/lock.h"
#include "base/thread_annotations.h"
#include "base/threading/thread_restrictions.h"

namespace leveldb {
namespace port {

class LOCKABLE Mutex {
 public:
  Mutex() = default;
  ~Mutex() = default;

  Mutex(const Mutex&) = delete;
  Mutex& operator=(const Mutex&) = delete;

  void Lock() EXCLUSIVE_LOCK_FUNCTION() { lock_.Acquire(); }
  void Unlock() UNLOCK_FUNCTION() { lock_.Release(); }
  void AssertHeld() ASSERT_EXCLUSIVE_LOCK() { lock_.AssertAcquired(); }

 private:
  friend class CondVar;
  base::Lock lock_;
};

// Thinly wraps base::ConditionVariable.
class CondVar {
 public:
  explicit CondVar(Mutex* mu) : cv_(&mu->lock_) { DCHECK(mu); }
  ~CondVar() = default;

  CondVar(const CondVar&) = delete;
  CondVar& operator=(const CondVar&) = delete;

  void Wait() {
    // This is an allowed use of base-sync-primitives.
    // LevelDB has a different I/O model than Chromium - it uses condition
    // variables to coordinate batch writes for efficiency, among other things.
    // Since use of base::ConditionVariable is an implementation detail of
    // Chromium's port, this is a better option than annotating all upstream
    // call sites with a ScopedAllow, which would leave us vulnerable to
    // upstream changes adding a Wait(). See https://crbug.com/1330845.
    base::ScopedAllowBaseSyncPrimitives allow_base_sync_primitives;
    cv_.Wait();
  }
  void Signal() { cv_.Signal(); }
  void SignalAll() { cv_.Broadcast(); }

 private:
  base::ConditionVariable cv_;
};

bool Snappy_Compress(const char* input, size_t input_length,
                     std::string* output);
bool Snappy_GetUncompressedLength(const char* input, size_t length,
                                  size_t* result);
bool Snappy_Uncompress(const char* input_data, size_t input_length,
                       char* output);

inline bool Zstd_Compress(int level,
                          const char* input,
                          size_t length,
                          std::string* output) {
  return false;
}

inline bool Zstd_GetUncompressedLength(const char* input, size_t length,
                                       size_t* result) {
  return false;
}

inline bool Zstd_Uncompress(const char* input, size_t length, char* output) {
  return false;
}

inline bool GetHeapProfile(void (*func)(void*, const char*, int), void* arg) {
  return false;
}

uint32_t AcceleratedCRC32C(uint32_t crc, const char* buf, size_t size);

}  // namespace port
}  // namespace leveldb

#endif  // STORAGE_LEVELDB_PORT_PORT_CHROMIUM_H_