blob: 7c02059fc57d705084cb2fe5a02473c72f441a6a (
plain)
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
|
//===-- LogMessageOsLog.h ---------------------------------------*- C++ -*-===//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
#ifndef LogMessageOsLog_h
#define LogMessageOsLog_h
#include "DarwinLogInterfaces.h"
#include "ActivityStreamSPI.h"
#include "LogMessage.h"
using ActivityStreamEntry = struct os_activity_stream_entry_s;
// -----------------------------------------------------------------------------
/// Provides a unified wrapper around os_log()-style log messages.
///
/// The lifetime of this class is intended to be very short. The caller
/// must ensure that the passed in ActivityStore and ActivityStreamEntry
/// outlive this LogMessageOsLog entry.
// -----------------------------------------------------------------------------
class LogMessageOsLog : public LogMessage
{
public:
static void
SetFormatterFunction(os_log_copy_formatted_message_t format_func);
LogMessageOsLog(const ActivityStore &activity_store,
ActivityStreamEntry &entry);
// API methods
bool
HasActivity() const override;
const char*
GetActivity() const override;
std::string
GetActivityChain() const override;
bool
HasCategory() const override;
const char*
GetCategory() const override;
bool
HasSubsystem() const override;
const char*
GetSubsystem() const override;
const char*
GetMessage() const override;
private:
const ActivityStore &m_activity_store;
ActivityStreamEntry &m_entry;
mutable std::string m_message;
};
#endif /* LogMessageOsLog_h */
|