1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222
|
=== tests/cases/conformance/types/uniqueSymbol/uniqueSymbolsErrors.ts ===
// declarations
declare const invalidUniqueType: unique number;
>invalidUniqueType : any
declare const {}: unique symbol;
declare let invalidLetType: unique symbol;
>invalidLetType : symbol
declare var invalidVarType: unique symbol;
>invalidVarType : symbol
// function arguments and return types
declare function invalidArgType(arg: unique symbol): void;
>invalidArgType : (arg: unique symbol) => void
>arg : symbol
declare function invalidRestArgType(...arg: (unique symbol)[]): void;
>invalidRestArgType : (...arg: (unique symbol)[]) => void
>arg : symbol[]
declare function invalidReturnType(): unique symbol;
>invalidReturnType : () => unique symbol
declare function invalidThisType(this: unique symbol): void;
>invalidThisType : (this: unique symbol) => void
>this : symbol
declare function invalidTypePredicate(n: any): n is unique symbol;
>invalidTypePredicate : (n: any) => n is symbol
>n : any
declare function invalidTypeParameterConstraint<T extends unique symbol>(): void;
>invalidTypeParameterConstraint : <T extends symbol>() => void
declare function invalidTypeParameterDefault<T = unique symbol>(): void;
>invalidTypeParameterDefault : <T = symbol>() => void
// classes
class InvalidClass {
>InvalidClass : InvalidClass
constructor(invalidConstructorArgType: unique symbol) {}
>invalidConstructorArgType : symbol
readonly invalidReadonlyPropertyType: unique symbol;
>invalidReadonlyPropertyType : symbol
invalidPropertyType: unique symbol;
>invalidPropertyType : symbol
invalidArgType(arg: unique symbol): void { return; }
>invalidArgType : (arg: unique symbol) => void
>arg : symbol
invalidRestArgType(...args: (unique symbol)[]): void { return; }
>invalidRestArgType : (...args: (unique symbol)[]) => void
>args : symbol[]
invalidReturnType(): unique symbol { return; }
>invalidReturnType : () => unique symbol
invalidThisType(this: unique symbol): void { return; }
>invalidThisType : (this: unique symbol) => void
>this : symbol
invalidTypePredicate(n: any): n is unique symbol { return; }
>invalidTypePredicate : (n: any) => n is symbol
>n : any
invalidTypeParameterConstraint<T extends unique symbol>(): void { return; }
>invalidTypeParameterConstraint : <T extends symbol>() => void
invalidTypeParameterDefault<T = unique symbol>(): void { return; }
>invalidTypeParameterDefault : <T = symbol>() => void
get invalidGetter(): unique symbol { return; }
>invalidGetter : symbol
set invalidSetter(arg: unique symbol) { return; }
>invalidSetter : symbol
>arg : symbol
static invalidStaticPropertyType: unique symbol;
>invalidStaticPropertyType : symbol
static invalidStaticArgType(arg: unique symbol): void { return; }
>invalidStaticArgType : (arg: unique symbol) => void
>arg : symbol
static invalidStaticRestArgType(...args: (unique symbol)[]): void { return; }
>invalidStaticRestArgType : (...args: (unique symbol)[]) => void
>args : symbol[]
static invalidStaticReturnType(): unique symbol { return; }
>invalidStaticReturnType : () => unique symbol
static invalidStaticThisType(this: unique symbol): void { return; }
>invalidStaticThisType : (this: unique symbol) => void
>this : symbol
static invalidStaticTypePredicate(n: any): n is unique symbol { return; }
>invalidStaticTypePredicate : (n: any) => n is symbol
>n : any
static invalidStaticTypeParameterConstraint<T extends unique symbol>(): void { return; }
>invalidStaticTypeParameterConstraint : <T extends symbol>() => void
static invalidStaticTypeParameterDefault<T = unique symbol>(): void { return; }
>invalidStaticTypeParameterDefault : <T = symbol>() => void
static get invalidStaticGetter(): unique symbol { return; }
>invalidStaticGetter : symbol
static set invalidStaticSetter(arg: unique symbol) { return; }
>invalidStaticSetter : symbol
>arg : symbol
}
// interfaces
interface InvalidInterface {
invalidPropertyType: unique symbol;
>invalidPropertyType : symbol
invalidArgType(arg: unique symbol): void;
>invalidArgType : (arg: unique symbol) => void
>arg : symbol
invalidRestArgType(...args: (unique symbol)[]): void;
>invalidRestArgType : (...args: (unique symbol)[]) => void
>args : symbol[]
invalidReturnType(): unique symbol;
>invalidReturnType : () => unique symbol
invalidThisType(this: unique symbol);
>invalidThisType : (this: unique symbol) => any
>this : symbol
invalidTypePredicate(n: any): n is unique symbol
>invalidTypePredicate : (n: any) => n is symbol
>n : any
invalidTypeParameterConstraint<T extends unique symbol>(): void;
>invalidTypeParameterConstraint : <T extends symbol>() => void
invalidTypeParameterDefault<T = unique symbol>(): void;
>invalidTypeParameterDefault : <T = symbol>() => void
}
// type literals
type InvalidTypeLiteral = {
>InvalidTypeLiteral : { invalidPropertyType: unique symbol; invalidArgType(arg: unique symbol): void; invalidRestArgType(...args: (unique symbol)[]): void; invalidReturnType(): unique symbol; invalidThisType(this: unique symbol): any; invalidTypePredicate(n: any): n is symbol; invalidTypeParameterConstraint<T extends symbol>(): void; invalidTypeParameterDefault<T = symbol>(): void; }
invalidPropertyType: unique symbol;
>invalidPropertyType : symbol
invalidArgType(arg: unique symbol): void;
>invalidArgType : (arg: unique symbol) => void
>arg : symbol
invalidRestArgType(...args: (unique symbol)[]): void;
>invalidRestArgType : (...args: (unique symbol)[]) => void
>args : symbol[]
invalidReturnType(): unique symbol;
>invalidReturnType : () => unique symbol
invalidThisType(this: unique symbol);
>invalidThisType : (this: unique symbol) => any
>this : symbol
invalidTypePredicate(n: any): n is unique symbol
>invalidTypePredicate : (n: any) => n is symbol
>n : any
invalidTypeParameterConstraint<T extends unique symbol>(): void;
>invalidTypeParameterConstraint : <T extends symbol>() => void
invalidTypeParameterDefault<T = unique symbol>(): void;
>invalidTypeParameterDefault : <T = symbol>() => void
};
// type alias
type InvalidAlias = unique symbol;
>InvalidAlias : symbol
type InvalidAliasTypeParameterConstraint<T extends unique symbol> = never;
>InvalidAliasTypeParameterConstraint : never
type InvalidAliasTypeParameterDefault<T extends unique symbol> = never;
>InvalidAliasTypeParameterDefault : never
// type references
declare const invalidTypeArgument: Promise<unique symbol>;
>invalidTypeArgument : Promise<symbol>
declare const invalidArrayType: (unique symbol)[];
>invalidArrayType : symbol[]
declare const invalidTupleType: [unique symbol];
>invalidTupleType : [symbol]
// mapped types
declare const invalidMappedType: { [P in string]: unique symbol };
>invalidMappedType : { [x: string]: symbol; }
// unions/intersection
declare const invalidUnion: unique symbol | unique symbol;
>invalidUnion : symbol
declare const invalidIntersection: unique symbol | unique symbol;
>invalidIntersection : symbol
// initializer assignability
// https://github.com/Microsoft/TypeScript/issues/21584
const shouldNotBeAssignable: string = Symbol();
>shouldNotBeAssignable : string
>Symbol() : unique symbol
>Symbol : SymbolConstructor
|