Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(322)

Side by Side Diff: runtime/vm/log.h

Issue 1314673008: Migrate logging infrastructure Isolate->Thread (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Finalize marking tasks in parallel, now that it's safe. Created 5 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #ifndef VM_LOG_H_ 5 #ifndef VM_LOG_H_
6 #define VM_LOG_H_ 6 #define VM_LOG_H_
7 7
8 #include "vm/allocation.h" 8 #include "vm/allocation.h"
9 #include "vm/growable_array.h" 9 #include "vm/growable_array.h"
10 #include "vm/os.h" 10 #include "vm/os.h"
11 11
12 namespace dart { 12 namespace dart {
13 13
14 class Isolate;
15 class LogBlock; 14 class LogBlock;
16 class Thread; 15 class Thread;
17 16
17 // TODO(koda): Rename ISL_* -> THR_*.
Ivan Posva 2015/09/08 21:22:22 Why not do the rename right now?
koda 2015/09/09 00:26:57 Done.
18 #if defined(_MSC_VER) 18 #if defined(_MSC_VER)
19 #define ISL_Print(format, ...) \ 19 #define ISL_Print(format, ...) \
20 Isolate::Current()->Log()->Print(format, __VA_ARGS__) 20 Thread::Current()->Log()->Print(format, __VA_ARGS__)
21 #else 21 #else
22 #define ISL_Print(format, ...) \ 22 #define ISL_Print(format, ...) \
23 Isolate::Current()->Log()->Print(format, ##__VA_ARGS__) 23 Thread::Current()->Log()->Print(format, ##__VA_ARGS__)
24 #endif 24 #endif
25 25
26 #define ISL_VPrint(format, args) \ 26 #define ISL_VPrint(format, args) \
27 Isolate::Current()->Log()->VPrint(format, args) 27 Thread::Current()->Log()->VPrint(format, args)
28 28
29 typedef void (*LogPrinter)(const char* str, ...); 29 typedef void (*LogPrinter)(const char* str, ...);
30 30
31 class Log { 31 class Log {
32 public: 32 public:
33 explicit Log(LogPrinter printer = OS::Print); 33 explicit Log(LogPrinter printer = OS::Print);
34 34
35 // Append a formatted string to the log. 35 // Append a formatted string to the log.
36 void Print(const char* format, ...) PRINTF_ATTRIBUTE(2, 3); 36 void Print(const char* format, ...) PRINTF_ATTRIBUTE(2, 3);
37 37
(...skipping 25 matching lines...) Expand all
63 friend class LogBlock; 63 friend class LogBlock;
64 friend class LogTestHelper; 64 friend class LogTestHelper;
65 DISALLOW_COPY_AND_ASSIGN(Log); 65 DISALLOW_COPY_AND_ASSIGN(Log);
66 }; 66 };
67 67
68 68
69 // Causes all log messages to be buffered until destructor is called. 69 // Causes all log messages to be buffered until destructor is called.
70 // Can be nested. 70 // Can be nested.
71 class LogBlock : public StackResource { 71 class LogBlock : public StackResource {
72 public: 72 public:
73 LogBlock(Isolate* isolate, Log* log) 73 LogBlock(Thread* thread, Log* log)
74 : StackResource(isolate), 74 : StackResource(thread),
75 log_(log), cursor_(log->cursor()) { 75 log_(log), cursor_(log->cursor()) {
76 CommonConstructor(); 76 CommonConstructor();
77 } 77 }
78 78
79 explicit LogBlock(Isolate* isolate);
80 explicit LogBlock(Thread* thread); 79 explicit LogBlock(Thread* thread);
Ivan Posva 2015/09/08 21:22:22 Is there a particular reason to have this construc
koda 2015/09/09 00:26:57 Done.
81 80
82 LogBlock(Thread* thread, Log* log);
83
84 ~LogBlock() { 81 ~LogBlock() {
85 CommonDestructor(); 82 CommonDestructor();
Ivan Posva 2015/09/08 21:22:22 ditto. Please move to .cc file and remove the unn
koda 2015/09/09 00:26:57 Done.
86 } 83 }
87 84
88 private: 85 private:
89 void CommonConstructor() { 86 void CommonConstructor() {
90 log_->EnableManualFlush(); 87 log_->EnableManualFlush();
91 } 88 }
92 89
93 void CommonDestructor() { 90 void CommonDestructor() {
94 log_->Flush(cursor_); 91 log_->Flush(cursor_);
95 log_->DisableManualFlush(); 92 log_->DisableManualFlush();
96 } 93 }
97 Log* log_; 94 Log* log_;
98 const intptr_t cursor_; 95 const intptr_t cursor_;
99 }; 96 };
100 97
101 } // namespace dart 98 } // namespace dart
102 99
103 #endif // VM_LOG_H_ 100 #endif // VM_LOG_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698