dart / co19 / 71951f8d687c6e7400bc9e5605301d2ef3fafa5b / . / LanguageFeatures / Set-literals / type_inference_A26_t01.dart

/* | |

* 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. | |

*/ | |

/** | |

* @assertion Finally, we define inference on a setOrMapLiteral collection as | |

* follows: | |

* ... | |

* Otherwise, collection is still ambiguous, the downwards context for the | |

* elements of collection is ?, and the disambiguation is done using the | |

* immediate elements of collection as follows: | |

* | |

* If all elements can be a set, and at least one element must be a set, then | |

* collection is a set literal with static type Set<T> where T is the least | |

* upper bound of the set element types of the elements. | |

* | |

* @description Checks that if all elements can be a set, and at least one | |

* element must be a set, then collection is a set literal with static type | |

* Set<T> where T is the least upper bound of the set element types of the | |

* elements | |

* @author sgrekhov@unipro.ru | |

*/ | |

import "../../Utils/expect.dart"; | |

main() { | |

dynamic d1 = 1; | |

dynamic d2 = 2; | |

var s = {d1, d2, 3}; | |

Expect.isTrue(s is Set<dynamic>); | |

Expect.isFalse(s is Set<int>); | |

} |