File: notimplemented.h

package info (click to toggle)
chromium 138.0.7204.183-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 6,071,908 kB
  • sloc: cpp: 34,937,088; ansic: 7,176,967; javascript: 4,110,704; python: 1,419,953; asm: 946,768; xml: 739,971; pascal: 187,324; sh: 89,623; perl: 88,663; objc: 79,944; sql: 50,304; cs: 41,786; fortran: 24,137; makefile: 21,806; php: 13,980; tcl: 13,166; yacc: 8,925; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (49 lines) | stat: -rw-r--r-- 2,287 bytes parent folder | download | duplicates (5)
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
// Copyright 2024 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_NOTIMPLEMENTED_H_
#define BASE_NOTIMPLEMENTED_H_

#include "base/check.h"
#include "base/dcheck_is_on.h"

// The NOTIMPLEMENTED() macro annotates codepaths which have not been
// implemented yet. If output spam is a serious concern,
// NOTIMPLEMENTED_LOG_ONCE() can be used.
#if DCHECK_IS_ON()
#define NOTIMPLEMENTED() \
  ::logging::CheckError::NotImplemented(__PRETTY_FUNCTION__)

// The lambda returns false the first time it is run, and true every other time.
// Note that the `static const bool call_once` trickery is used for thread
// safety (C++11 guarantees that `call_once` is only initialized once, no UB
// even if two threads enter concurrently).
#define NOTIMPLEMENTED_LOG_ONCE()                                      \
  switch (0)                                                           \
  case 0:                                                              \
  default:                                                             \
    if ([] {                                                           \
          bool old_value = true;                                       \
          [[maybe_unused]] static const bool call_once = [](bool* b) { \
            *b = false;                                                \
            return true;                                               \
          }(&old_value);                                               \
          return old_value;                                            \
        }())                                                           \
      ;                                                                \
    else                                                               \
      NOTIMPLEMENTED()

// The TVOS_NOT_YET_IMPLEMENTED() macro marks code paths that have not yet been
// implemented for tvOS.
#define TVOS_NOT_YET_IMPLEMENTED() \
  ::logging::CheckError::NotImplemented(__PRETTY_FUNCTION__)

#else
#define NOTIMPLEMENTED() EAT_CHECK_STREAM_PARAMS()
#define NOTIMPLEMENTED_LOG_ONCE() EAT_CHECK_STREAM_PARAMS()
#define TVOS_NOT_YET_IMPLEMENTED() EAT_CHECK_STREAM_PARAMS()
#endif

#endif  // BASE_NOTIMPLEMENTED_H_