type-plus
    Preparing search index...

    Type Alias IsNotStringLiteral<T, $O>

    IsNotStringLiteral: $Special<
        T,
        $MergeOptions<
            $O,
            {
                $else: IsNotStringLiteral.$<T, $O>;
                $then: $ResolveBranch<$O, [$Then], T>;
            },
        >,
    >

    🎭 predicate

    Validate if T is not a string literal(s).

    Type Parameters

    type R = IsNotStringLiteral<string> // true
    type R = IsNotStringLiteral<'a'> // false
    type R = IsNotStringLiteral<`${number}`> // false

    type R = IsNotStringLiteral<never> // true
    type R = IsNotStringLiteral<unknown> // true
    type R = IsNotStringLiteral<'a' | boolean> // boolean

    🔢 customize

    Filter to ensure T is not a string literal(s), otherwise returns never.

    type R = IsNotStringLiteral<string, { selection: 'filter' }> // string
    type R = IsNotStringLiteral<'a', { selection: 'filter' }> // never

    type R = IsNotStringLiteral<never, { selection: 'filter' }> // never
    type R = IsNotStringLiteral<unknown, { selection: 'filter' }> // unknown
    type R = IsNotStringLiteral<'a' | boolean, { selection: 'filter' }> // boolean

    🔢 customize:

    Disable distribution of union types.

    type R = IsNotStringLiteral<'abc' | 1> // boolean
    type R = IsNotStringLiteral<'abc' | 1, { distributive: false }> // true

    🔢 customize:

    Check if T is exactly not a string literal, excluding template literals.

    type R = IsNotStringLiteral<'${number}'> // false
    type R = IsNotStringLiteral<'${number}', { exact: true }> // true

    🔢 customize

    Use unique branch identifiers to allow precise processing of the result.

    type R = IsNotStringLiteral<'abc', $IsNotStringLiteral.$Branch> // $Else
    type R = IsNotStringLiteral<string, $IsNotStringLiteral.$Branch> // $Then