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

Unified Diff: packages/barback/test/transformer/check_content_and_rename.dart

Issue 1400473008: Roll Observatory packages and add a roll script (Closed) Base URL: git@github.com:dart-lang/observatory_pub_packages.git@master
Patch Set: Created 5 years, 2 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
Index: packages/barback/test/transformer/check_content_and_rename.dart
diff --git a/packages/barback/test/transformer/check_content_and_rename.dart b/packages/barback/test/transformer/check_content_and_rename.dart
new file mode 100644
index 0000000000000000000000000000000000000000..dffad3798e39f296680c754bfd79ecbc9decb8a4
--- /dev/null
+++ b/packages/barback/test/transformer/check_content_and_rename.dart
@@ -0,0 +1,41 @@
+// Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file
+// 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.
+
+library barback.test.transformer.check_content_and_rename;
+
+import 'dart:async';
+
+import 'package:barback/barback.dart';
+
+import 'mock.dart';
+
+/// A transformer that checks the extension and content of an asset, then
+/// produces a new asset with a new extension and new content.
+class CheckContentAndRenameTransformer extends MockTransformer {
+ final String oldExtension;
+ final String oldContent;
+ final String newExtension;
+ final String newContent;
+
+ CheckContentAndRenameTransformer({this.oldExtension, this.oldContent,
+ this.newExtension, this.newContent}) {
+ assert(oldExtension != null);
+ assert(oldContent != null);
+ assert(newExtension != null);
+ assert(newContent != null);
+ }
+
+ bool doIsPrimary(AssetId id) => id.extension == '.$oldExtension';
+
+ Future doApply(Transform transform) {
+ return getPrimary(transform).then((input) {
+ return input.readAsString().then((contents) {
+ if (contents != oldContent) return;
+
+ transform.addOutput(new Asset.fromString(
+ input.id.changeExtension('.$newExtension'), newContent));
+ });
+ });
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698