blob: fff36a83bb7cc047891f1bce876598c7918f4748 [file] [log] [blame]
library /*isNonNullableByDefault*/;
import self as self;
import "dart:core" as core;
import "dart:collection" as col;
import "dart:_internal" as _in;
import "dart:collection";
class MyMap<K extends core::Object? = dynamic, V extends core::Object? = dynamic> extends col::MapBase<self::MyMap::K%, self::MyMap::V%> {
covariant-by-class field core::Map<self::MyMap::K%, self::MyMap::V%> _inner;
field core::String log = "";
constructor •(core::Map<self::MyMap::K%, self::MyMap::V%> _inner) self::MyMap<self::MyMap::K%, self::MyMap::V%>
: self::MyMap::_inner = _inner, super col::MapBase::•()
;
@#C1
operator [](core::Object? key) self::MyMap::V? {
this.{self::MyMap::log} = this.{self::MyMap::log}{core::String}.{core::String::+}("[${key}];"){(core::String) core::String};
return this.{self::MyMap::_inner}{core::Map<self::MyMap::K%, self::MyMap::V%>}.{core::Map::[]}(key){(core::Object?) self::MyMap::V?};
}
@#C1
operator []=(covariant-by-class self::MyMap::K% key, covariant-by-class self::MyMap::V% value) void {
this.{self::MyMap::log} = this.{self::MyMap::log}{core::String}.{core::String::+}("[${key}]=${value};"){(core::String) core::String};
this.{self::MyMap::_inner}{core::Map<self::MyMap::K%, self::MyMap::V%>}.{core::Map::[]=}(key, value){(self::MyMap::K%, self::MyMap::V%) void};
}
@#C1
method clear() void {
this.{self::MyMap::log} = this.{self::MyMap::log}{core::String}.{core::String::+}("clear();"){(core::String) core::String};
this.{self::MyMap::_inner}{core::Map<self::MyMap::K%, self::MyMap::V%>}.{core::Map::clear}(){() void};
}
@#C1
get keys() core::Iterable<self::MyMap::K%> {
this.{self::MyMap::log} = this.{self::MyMap::log}{core::String}.{core::String::+}("keys;"){(core::String) core::String};
return this.{self::MyMap::_inner}{core::Map<self::MyMap::K%, self::MyMap::V%>}.{core::Map::keys}{core::Iterable<self::MyMap::K%>};
}
@#C1
method remove(core::Object? key) self::MyMap::V? {
this.{self::MyMap::log} = this.{self::MyMap::log}{core::String}.{core::String::+}("remove(${key});"){(core::String) core::String};
return this.{self::MyMap::_inner}{core::Map<self::MyMap::K%, self::MyMap::V%>}.{core::Map::remove}(key){(core::Object?) self::MyMap::V?};
}
@#C1
get length() core::int {
this.{self::MyMap::log} = this.{self::MyMap::log}{core::String}.{core::String::+}("length;"){(core::String) core::String};
return this.{self::MyMap::_inner}{core::Map<self::MyMap::K%, self::MyMap::V%>}.{core::Map::length}{core::int};
}
@#C1
method containsKey(core::Object? key) core::bool {
this.{self::MyMap::log} = this.{self::MyMap::log}{core::String}.{core::String::+}("containsKey(${key});"){(core::String) core::String};
return this.{self::MyMap::_inner}{core::Map<self::MyMap::K%, self::MyMap::V%>}.{core::Map::containsKey}(key){(core::Object?) core::bool};
}
method clearLog() void {
this.{self::MyMap::log} = "";
}
}
static field core::String unsoundResult = "containsKey(key1);[key1];containsKey(key2);[key2];";
static field core::String soundResult = "[key1];[key2];";
static get hasUnsoundNullSafety() core::bool
return #C2 is{ForNonNullableByDefault} core::List<core::Object>;
static method test1(core::Object o) core::String {
#L1:
{
final synthesized core::Object #0#0 = o;
late final synthesized core::bool #0#3 = #0#0{core::Map<core::String, core::int>}.{core::Map::containsKey}(#C3){(core::Object?) → core::bool};
late final synthesized core::bool #0#6 = #C4 =={core::num::==}{(core::Object) → core::bool} #0#0{core::Map<core::String, core::int>}.{core::Map::[]}(#C3){(core::Object?) → core::int?} as{ForNonNullableByDefault} core::int;
late final synthesized core::bool #0#8 = #0#0{core::Map<core::String, core::int>}.{core::Map::containsKey}(#C5){(core::Object?) → core::bool};
late final synthesized core::int? #0#9 = #0#0{core::Map<core::String, core::int>}.{core::Map::[]}(#C5){(core::Object?) → core::int?};
{
if(#0#0 is{ForNonNullableByDefault} core::Map<core::String, core::int> && #0#3 && #0#6 && #0#8 && #C6 =={core::num::==}{(core::Object) → core::bool} #0#9{core::int}) {
{
return "match-2";
}
}
}
{
if(#0#0 is{ForNonNullableByDefault} core::Map<core::String, core::int> && #0#3 && #0#6 && #0#8 && #C7 =={core::num::==}{(core::Object) → core::bool} #0#9{core::int}) {
{
return "match-3";
}
}
}
{
{
{
return "no match";
}
}
}
}
}
static method test2(core::Object o) core::String
return block {
core::String #t1;
final synthesized core::Object #0#0 = o;
late final synthesized core::bool #0#3 = #0#0{core::Map<core::String, core::int>}.{core::Map::containsKey}(#C3){(core::Object?) → core::bool};
late final synthesized core::bool #0#6 = #C4 =={core::num::==}{(core::Object) → core::bool} #0#0{core::Map<core::String, core::int>}.{core::Map::[]}(#C3){(core::Object?) → core::int?} as{ForNonNullableByDefault} core::int;
late final synthesized core::bool #0#8 = #0#0{core::Map<core::String, core::int>}.{core::Map::containsKey}(#C5){(core::Object?) → core::bool};
late final synthesized core::int? #0#9 = #0#0{core::Map<core::String, core::int>}.{core::Map::[]}(#C5){(core::Object?) → core::int?};
#L2:
{
{
if(#0#0 is{ForNonNullableByDefault} core::Map<core::String, core::int> && #0#3 && #0#6 && #0#8 && #C6 =={core::num::==}{(core::Object) → core::bool} #0#9{core::int}) {
#t1 = "match-2";
break #L2;
}
}
{
if(#0#0 is{ForNonNullableByDefault} core::Map<core::String, core::int> && #0#3 && #0#6 && #0#8 && #C7 =={core::num::==}{(core::Object) → core::bool} #0#9{core::int}) {
#t1 = "match-3";
break #L2;
}
}
{
if(true) {
#t1 = "no match";
break #L2;
}
}
throw new _in::ReachabilityError::•("`null` encountered as case in a switch expression with a non-nullable type.");
}
} =>#t1;
static method main() dynamic {
final self::MyMap<core::String, core::int> map = new self::MyMap::•<core::String, core::int>(<core::String, core::int>{"key1": 1, "key2": 2});
self::expect("match-3", self::test1(map));
self::expect(self::hasUnsoundNullSafety ?{core::String} self::unsoundResult : self::soundResult, map.{self::MyMap::log}{core::String});
map.{self::MyMap::clearLog}(){() void};
self::expect("match-3", self::test2(map));
self::expect(self::hasUnsoundNullSafety ?{core::String} self::unsoundResult : self::soundResult, map.{self::MyMap::log}{core::String});
map.{self::MyMap::clearLog}(){() void};
hoisted has-declared-initializer core::int x1;
hoisted has-declared-initializer core::int x2;
{
final synthesized dynamic #0#0 = map;
if(!(#0#0{self::MyMap<core::String, core::int>}.{self::MyMap::containsKey}(#C3){(core::Object?) → core::bool} && (let final dynamic #t2 = x1 = #0#0{self::MyMap<core::String, core::int>}.{self::MyMap::[]}(#C3){(core::Object?) → core::int?} as{ForNonNullableByDefault} core::int in true) && #0#0{self::MyMap<core::String, core::int>}.{self::MyMap::containsKey}(#C5){(core::Object?) → core::bool} && (let final dynamic #t3 = x2 = #0#0{self::MyMap<core::String, core::int>}.{self::MyMap::[]}(#C5){(core::Object?) → core::int?} as{ForNonNullableByDefault} core::int in true)))
throw new core::StateError::•("Pattern matching error");
}
self::expect(self::hasUnsoundNullSafety ?{core::String} self::unsoundResult : self::soundResult, map.{self::MyMap::log}{core::String});
map.{self::MyMap::clearLog}(){() void};
final hoisted has-declared-initializer core::int y1;
final hoisted has-declared-initializer core::int y2;
{
final synthesized dynamic #1#0 = map;
if(!(#1#0{self::MyMap<core::String, core::int>}.{self::MyMap::containsKey}(#C3){(core::Object?) → core::bool} && (let final dynamic #t4 = y1 = #1#0{self::MyMap<core::String, core::int>}.{self::MyMap::[]}(#C3){(core::Object?) → core::int?} as{ForNonNullableByDefault} core::int in true) && #1#0{self::MyMap<core::String, core::int>}.{self::MyMap::containsKey}(#C5){(core::Object?) → core::bool} && (let final dynamic #t5 = y2 = #1#0{self::MyMap<core::String, core::int>}.{self::MyMap::[]}(#C5){(core::Object?) → core::int?} as{ForNonNullableByDefault} core::int in true)))
throw new core::StateError::•("Pattern matching error");
}
self::expect(self::hasUnsoundNullSafety ?{core::String} self::unsoundResult : self::soundResult, map.{self::MyMap::log}{core::String});
}
static method expect(dynamic expected, dynamic actual) dynamic {
if(!(expected =={core::Object::==}{(core::Object) core::bool} actual))
throw "Expected ${expected}, actual ${actual}";
}
constants {
#C1 = core::_Override {}
#C2 = <Null>[]
#C3 = "key1"
#C4 = 1
#C5 = "key2"
#C6 = 3
#C7 = 2
}