xref: /aosp_15_r20/external/google-breakpad/src/processor/logging.cc (revision 9712c20fc9bbfbac4935993a2ca0b3958c5adad2)
1*9712c20fSFrederick Mayle // Copyright 2007 Google LLC
2*9712c20fSFrederick Mayle //
3*9712c20fSFrederick Mayle // Redistribution and use in source and binary forms, with or without
4*9712c20fSFrederick Mayle // modification, are permitted provided that the following conditions are
5*9712c20fSFrederick Mayle // met:
6*9712c20fSFrederick Mayle //
7*9712c20fSFrederick Mayle //     * Redistributions of source code must retain the above copyright
8*9712c20fSFrederick Mayle // notice, this list of conditions and the following disclaimer.
9*9712c20fSFrederick Mayle //     * Redistributions in binary form must reproduce the above
10*9712c20fSFrederick Mayle // copyright notice, this list of conditions and the following disclaimer
11*9712c20fSFrederick Mayle // in the documentation and/or other materials provided with the
12*9712c20fSFrederick Mayle // distribution.
13*9712c20fSFrederick Mayle //     * Neither the name of Google LLC nor the names of its
14*9712c20fSFrederick Mayle // contributors may be used to endorse or promote products derived from
15*9712c20fSFrederick Mayle // this software without specific prior written permission.
16*9712c20fSFrederick Mayle //
17*9712c20fSFrederick Mayle // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18*9712c20fSFrederick Mayle // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19*9712c20fSFrederick Mayle // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20*9712c20fSFrederick Mayle // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
21*9712c20fSFrederick Mayle // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
22*9712c20fSFrederick Mayle // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
23*9712c20fSFrederick Mayle // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24*9712c20fSFrederick Mayle // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25*9712c20fSFrederick Mayle // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26*9712c20fSFrederick Mayle // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
27*9712c20fSFrederick Mayle // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28*9712c20fSFrederick Mayle 
29*9712c20fSFrederick Mayle // logging.cc: Breakpad logging
30*9712c20fSFrederick Mayle //
31*9712c20fSFrederick Mayle // See logging.h for documentation.
32*9712c20fSFrederick Mayle //
33*9712c20fSFrederick Mayle // Author: Mark Mentovai
34*9712c20fSFrederick Mayle 
35*9712c20fSFrederick Mayle #ifdef HAVE_CONFIG_H
36*9712c20fSFrederick Mayle #include <config.h>  // Must come first
37*9712c20fSFrederick Mayle #endif
38*9712c20fSFrederick Mayle 
39*9712c20fSFrederick Mayle #include <assert.h>
40*9712c20fSFrederick Mayle #include <errno.h>
41*9712c20fSFrederick Mayle #include <string.h>
42*9712c20fSFrederick Mayle #include <time.h>
43*9712c20fSFrederick Mayle 
44*9712c20fSFrederick Mayle #include <string>
45*9712c20fSFrederick Mayle 
46*9712c20fSFrederick Mayle #include "common/stdio_wrapper.h"
47*9712c20fSFrederick Mayle #include "common/using_std_string.h"
48*9712c20fSFrederick Mayle #include "processor/logging.h"
49*9712c20fSFrederick Mayle #include "processor/pathname_stripper.h"
50*9712c20fSFrederick Mayle 
51*9712c20fSFrederick Mayle namespace google_breakpad {
52*9712c20fSFrederick Mayle 
LogStream(std::ostream & stream,Severity severity,const char * file,int line)53*9712c20fSFrederick Mayle LogStream::LogStream(std::ostream& stream, Severity severity,
54*9712c20fSFrederick Mayle                      const char* file, int line)
55*9712c20fSFrederick Mayle     : stream_(stream) {
56*9712c20fSFrederick Mayle   time_t clock;
57*9712c20fSFrederick Mayle   time(&clock);
58*9712c20fSFrederick Mayle   struct tm tm_struct;
59*9712c20fSFrederick Mayle #ifdef _WIN32
60*9712c20fSFrederick Mayle   localtime_s(&tm_struct, &clock);
61*9712c20fSFrederick Mayle #else
62*9712c20fSFrederick Mayle   localtime_r(&clock, &tm_struct);
63*9712c20fSFrederick Mayle #endif
64*9712c20fSFrederick Mayle   char time_string[20];
65*9712c20fSFrederick Mayle   strftime(time_string, sizeof(time_string), "%Y-%m-%d %H:%M:%S", &tm_struct);
66*9712c20fSFrederick Mayle 
67*9712c20fSFrederick Mayle   const char* severity_string = "UNKNOWN_SEVERITY";
68*9712c20fSFrederick Mayle   switch (severity) {
69*9712c20fSFrederick Mayle     case SEVERITY_INFO:
70*9712c20fSFrederick Mayle       severity_string = "INFO";
71*9712c20fSFrederick Mayle       break;
72*9712c20fSFrederick Mayle     case SEVERITY_ERROR:
73*9712c20fSFrederick Mayle       severity_string = "ERROR";
74*9712c20fSFrederick Mayle       break;
75*9712c20fSFrederick Mayle     case SEVERITY_CRITICAL:
76*9712c20fSFrederick Mayle       severity_string = "CRITICAL";
77*9712c20fSFrederick Mayle       break;
78*9712c20fSFrederick Mayle   }
79*9712c20fSFrederick Mayle 
80*9712c20fSFrederick Mayle   stream_ << time_string << ": " << PathnameStripper::File(file) << ":" <<
81*9712c20fSFrederick Mayle              line << ": " << severity_string << ": ";
82*9712c20fSFrederick Mayle }
83*9712c20fSFrederick Mayle 
~LogStream()84*9712c20fSFrederick Mayle LogStream::~LogStream() {
85*9712c20fSFrederick Mayle   stream_ << std::endl;
86*9712c20fSFrederick Mayle }
87*9712c20fSFrederick Mayle 
HexString(uint32_t number)88*9712c20fSFrederick Mayle string HexString(uint32_t number) {
89*9712c20fSFrederick Mayle   char buffer[11];
90*9712c20fSFrederick Mayle   snprintf(buffer, sizeof(buffer), "0x%x", number);
91*9712c20fSFrederick Mayle   return string(buffer);
92*9712c20fSFrederick Mayle }
93*9712c20fSFrederick Mayle 
HexString(uint64_t number)94*9712c20fSFrederick Mayle string HexString(uint64_t number) {
95*9712c20fSFrederick Mayle   char buffer[19];
96*9712c20fSFrederick Mayle   snprintf(buffer, sizeof(buffer), "0x%" PRIx64, number);
97*9712c20fSFrederick Mayle   return string(buffer);
98*9712c20fSFrederick Mayle }
99*9712c20fSFrederick Mayle 
HexString(int number)100*9712c20fSFrederick Mayle string HexString(int number) {
101*9712c20fSFrederick Mayle   char buffer[19];
102*9712c20fSFrederick Mayle   snprintf(buffer, sizeof(buffer), "0x%x", number);
103*9712c20fSFrederick Mayle   return string(buffer);
104*9712c20fSFrederick Mayle }
105*9712c20fSFrederick Mayle 
ErrnoString(string * error_string)106*9712c20fSFrederick Mayle int ErrnoString(string* error_string) {
107*9712c20fSFrederick Mayle   assert(error_string);
108*9712c20fSFrederick Mayle 
109*9712c20fSFrederick Mayle   // strerror isn't necessarily thread-safe.  strerror_r would be preferrable,
110*9712c20fSFrederick Mayle   // but GNU libc uses a nonstandard strerror_r by default, which returns a
111*9712c20fSFrederick Mayle   // char* (rather than an int success indicator) and doesn't necessarily
112*9712c20fSFrederick Mayle   // use the supplied buffer.
113*9712c20fSFrederick Mayle   error_string->assign(strerror(errno));
114*9712c20fSFrederick Mayle   return errno;
115*9712c20fSFrederick Mayle }
116*9712c20fSFrederick Mayle 
117*9712c20fSFrederick Mayle }  // namespace google_breakpad
118