| OLD | NEW |
| 1 // Copyright 2009 the V8 project authors. All rights reserved. | 1 // Copyright 2009 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 276 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 287 continue; | 287 continue; |
| 288 } | 288 } |
| 289 if (line.charAt(0) == '#' || | 289 if (line.charAt(0) == '#' || |
| 290 line.substr(0, line.indexOf(',')) in this.backRefsCommands_) { | 290 line.substr(0, line.indexOf(',')) in this.backRefsCommands_) { |
| 291 line = this.expandBackRef_(line); | 291 line = this.expandBackRef_(line); |
| 292 } | 292 } |
| 293 var fields = csvParser.parseLine(line); | 293 var fields = csvParser.parseLine(line); |
| 294 this.dispatchLogRow_(fields); | 294 this.dispatchLogRow_(fields); |
| 295 } | 295 } |
| 296 } catch (e) { | 296 } catch (e) { |
| 297 this.printError('line ' + (i + 1) + ': ' + (e.message || e)); | 297 // An error on the last line is acceptable since log file can be truncated. |
| 298 throw e; | 298 if (i < n - 1) { |
| 299 this.printError('line ' + (i + 1) + ': ' + (e.message || e)); |
| 300 throw e; |
| 301 } |
| 299 } | 302 } |
| 300 }; | 303 }; |
| 301 | 304 |
| 302 | 305 |
| 303 /** | 306 /** |
| 304 * Processes repeat log record. Expands it according to calls count and | 307 * Processes repeat log record. Expands it according to calls count and |
| 305 * invokes processing. | 308 * invokes processing. |
| 306 * | 309 * |
| 307 * @param {number} count Count. | 310 * @param {number} count Count. |
| 308 * @param {Array.<string>} cmd Parsed command. | 311 * @param {Array.<string>} cmd Parsed command. |
| 309 * @private | 312 * @private |
| 310 */ | 313 */ |
| 311 devtools.profiler.LogReader.prototype.processRepeat_ = function(count, cmd) { | 314 devtools.profiler.LogReader.prototype.processRepeat_ = function(count, cmd) { |
| 312 // Replace the repeat-prefixed command from backrefs list with a non-prefixed. | 315 // Replace the repeat-prefixed command from backrefs list with a non-prefixed. |
| 313 this.backRefs_[0] = cmd.join(','); | 316 this.backRefs_[0] = cmd.join(','); |
| 314 for (var i = 0; i < count; ++i) { | 317 for (var i = 0; i < count; ++i) { |
| 315 this.dispatchLogRow_(cmd); | 318 this.dispatchLogRow_(cmd); |
| 316 } | 319 } |
| 317 }; | 320 }; |
| OLD | NEW |