DXR is a code search and navigation tool aimed at making sense of large projects. It supports full-text and regex searches as well as structural queries.

Mercurial (50bba836b642)

VCS Links

Line Code
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
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this file,
 * You can obtain one at http://mozilla.org/MPL/2.0/. */

#ifndef Logging_h
#define Logging_h

#include "mozilla/Likely.h"
#include "mozilla/MacroArgs.h"

#ifdef ANDROID
#  include <android/log.h>
#  define LOG(...) \
    __android_log_print(ANDROID_LOG_INFO, "GeckoLinker", __VA_ARGS__)
#  define WARN(...) \
    __android_log_print(ANDROID_LOG_WARN, "GeckoLinker", __VA_ARGS__)
#  define ERROR(...) \
    __android_log_print(ANDROID_LOG_ERROR, "GeckoLinker", __VA_ARGS__)
#else
#  include <cstdio>

/* Expand to 1 or m depending on whether there is one argument or more
 * given. */
#  define MOZ_ONE_OR_MORE_ARGS_IMPL2(_1, _2, _3, _4, _5, _6, _7, _8, _9, N, \
                                     ...)                                   \
    N
#  define MOZ_ONE_OR_MORE_ARGS_IMPL(args) MOZ_ONE_OR_MORE_ARGS_IMPL2 args
#  define MOZ_ONE_OR_MORE_ARGS(...) \
    MOZ_ONE_OR_MORE_ARGS_IMPL((__VA_ARGS__, m, m, m, m, m, m, m, m, 1, 0))

#  define MOZ_MACRO_GLUE(a, b) a b

/* Some magic to choose between LOG1 and LOGm depending on the number of
 * arguments */
#  define MOZ_CHOOSE_LOG(...)                                          \
    MOZ_MACRO_GLUE(MOZ_CONCAT(LOG, MOZ_ONE_OR_MORE_ARGS(__VA_ARGS__)), \
                   (__VA_ARGS__))

#  define LOG1(format) fprintf(stderr, format "\n")
#  define LOGm(format, ...) fprintf(stderr, format "\n", __VA_ARGS__)
#  define LOG(...) MOZ_CHOOSE_LOG(__VA_ARGS__)
#  define WARN(...) MOZ_CHOOSE_LOG("Warning: " __VA_ARGS__)
#  define ERROR(...) MOZ_CHOOSE_LOG("Error: " __VA_ARGS__)

#endif

class Logging {
 public:
  static bool isVerbose() { return Singleton.verbose; }

 private:
  bool verbose;

 public:
  static void Init() {
    const char* env = getenv("MOZ_DEBUG_LINKER");
    if (env && *env == '1') Singleton.verbose = true;
  }

 private:
  static Logging Singleton;
};

#define DEBUG_LOG(...)                        \
  do {                                        \
    if (MOZ_UNLIKELY(Logging::isVerbose())) { \
      LOG(__VA_ARGS__);                       \
    }                                         \
  } while (0)

#endif /* Logging_h */