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

Side by Side Diff: pkg/barback/lib/src/serialize.dart

Issue 307543006: Add a "message" field to wrapped barback exceptions. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 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 | Annotate | Revision Log
« no previous file with comments | « pkg/barback/lib/src/errors.dart ('k') | pkg/barback/lib/src/utils.dart » ('j') | 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) 2013, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2013, 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 library barback.serialize; 5 library barback.serialize;
6 6
7 import 'dart:async'; 7 import 'dart:async';
8 import 'dart:isolate'; 8 import 'dart:isolate';
9 9
10 import 'package:stack_trace/stack_trace.dart'; 10 import 'package:stack_trace/stack_trace.dart';
(...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after
97 message = error['message'], 97 message = error['message'],
98 stackTrace = error['stack'] == null ? null : 98 stackTrace = error['stack'] == null ? null :
99 new Chain.parse(error['stack']); 99 new Chain.parse(error['stack']);
100 100
101 /// Serializes [error] to an object that can safely be passed across isolate 101 /// Serializes [error] to an object that can safely be passed across isolate
102 /// boundaries. 102 /// boundaries.
103 static Map serialize(error, [StackTrace stack]) { 103 static Map serialize(error, [StackTrace stack]) {
104 if (stack == null && error is Error) stack = error.stackTrace; 104 if (stack == null && error is Error) stack = error.stackTrace;
105 return { 105 return {
106 'type': error.runtimeType.toString(), 106 'type': error.runtimeType.toString(),
107 'message': _getErrorMessage(error), 107 'message': getErrorMessage(error),
108 'stack': stack == null ? null : new Chain.forTrace(stack).toString() 108 'stack': stack == null ? null : new Chain.forTrace(stack).toString()
109 }; 109 };
110 } 110 }
111 111
112 String toString() => "$message\n$stackTrace"; 112 String toString() => "$message\n$stackTrace";
113 } 113 }
114
115 /// A regular expression to match the exception prefix that some exceptions'
116 /// [Object.toString] values contain.
117 final _exceptionPrefix = new RegExp(r'^([A-Z][a-zA-Z]*)?(Exception|Error): ');
118
119 /// Get a string description of an exception.
120 ///
121 /// Many exceptions include the exception class name at the beginning of their
122 /// [toString], so we remove that if it exists.
123 String _getErrorMessage(error) =>
124 error.toString().replaceFirst(_exceptionPrefix, '');
OLDNEW
« no previous file with comments | « pkg/barback/lib/src/errors.dart ('k') | pkg/barback/lib/src/utils.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698