File: ProcessWindowsLog.h

package info (click to toggle)
llvm-toolchain-3.8 1%3A3.8.1-24
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 379,280 kB
  • ctags: 388,501
  • sloc: cpp: 2,309,705; ansic: 477,070; objc: 100,918; asm: 97,974; python: 95,911; sh: 18,634; makefile: 7,294; perl: 5,584; ml: 5,460; pascal: 4,661; lisp: 2,548; xml: 686; cs: 350; php: 212; csh: 117
file content (96 lines) | stat: -rw-r--r-- 3,577 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
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
//===-- ProcessWindowsLog.h -------------------------------------*- C++ -*-===//
//
//                     The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//

#ifndef liblldb_ProcessWindowsLog_h_
#define liblldb_ProcessWindowsLog_h_

#include "lldb/Core/Log.h"

#define WINDOWS_LOG_VERBOSE     (1u << 0)
#define WINDOWS_LOG_PROCESS     (1u << 1)    // Log process operations
#define WINDOWS_LOG_EXCEPTION   (1u << 1)    // Log exceptions
#define WINDOWS_LOG_THREAD      (1u << 2)    // Log thread operations
#define WINDOWS_LOG_MEMORY      (1u << 3)    // Log memory reads/writes calls
#define WINDOWS_LOG_BREAKPOINTS (1u << 4)    // Log breakpoint operations
#define WINDOWS_LOG_STEP        (1u << 5)    // Log step operations
#define WINDOWS_LOG_REGISTERS   (1u << 6)    // Log register operations
#define WINDOWS_LOG_EVENT       (1u << 7)    // Low level debug events
#define WINDOWS_LOG_ALL         (UINT32_MAX)

enum class LogMaskReq
{
    All,
    Any
};

class ProcessWindowsLog
{
    static const char *m_pluginname;

public:
    // ---------------------------------------------------------------------
    // Public Static Methods
    // ---------------------------------------------------------------------
    static void
    Initialize();

    static void
    Terminate();

    static void
    RegisterPluginName(const char *pluginName)
    {
        m_pluginname = pluginName;
    }

    static void
    RegisterPluginName(lldb_private::ConstString pluginName)
    {
        m_pluginname = pluginName.GetCString();
    }

    static bool
    TestLogFlags(uint32_t mask, LogMaskReq req);

    static lldb_private::Log *
    GetLog();

    static void
    DisableLog(const char **args, lldb_private::Stream *feedback_strm);

    static lldb_private::Log *
    EnableLog(lldb::StreamSP &log_stream_sp, uint32_t log_options,
               const char **args, lldb_private::Stream *feedback_strm);

    static void
    ListLogCategories(lldb_private::Stream *strm);
};

#define WINLOGF_IF(Flags, Req, Method, ...)              \
    {                                                    \
        if (ProcessWindowsLog::TestLogFlags(Flags, Req)) \
        {                                                \
            Log *log = ProcessWindowsLog::GetLog();      \
            if (log)                                     \
                log->Method(__VA_ARGS__);                \
        }                                                \
    }

#define WINLOG_IFANY(Flags, ...) WINLOGF_IF(Flags, LogMaskReq::Any, Printf, __VA_ARGS__)
#define WINLOG_IFALL(Flags, ...) WINLOGF_IF(Flags, LogMaskReq::All, Printf, __VA_ARGS__)
#define WINLOGV_IFANY(Flags, ...) WINLOGF_IF(Flags, LogMaskReq::Any, Verbose, __VA_ARGS__)
#define WINLOGV_IFALL(Flags, ...) WINLOGF_IF(Flags, LogMaskReq::All, Verbose, __VA_ARGS__)
#define WINLOGD_IFANY(Flags, ...) WINLOGF_IF(Flags, LogMaskReq::Any, Debug, __VA_ARGS__)
#define WINLOGD_IFALL(Flags, ...) WINLOGF_IF(Flags, LogMaskReq::All, Debug, __VA_ARGS__)
#define WINERR_IFANY(Flags, ...) WINLOGF_IF(Flags, LogMaskReq::Any, Error, __VA_ARGS__)
#define WINERR_IFALL(Flags, ...) WINLOGF_IF(Flags, LogMaskReq::All, Error, __VA_ARGS__)
#define WINWARN_IFANY(Flags, ...) WINLOGF_IF(Flags, LogMaskReq::Any, Warning, __VA_ARGS__)
#define WINWARN_IFALL(Flags, ...) WINLOGF_IF(Flags, LogMaskReq::All, Warning, __VA_ARGS__)

#endif  // liblldb_ProcessWindowsLog_h_