xref: /aosp_15_r20/external/cronet/base/trace_event/log_message.cc (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker // Copyright 2019 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker 
5*6777b538SAndroid Build Coastguard Worker #include "base/trace_event/log_message.h"
6*6777b538SAndroid Build Coastguard Worker 
7*6777b538SAndroid Build Coastguard Worker #include <stdint.h>
8*6777b538SAndroid Build Coastguard Worker 
9*6777b538SAndroid Build Coastguard Worker #include <string>
10*6777b538SAndroid Build Coastguard Worker #include <string_view>
11*6777b538SAndroid Build Coastguard Worker 
12*6777b538SAndroid Build Coastguard Worker #include "base/json/string_escape.h"
13*6777b538SAndroid Build Coastguard Worker #include "base/notreached.h"
14*6777b538SAndroid Build Coastguard Worker #include "base/strings/stringprintf.h"
15*6777b538SAndroid Build Coastguard Worker 
16*6777b538SAndroid Build Coastguard Worker namespace base {
17*6777b538SAndroid Build Coastguard Worker namespace trace_event {
18*6777b538SAndroid Build Coastguard Worker 
LogMessage(const char * file,std::string_view message,int line)19*6777b538SAndroid Build Coastguard Worker LogMessage::LogMessage(const char* file, std::string_view message, int line)
20*6777b538SAndroid Build Coastguard Worker     : file_(file), message_(message), line_number_(line) {}
21*6777b538SAndroid Build Coastguard Worker 
22*6777b538SAndroid Build Coastguard Worker LogMessage::~LogMessage() = default;
23*6777b538SAndroid Build Coastguard Worker 
AppendAsTraceFormat(std::string * out) const24*6777b538SAndroid Build Coastguard Worker void LogMessage::AppendAsTraceFormat(std::string* out) const {
25*6777b538SAndroid Build Coastguard Worker   out->append("{");
26*6777b538SAndroid Build Coastguard Worker   out->append(base::StringPrintf("\"line\":\"%d\",", line_number_));
27*6777b538SAndroid Build Coastguard Worker   out->append("\"message\":");
28*6777b538SAndroid Build Coastguard Worker   base::EscapeJSONString(message_, true, out);
29*6777b538SAndroid Build Coastguard Worker   out->append(",");
30*6777b538SAndroid Build Coastguard Worker   out->append(base::StringPrintf("\"file\":\"%s\"", file_));
31*6777b538SAndroid Build Coastguard Worker   out->append("}");
32*6777b538SAndroid Build Coastguard Worker }
33*6777b538SAndroid Build Coastguard Worker 
EstimateTraceMemoryOverhead(TraceEventMemoryOverhead * overhead)34*6777b538SAndroid Build Coastguard Worker void LogMessage::EstimateTraceMemoryOverhead(
35*6777b538SAndroid Build Coastguard Worker     TraceEventMemoryOverhead* overhead) {
36*6777b538SAndroid Build Coastguard Worker   overhead->Add(TraceEventMemoryOverhead::kOther, sizeof(*this));
37*6777b538SAndroid Build Coastguard Worker   overhead->AddString(message_);
38*6777b538SAndroid Build Coastguard Worker }
39*6777b538SAndroid Build Coastguard Worker 
AppendToProto(ProtoAppender * appender) const40*6777b538SAndroid Build Coastguard Worker bool LogMessage::AppendToProto(ProtoAppender* appender) const {
41*6777b538SAndroid Build Coastguard Worker   // LogMessage is handled in a special way in
42*6777b538SAndroid Build Coastguard Worker   // track_event_thread_local_event_sink.cc in the function |AddTraceEvent|, so
43*6777b538SAndroid Build Coastguard Worker   // this call should never happen.
44*6777b538SAndroid Build Coastguard Worker   NOTREACHED();
45*6777b538SAndroid Build Coastguard Worker   return false;
46*6777b538SAndroid Build Coastguard Worker }
47*6777b538SAndroid Build Coastguard Worker 
48*6777b538SAndroid Build Coastguard Worker }  // namespace trace_event
49*6777b538SAndroid Build Coastguard Worker }  // namespace base
50