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

Unified Diff: dart/runtime/lib/string_buffer_patch.dart

Issue 12296011: Version 0.3.7.4 (Closed) Base URL: http://dart.googlecode.com/svn/trunk/
Patch Set: Created 7 years, 10 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « dart/runtime/lib/growable_array.dart ('k') | dart/samples/swarm/swarm_ui_lib/observable/observable.dart » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: dart/runtime/lib/string_buffer_patch.dart
===================================================================
--- dart/runtime/lib/string_buffer_patch.dart (revision 18634)
+++ dart/runtime/lib/string_buffer_patch.dart (working copy)
@@ -2,58 +2,45 @@
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
-patch /* abstract */ class StringBuffer {
- /* patch */ factory StringBuffer([Object content = ""])
- => new _StringBufferImpl(content);
-}
-
-class _StringBufferImpl implements StringBuffer {
-
+patch class StringBuffer {
List<String> _buffer;
int _length;
/// Creates the string buffer with an initial content.
- _StringBufferImpl(Object content) {
- clear();
- add(content);
+ /* patch */ StringBuffer([Object content = ""]) {
+ _buffer = new List<String>();
+ _length = 0;
+ write(content);
}
- /// Returns the length of the buffer.
- int get length => _length;
+ /* patch */ int get length => _length;
- bool get isEmpty => _length == 0;
-
/// Adds [obj] to the buffer.
- void add(Object obj) {
+ /* patch */ void write(Object obj) {
// TODO(srdjan): The following four lines could be replaced by
// '$obj', but apparently this is too slow on the Dart VM.
- String str = obj.toString();
- if (str is !String) {
- throw new ArgumentError('toString() did not return a string');
+ String str;
+ if (obj is String) {
+ str = obj;
+ } else {
+ str = obj.toString();
+ if (str is! String) {
+ throw new ArgumentError('toString() did not return a string');
+ }
}
if (str.isEmpty) return;
_buffer.add(str);
_length += str.length;
}
- /// Adds all items in [objects] to the buffer.
- void addAll(Iterable objects) {
- for (Object obj in objects) add(obj);
- }
-
- /// Adds the string representation of [charCode] to the buffer.
- void addCharCode(int charCode) {
- add(new String.fromCharCodes([charCode]));
- }
-
/// Clears the string buffer.
- void clear() {
+ /* patch */ void clear() {
_buffer = new List<String>();
_length = 0;
}
/// Returns the contents of buffer as a concatenated string.
- String toString() {
+ /* patch */ String toString() {
if (_buffer.length == 0) return "";
if (_buffer.length == 1) return _buffer[0];
String result = Strings.concatAll(_buffer);
« no previous file with comments | « dart/runtime/lib/growable_array.dart ('k') | dart/samples/swarm/swarm_ui_lib/observable/observable.dart » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698