blob: 25f6e4e12350ff3b4c6df3888d080b09029afe12 [file] [log] [blame]
// Copyright (c) 2019, 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.
class Class {
Class? _field;
}
extension Extension on Class {
Class? get field => _field;
void set field(Class? value) {
_field = value;
}
Class? method() => field;
Class? operator [](Class? key) => field;
void operator []=(Class? key, Class? value) {
field = value;
}
Class? operator +(int value) => field;
Class? operator -() => field;
}
main() {
propertyAccess(null);
indexAccess(null);
operatorAccess(null);
ifNull(null);
}
void propertyAccess(Class? c) {
c?.field;
c?.field = new Class();
c = c?.field = new Class();
c?.method();
c?.field.field;
c?.field.field = new Class();
throws(() => (c?.field).field);
throws(() => (c?.field = new Class()).field);
throws(() => (c?.method()).field);
c = c?.field.field = new Class();
c?.field.method();
c?.field = new Class().field;
c = c?.field = new Class().field;
c?.field = new Class().field = new Class();
c = c?.field = new Class().field = new Class();
c?.field = new Class().method();
c = c?.field = new Class().method();
c?.method().field;
c?.method().field = new Class();
c?.method().method();
c?.field.field.field;
c?.field.field.field = new Class();
c = c?.field.field.field = new Class();
c?.field.field.method();
c?.field = new Class().field.field;
c = c?.field = new Class().field.field;
c?.field = new Class().field.field = new Class();
c = c?.field = new Class().field.field = new Class();
c?.field = new Class().field.method();
c = c?.field = new Class().field.method();
c?.method().field.field;
c?.method().field.field = new Class();
c?.method().field.method();
c?.field.field = new Class().field;
c = c?.field.field = new Class().field;
c?.field.field = new Class().field = new Class();
c = c?.field.field = new Class().field = new Class();
c?.field.field = new Class().method();
c = c?.field.field = new Class().method();
c?.field = new Class().field = new Class().field;
c = c?.field = new Class().field = new Class().field;
c?.field = new Class().field = new Class().field = new Class();
c = c?.field = new Class().field = new Class().field = new Class();
c?.field = new Class().field = new Class().method();
c = c?.field = new Class().field = new Class().method();
c?.method().field = new Class().field;
c = c?.method().field = new Class().field;
c?.method().field = new Class().field = new Class();
c = c?.method().field = new Class().field = new Class();
c?.method().field = new Class().method();
c = c?.method().field = new Class().method();
c?.field.method().field;
c?.field.method().field = new Class();
c = c?.field.method().field = new Class();
c?.field.method().method();
c?.field = new Class().method().field;
c = c?.field = new Class().method().field;
c?.field = new Class().method().field = new Class();
c = c?.field = new Class().method().field = new Class();
c?.field = new Class().method().method();
c = c?.field = new Class().method().method();
c?.method().method().field;
c?.method().method().field = new Class();
c?.method().method().method();
}
void indexAccess(Class? c) {
// TODO(johnniwinther): Handle null aware index access.
//c?.[c];
//c?.[c] = new Class();
//c?.[c].method();
c?.field[c];
c?.field[c] = new Class();
c = c?.field[c] = new Class();
c?.field[c].method();
c?.field[c] += 0;
c = c?.field[c] += 0;
// TODO(johnniwinther): ++ should probably not be null-shorted, awaiting spec
// update.
c?.field[c]++;
c = c?.field[c]++;
++c?.field[c];
c = ++c?.field[c];
}
void operatorAccess(Class? c) {
throws(() => c?.field + 0);
throws(() => -c?.field);
c?.field += 0;
c = c?.field += 0;
c?.field.field += 0;
c = c?.field.field += 0;
// TODO(johnniwinther): ++ should probably not be null-shorted, awaiting spec
// update.
c?.field++;
c = c?.field++;
++c?.field;
c = ++c?.field;
}
void ifNull(Class? c) {
c?.field ??= c;
c = c?.field ??= c;
c?.field[c] ??= c;
}
void throws(void Function() f) {
try {
f();
} catch (_) {
return;
}
throw 'Expected exception.';
}