TypeScript/tests/baselines/reference/nominalSubtypeCheckOfTypeParameter.types

62 lines
1.3 KiB
Plaintext
Raw Normal View History

2014-08-15 23:33:16 +02:00
=== tests/cases/conformance/types/typeRelationships/recursiveTypes/nominalSubtypeCheckOfTypeParameter.ts ===
interface Tuple<T, S> {
>Tuple : Tuple<T, S>
>T : T
>S : S
2014-08-15 23:33:16 +02:00
first: T
>first : T
>T : T
2014-08-15 23:33:16 +02:00
second: S
>second : S
>S : S
2014-08-15 23:33:16 +02:00
}
interface Sequence<T> {
>Sequence : Sequence<T>
>T : T
2014-08-15 23:33:16 +02:00
hasNext(): boolean
>hasNext : () => boolean
2014-08-15 23:33:16 +02:00
pop(): T
>pop : () => T
>T : T
2014-08-15 23:33:16 +02:00
zip<S>(seq: Sequence<S>): Sequence<Tuple<T, S>>
>zip : <S>(seq: Sequence<S>) => Sequence<Tuple<T, S>>
>S : S
>seq : Sequence<S>
>Sequence : Sequence<T>
>S : S
>Sequence : Sequence<T>
>Tuple : Tuple<T, S>
>T : T
>S : S
2014-08-15 23:33:16 +02:00
}
// error, despite the fact that the code explicitly says List<T> extends Sequence<T>, the current rules for infinitely expanding type references
// perform nominal subtyping checks that allow variance for type arguments, but not nominal subtyping for the generic type itself
interface List<T> extends Sequence<T> {
>List : List<T>
>T : T
>Sequence : Sequence<T>
>T : T
2014-08-15 23:33:16 +02:00
getLength(): number
>getLength : () => number
2014-08-15 23:33:16 +02:00
zip<S>(seq: Sequence<S>): List<Tuple<T, S>>
>zip : <S>(seq: Sequence<S>) => List<Tuple<T, S>>
>S : S
>seq : Sequence<S>
>Sequence : Sequence<T>
>S : S
>List : List<T>
>Tuple : Tuple<T, S>
>T : T
>S : S
2014-08-15 23:33:16 +02:00
}