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

Side by Side Diff: processor/microdump.cc

Issue 1181113004: [microdump] Trim newline characters from input lines. (Closed) Base URL: https://chromium.googlesource.com/external/google-breakpad/src.git@master
Patch Set: Update for review comment. Created 5 years, 6 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
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2014 Google Inc. 1 // Copyright (c) 2014 Google Inc.
2 // All rights reserved. 2 // All rights reserved.
3 // 3 //
4 // Redistribution and use in source and binary forms, with or without 4 // Redistribution and use in source and binary forms, with or without
5 // modification, are permitted provided that the following conditions are 5 // modification, are permitted provided that the following conditions are
6 // met: 6 // met:
7 // 7 //
8 // * Redistributions of source code must retain the above copyright 8 // * Redistributions of source code must retain the above copyright
9 // notice, this list of conditions and the following disclaimer. 9 // notice, this list of conditions and the following disclaimer.
10 // * Redistributions in binary form must reproduce the above 10 // * Redistributions in binary form must reproduce the above
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after
69 } 69 }
70 70
71 std::vector<uint8_t> ParseHexBuf(const string& str) { 71 std::vector<uint8_t> ParseHexBuf(const string& str) {
72 std::vector<uint8_t> buf; 72 std::vector<uint8_t> buf;
73 for (size_t i = 0; i < str.length(); i += 2) { 73 for (size_t i = 0; i < str.length(); i += 2) {
74 buf.push_back(HexStrToL<uint8_t>(str.substr(i, 2))); 74 buf.push_back(HexStrToL<uint8_t>(str.substr(i, 2)));
75 } 75 }
76 return buf; 76 return buf;
77 } 77 }
78 78
79 bool GetLine(std::istringstream* istream, string* str) {
80 if (std::getline(*istream, *str)) {
81 // Trim any trailing newline from the end of the line. Allows us
82 // to seamlessly handle both Windows/DOS and Unix formatted input. The
83 // adb tool generally writes logcat dumps in Windows/DOS format.
84 if (!str->empty() && str->at(str->size() - 1) == '\r') {
85 str->erase(str->size() - 1);
86 }
87 return true;
88 }
89 return false;
90 }
91
79 } // namespace 92 } // namespace
80 93
81 namespace google_breakpad { 94 namespace google_breakpad {
82 95
83 // 96 //
84 // MicrodumpModules 97 // MicrodumpModules
85 // 98 //
86 99
87 void MicrodumpModules::Add(const CodeModule* module) { 100 void MicrodumpModules::Add(const CodeModule* module) {
88 linked_ptr<const CodeModule> module_ptr(module); 101 linked_ptr<const CodeModule> module_ptr(module);
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after
176 system_info_(new SystemInfo()) { 189 system_info_(new SystemInfo()) {
177 assert(!contents.empty()); 190 assert(!contents.empty());
178 191
179 bool in_microdump = false; 192 bool in_microdump = false;
180 string line; 193 string line;
181 uint64_t stack_start = 0; 194 uint64_t stack_start = 0;
182 std::vector<uint8_t> stack_content; 195 std::vector<uint8_t> stack_content;
183 string arch; 196 string arch;
184 197
185 std::istringstream stream(contents); 198 std::istringstream stream(contents);
186 while (std::getline(stream, line)) { 199 while (GetLine(&stream, &line)) {
187 if (line.find(kGoogleBreakpadKey) == string::npos) { 200 if (line.find(kGoogleBreakpadKey) == string::npos) {
188 continue; 201 continue;
189 } 202 }
190 if (line.find(kMicrodumpBegin) != string::npos) { 203 if (line.find(kMicrodumpBegin) != string::npos) {
191 in_microdump = true; 204 in_microdump = true;
192 continue; 205 continue;
193 } 206 }
194 if (line.find(kMicrodumpEnd) != string::npos) { 207 if (line.find(kMicrodumpEnd) != string::npos) {
195 break; 208 break;
196 } 209 }
(...skipping 10 matching lines...) Expand all
207 string num_cpus; 220 string num_cpus;
208 string os_version; 221 string os_version;
209 // This reflect the actual HW arch and might not match the arch emulated 222 // This reflect the actual HW arch and might not match the arch emulated
210 // for the execution (e.g., running a 32-bit binary on a 64-bit cpu). 223 // for the execution (e.g., running a 32-bit binary on a 64-bit cpu).
211 string hw_arch; 224 string hw_arch;
212 225
213 os_tokens >> os_id; 226 os_tokens >> os_id;
214 os_tokens >> arch; 227 os_tokens >> arch;
215 os_tokens >> num_cpus; 228 os_tokens >> num_cpus;
216 os_tokens >> hw_arch; 229 os_tokens >> hw_arch;
217 std::getline(os_tokens, os_version); 230 GetLine(&os_tokens, &os_version);
218 os_version.erase(0, 1); // remove leading space. 231 os_version.erase(0, 1); // remove leading space.
219 232
220 system_info_->cpu = hw_arch; 233 system_info_->cpu = hw_arch;
221 system_info_->cpu_count = HexStrToL<uint8_t>(num_cpus); 234 system_info_->cpu_count = HexStrToL<uint8_t>(num_cpus);
222 system_info_->os_version = os_version; 235 system_info_->os_version = os_version;
223 236
224 if (os_id == "L") { 237 if (os_id == "L") {
225 system_info_->os = "Linux"; 238 system_info_->os = "Linux";
226 system_info_->os_short = "linux"; 239 system_info_->os_short = "linux";
227 } else if (os_id == "A") { 240 } else if (os_id == "A") {
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after
297 filename, // debug_file 310 filename, // debug_file
298 identifier, // debug_identifier 311 identifier, // debug_identifier
299 "")); // version 312 "")); // version
300 } 313 }
301 } 314 }
302 stack_region_->Init(stack_start, stack_content); 315 stack_region_->Init(stack_start, stack_content);
303 } 316 }
304 317
305 } // namespace google_breakpad 318 } // namespace google_breakpad
306 319
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698