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

Side by Side Diff: pkg/compiler/lib/src/js_backend/backend.dart

Issue 925973002: Fix error handling in dart2js async-await (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Fixed unit-test Created 5 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, 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 part of js_backend; 5 part of js_backend;
6 6
7 const VERBOSE_OPTIMIZER_HINTS = false; 7 const VERBOSE_OPTIMIZER_HINTS = false;
8 8
9 const bool USE_CPS_IR = const bool.fromEnvironment("USE_CPS_IR"); 9 const bool USE_CPS_IR = const bool.fromEnvironment("USE_CPS_IR");
10 10
(...skipping 1582 matching lines...) Expand 10 before | Expand all | Expand 10 after
1593 } 1593 }
1594 1594
1595 Element getCreateInvocationMirror() { 1595 Element getCreateInvocationMirror() {
1596 return findHelper(Compiler.CREATE_INVOCATION_MIRROR); 1596 return findHelper(Compiler.CREATE_INVOCATION_MIRROR);
1597 } 1597 }
1598 1598
1599 Element getCyclicThrowHelper() { 1599 Element getCyclicThrowHelper() {
1600 return findHelper("throwCyclicInit"); 1600 return findHelper("throwCyclicInit");
1601 } 1601 }
1602 1602
1603 Element getThenHelper() { 1603 Element getAsyncHelper() {
1604 return findHelper("thenHelper"); 1604 return findHelper("asyncHelper");
1605 } 1605 }
1606 1606
1607 Element getYieldStar() { 1607 Element getYieldStar() {
1608 ClassElement classElement = findHelper("IterationMarker"); 1608 ClassElement classElement = findHelper("IterationMarker");
1609 classElement.ensureResolved(compiler); 1609 classElement.ensureResolved(compiler);
1610 return classElement.lookupLocalMember("yieldStar"); 1610 return classElement.lookupLocalMember("yieldStar");
1611 } 1611 }
1612 1612
1613 Element getYieldSingle() { 1613 Element getYieldSingle() {
1614 ClassElement classElement = findHelper("IterationMarker"); 1614 ClassElement classElement = findHelper("IterationMarker");
1615 classElement.ensureResolved(compiler); 1615 classElement.ensureResolved(compiler);
1616 return classElement.lookupLocalMember("yieldSingle"); 1616 return classElement.lookupLocalMember("yieldSingle");
1617 } 1617 }
1618 1618
1619 Element getStreamHelper() { 1619 Element getSyncStarUncaughtError() {
1620 return findHelper("streamHelper"); 1620 ClassElement classElement = findHelper("IterationMarker");
1621 classElement.ensureResolved(compiler);
1622 return classElement.lookupLocalMember("uncaughtError");
1623 }
1624
1625 Element getAsyncStarHelper() {
1626 return findHelper("asyncStarHelper");
1621 } 1627 }
1622 1628
1623 Element getStreamOfController() { 1629 Element getStreamOfController() {
1624 return findHelper("streamOfController"); 1630 return findHelper("streamOfController");
1625 } 1631 }
1626 1632
1627 Element getEndOfIteration() { 1633 Element getEndOfIteration() {
1628 ClassElement classElement = findHelper("IterationMarker"); 1634 ClassElement classElement = findHelper("IterationMarker");
1629 classElement.ensureResolved(compiler); 1635 classElement.ensureResolved(compiler);
1630 return classElement.lookupLocalMember("endOfIteration"); 1636 return classElement.lookupLocalMember("endOfIteration");
(...skipping 771 matching lines...) Expand 10 before | Expand all | Expand 10 after
2402 : "out"; 2408 : "out";
2403 String outName = outPath.substring(outPath.lastIndexOf('/') + 1); 2409 String outName = outPath.substring(outPath.lastIndexOf('/') + 1);
2404 String extension = addExtension ? ".part.js" : ""; 2410 String extension = addExtension ? ".part.js" : "";
2405 return "${outName}_$name$extension"; 2411 return "${outName}_$name$extension";
2406 } 2412 }
2407 2413
2408 void registerAsyncMarker(FunctionElement element, 2414 void registerAsyncMarker(FunctionElement element,
2409 Enqueuer enqueuer, 2415 Enqueuer enqueuer,
2410 Registry registry) { 2416 Registry registry) {
2411 if (element.asyncMarker == AsyncMarker.ASYNC) { 2417 if (element.asyncMarker == AsyncMarker.ASYNC) {
2412 enqueue(enqueuer, getThenHelper(), registry); 2418 enqueue(enqueuer, getAsyncHelper(), registry);
2413 enqueue(enqueuer, getCompleterConstructor(), registry); 2419 enqueue(enqueuer, getCompleterConstructor(), registry);
2414 enqueue(enqueuer, getStreamIteratorConstructor(), registry); 2420 enqueue(enqueuer, getStreamIteratorConstructor(), registry);
2415 } else if (element.asyncMarker == AsyncMarker.SYNC_STAR) { 2421 } else if (element.asyncMarker == AsyncMarker.SYNC_STAR) {
2416 enqueuer.registerInstantiatedClass(getSyncStarIterable(), registry); 2422 enqueuer.registerInstantiatedClass(getSyncStarIterable(), registry);
2417 enqueue(enqueuer, getSyncStarIterableConstructor(), registry); 2423 enqueue(enqueuer, getSyncStarIterableConstructor(), registry);
2418 enqueue(enqueuer, getEndOfIteration(), registry); 2424 enqueue(enqueuer, getEndOfIteration(), registry);
2419 enqueue(enqueuer, getYieldStar(), registry); 2425 enqueue(enqueuer, getYieldStar(), registry);
2426 enqueue(enqueuer, getSyncStarUncaughtError(), registry);
2420 } else if (element.asyncMarker == AsyncMarker.ASYNC_STAR) { 2427 } else if (element.asyncMarker == AsyncMarker.ASYNC_STAR) {
2421 enqueuer.registerInstantiatedClass(getASyncStarController(), registry); 2428 enqueuer.registerInstantiatedClass(getASyncStarController(), registry);
2422 enqueue(enqueuer, getStreamHelper(), registry); 2429 enqueue(enqueuer, getAsyncStarHelper(), registry);
2423 enqueue(enqueuer, getStreamOfController(), registry); 2430 enqueue(enqueuer, getStreamOfController(), registry);
2424 enqueue(enqueuer, getYieldSingle(), registry); 2431 enqueue(enqueuer, getYieldSingle(), registry);
2425 enqueue(enqueuer, getYieldStar(), registry); 2432 enqueue(enqueuer, getYieldStar(), registry);
2426 enqueue(enqueuer, getASyncStarControllerConstructor(), registry); 2433 enqueue(enqueuer, getASyncStarControllerConstructor(), registry);
2427 enqueue(enqueuer, getStreamIteratorConstructor(), registry); 2434 enqueue(enqueuer, getStreamIteratorConstructor(), registry);
2428 } 2435 }
2429 } 2436 }
2430 } 2437 }
2431 2438
2432 /// Handling of special annotations for tests. 2439 /// Handling of special annotations for tests.
(...skipping 253 matching lines...) Expand 10 before | Expand all | Expand 10 after
2686 } 2693 }
2687 } 2694 }
2688 2695
2689 /// Records that [constant] is used by the element behind [registry]. 2696 /// Records that [constant] is used by the element behind [registry].
2690 class Dependency { 2697 class Dependency {
2691 final ConstantValue constant; 2698 final ConstantValue constant;
2692 final Element annotatedElement; 2699 final Element annotatedElement;
2693 2700
2694 const Dependency(this.constant, this.annotatedElement); 2701 const Dependency(this.constant, this.annotatedElement);
2695 } 2702 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698