OLD | NEW |
1 #include "DMReporter.h" | 1 #include "DMReporter.h" |
2 | 2 |
3 #include "SkCommandLineFlags.h" | 3 #include "SkCommandLineFlags.h" |
4 #include "OverwriteLine.h" | 4 #include "OverwriteLine.h" |
5 | 5 |
6 DEFINE_bool2(quiet, q, false, "If true, don't print status updates."); | 6 DEFINE_bool2(quiet, q, false, "If true, don't print status updates."); |
7 DEFINE_bool2(verbose, v, false, "If true, print status updates one-per-line."); | 7 DEFINE_bool2(verbose, v, false, "If true, print status updates one-per-line."); |
8 | 8 |
9 namespace DM { | 9 namespace DM { |
10 | 10 |
11 void Reporter::finish(SkString name) { | 11 void Reporter::finish(SkString name) { |
12 sk_atomic_inc(&fFinished); | 12 sk_atomic_inc(&fFinished); |
13 | 13 |
14 if (FLAGS_quiet) { | 14 if (FLAGS_quiet) { |
15 return; | 15 return; |
16 } | 16 } |
17 | 17 |
18 SkString status; | 18 SkString status; |
19 status.printf("%s%d tasks left", | 19 status.printf("%s%d tasks left", |
20 FLAGS_verbose ? "\n" : kSkOverwriteLine, | 20 FLAGS_verbose ? "\n" : kSkOverwriteLine, |
21 this->started() - this->finished()); | 21 this->started() - this->finished()); |
22 const int failed = this->failed(); | 22 const int failed = this->failed(); |
23 if (failed > 0) { | 23 if (failed > 0) { |
24 status.appendf(", %d failed", failed); | 24 status.appendf(", %d failed", failed); |
25 } | 25 } |
26 status.appendf("\t[%s done]", name.c_str()); | 26 status.appendf("\t[%s done]", name.c_str()); |
27 SkDebugf(status.c_str()); | 27 SkDebugf("%s", status.c_str()); |
28 } | 28 } |
29 | 29 |
30 int32_t Reporter::failed() const { | 30 int32_t Reporter::failed() const { |
31 SkAutoMutexAcquire reader(&fMutex); | 31 SkAutoMutexAcquire reader(&fMutex); |
32 return fFailures.count(); | 32 return fFailures.count(); |
33 } | 33 } |
34 | 34 |
35 void Reporter::fail(SkString msg) { | 35 void Reporter::fail(SkString msg) { |
36 SkAutoMutexAcquire writer(&fMutex); | 36 SkAutoMutexAcquire writer(&fMutex); |
37 fFailures.push_back(msg); | 37 fFailures.push_back(msg); |
38 } | 38 } |
39 | 39 |
40 void Reporter::getFailures(SkTArray<SkString>* failures) const { | 40 void Reporter::getFailures(SkTArray<SkString>* failures) const { |
41 SkAutoMutexAcquire reader(&fMutex); | 41 SkAutoMutexAcquire reader(&fMutex); |
42 *failures = fFailures; | 42 *failures = fFailures; |
43 } | 43 } |
44 | 44 |
45 } // namespace DM | 45 } // namespace DM |
OLD | NEW |