|  | library test; | 
|  | import self as self; | 
|  | import "dart:core" as core; | 
|  | import "dart:async" as asy; | 
|  |  | 
|  | import "dart:async"; | 
|  |  | 
|  | class MyFuture<T extends core::Object* = dynamic> extends core::Object implements asy::Future<self::MyFuture::T*> { | 
|  | constructor •() → self::MyFuture<self::MyFuture::T*>* | 
|  | : super core::Object::•() {} | 
|  | constructor value([dynamic x = #C1]) → self::MyFuture<self::MyFuture::T*>* | 
|  | : super core::Object::•() {} | 
|  | method noSuchMethod(core::Invocation* invocation) → dynamic | 
|  | return null; | 
|  | method then<S extends core::Object* = dynamic>((self::MyFuture::T*) →* FutureOr<self::MyFuture::then::S*>* f, {core::Function* onError = #C1}) → self::MyFuture<self::MyFuture::then::S*>* | 
|  | return null; | 
|  | abstract member-signature get _identityHashCode() → core::int*; -> core::Object::_identityHashCode | 
|  | abstract member-signature method _instanceOf(dynamic instantiatorTypeArguments, dynamic functionTypeArguments, dynamic type) → core::bool*; -> core::Object::_instanceOf | 
|  | abstract member-signature method _simpleInstanceOf(dynamic type) → core::bool*; -> core::Object::_simpleInstanceOf | 
|  | abstract member-signature method _simpleInstanceOfTrue(dynamic type) → core::bool*; -> core::Object::_simpleInstanceOfTrue | 
|  | abstract member-signature method _simpleInstanceOfFalse(dynamic type) → core::bool*; -> core::Object::_simpleInstanceOfFalse | 
|  | abstract member-signature operator ==(dynamic other) → core::bool*; -> core::Object::== | 
|  | abstract member-signature get hashCode() → core::int*; -> core::Object::hashCode | 
|  | abstract member-signature method toString() → core::String*; -> core::Object::toString | 
|  | abstract member-signature get runtimeType() → core::Type*; -> core::Object::runtimeType | 
|  | no-such-method-forwarder method catchError(core::Function* onError, {(core::Object*) →* core::bool* test = #C1}) → asy::Future<self::MyFuture::T*>* | 
|  | return this.{self::MyFuture::noSuchMethod}(new core::_InvocationMirror::_withType(#C2, 0, #C3, core::List::unmodifiable<dynamic>(core::_GrowableList::_literal1<dynamic>(onError)), core::Map::unmodifiable<core::Symbol*, dynamic>(<core::Symbol*, dynamic>{#C4: test}))){(core::Invocation*) →* dynamic} as{TypeError,ForDynamic} asy::Future<self::MyFuture::T*>*; | 
|  | no-such-method-forwarder method whenComplete(() →* FutureOr<void>* action) → asy::Future<self::MyFuture::T*>* | 
|  | return this.{self::MyFuture::noSuchMethod}(new core::_InvocationMirror::_withType(#C5, 0, #C3, core::List::unmodifiable<dynamic>(core::_GrowableList::_literal1<dynamic>(action)), core::Map::unmodifiable<core::Symbol*, dynamic>(#C6))){(core::Invocation*) →* dynamic} as{TypeError,ForDynamic} asy::Future<self::MyFuture::T*>*; | 
|  | no-such-method-forwarder method asStream() → asy::Stream<self::MyFuture::T*>* | 
|  | return this.{self::MyFuture::noSuchMethod}(new core::_InvocationMirror::_withType(#C7, 0, #C3, #C8, core::Map::unmodifiable<core::Symbol*, dynamic>(#C6))){(core::Invocation*) →* dynamic} as{TypeError,ForDynamic} asy::Stream<self::MyFuture::T*>*; | 
|  | no-such-method-forwarder method timeout(core::Duration* timeLimit, {covariant-by-class () →* FutureOr<self::MyFuture::T*>* onTimeout = #C1}) → asy::Future<self::MyFuture::T*>* | 
|  | return this.{self::MyFuture::noSuchMethod}(new core::_InvocationMirror::_withType(#C9, 0, #C3, core::List::unmodifiable<dynamic>(core::_GrowableList::_literal1<dynamic>(timeLimit)), core::Map::unmodifiable<core::Symbol*, dynamic>(<core::Symbol*, dynamic>{#C10: onTimeout}))){(core::Invocation*) →* dynamic} as{TypeError,ForDynamic} asy::Future<self::MyFuture::T*>*; | 
|  | } | 
|  | static field self::MyFuture<dynamic>* f; | 
|  | static field asy::Future<core::int*>* t1 = self::f.{self::MyFuture::then}<core::int*>((dynamic _) → self::MyFuture<core::int*>* => new self::MyFuture::value<core::int*>("hi")){((dynamic) →* FutureOr<core::int*>*, {onError: core::Function*}) →* self::MyFuture<core::int*>*}; | 
|  | static field asy::Future<core::List<core::int*>*>* t2 = self::f.{self::MyFuture::then}<core::List<core::int*>*>((dynamic _) → core::List<core::int*>* => core::_GrowableList::_literal1<core::int*>(3)){((dynamic) →* FutureOr<core::List<core::int*>*>*, {onError: core::Function*}) →* self::MyFuture<core::List<core::int*>*>*}; | 
|  | static method g2() → asy::Future<core::List<core::int*>*>* /* originally async */ { | 
|  | final asy::_Future<core::List<core::int*>*>* :async_future = new asy::_Future::•<core::List<core::int*>*>(); | 
|  | core::bool* :is_sync = false; | 
|  | FutureOr<core::List<core::int*>*>* :return_value; | 
|  | (dynamic) →* dynamic :async_op_then; | 
|  | (core::Object*, core::StackTrace*) →* dynamic :async_op_error; | 
|  | core::int* :await_jump_var = 0; | 
|  | dynamic :await_ctx_var; | 
|  | function :async_op([dynamic :result, dynamic :exception, dynamic :stack_trace]) → dynamic yielding | 
|  | try { | 
|  | #L1: | 
|  | { | 
|  | :return_value = core::_GrowableList::_literal1<core::int*>(3); | 
|  | break #L1; | 
|  | } | 
|  | asy::_completeOnAsyncReturn(:async_future, :return_value, :is_sync); | 
|  | return; | 
|  | } | 
|  | on dynamic catch(dynamic exception, core::StackTrace* stack_trace) { | 
|  | asy::_completeOnAsyncError(:async_future, exception, stack_trace, :is_sync); | 
|  | } | 
|  | :async_op_then = asy::_asyncThenWrapperHelper(:async_op); | 
|  | :async_op_error = asy::_asyncErrorWrapperHelper(:async_op); | 
|  | :async_op(){() →* dynamic}; | 
|  | :is_sync = true; | 
|  | return :async_future; | 
|  | } | 
|  | static method g3() → asy::Future<core::List<core::int*>*>* /* originally async */ { | 
|  | final asy::_Future<core::List<core::int*>*>* :async_future = new asy::_Future::•<core::List<core::int*>*>(); | 
|  | core::bool* :is_sync = false; | 
|  | FutureOr<core::List<core::int*>*>* :return_value; | 
|  | (dynamic) →* dynamic :async_op_then; | 
|  | (core::Object*, core::StackTrace*) →* dynamic :async_op_error; | 
|  | core::int* :await_jump_var = 0; | 
|  | dynamic :await_ctx_var; | 
|  | function :async_op([dynamic :result, dynamic :exception, dynamic :stack_trace]) → dynamic yielding | 
|  | try { | 
|  | #L2: | 
|  | { | 
|  | :return_value = new self::MyFuture::value<core::List<core::int*>*>(core::_GrowableList::_literal1<core::int*>(3)); | 
|  | break #L2; | 
|  | } | 
|  | asy::_completeOnAsyncReturn(:async_future, :return_value, :is_sync); | 
|  | return; | 
|  | } | 
|  | on dynamic catch(dynamic exception, core::StackTrace* stack_trace) { | 
|  | asy::_completeOnAsyncError(:async_future, exception, stack_trace, :is_sync); | 
|  | } | 
|  | :async_op_then = asy::_asyncThenWrapperHelper(:async_op); | 
|  | :async_op_error = asy::_asyncErrorWrapperHelper(:async_op); | 
|  | :async_op(){() →* dynamic}; | 
|  | :is_sync = true; | 
|  | return :async_future; | 
|  | } | 
|  | static method main() → dynamic {} | 
|  |  | 
|  | constants  { | 
|  | #C1 = null | 
|  | #C2 = #catchError | 
|  | #C3 = <core::Type*>[] | 
|  | #C4 = #test | 
|  | #C5 = #whenComplete | 
|  | #C6 = <core::Symbol*, dynamic>{) | 
|  | #C7 = #asStream | 
|  | #C8 = <dynamic>[] | 
|  | #C9 = #timeout | 
|  | #C10 = #onTimeout | 
|  | } |