50 lines
2.0 KiB
Plaintext

In unions and intersections, redundant types should not be used.
== Why is this an issue?
When defining a union or intersection in TypeScript, it is possible to mistakenly include type constituents that encompass other constituents, that don't have any effect, or that are more restrictive. For instance,
- The type `something` in `any | something` is redundant because `any` covers all possible types, whatever `something` is.
- The types `never` in unions like `never | something` or `unknown` in intersections like `unknown & something` are effectless.
- More restrictive types in intersections like the literal type `1` in `1 & number` reduce the set of possible values to specific ones.
Eliminating redundant types from a union or intersection type simplifies the code and enhances its readability. Moreover, it provides a clearer representation of the actual values that a variable can hold.
== How to fix it
The redundant and overridden types should be removed.
=== Code examples
==== Noncompliant code example
[source,typescript,diff-id=1,diff-type=noncompliant]
----
type UnionWithAny = any | 'redundant'; // Noncompliant
type UnionWithNever = never | 'override'; // Noncompliant
type UnionWithLiteral = number | 1; // Noncompliant
type IntersectionWithAny = any & 'redundant'; // Noncompliant
type IntersectionWithUnknown = string & unknown; // Noncompliant
type IntersectionWithLiteral = string & 'override'; // Noncompliant
----
==== Compliant solution
[source,typescript,diff-id=1,diff-type=compliant]
----
type UnionWithAny = any;
type UnionWithNever = never;
type UnionWithLiteral = number;
type IntersectionWithAny = any;
type IntersectionWithUnknown = string;
type IntersectionWithLiteral = 'override';
----
== Resources
=== Documentation
* TypeScript Documentation - https://www.typescriptlang.org/docs/handbook/2/everyday-types.html#union-types[Union Types]
* TypeScript Documentation - https://www.typescriptlang.org/docs/handbook/2/objects.html#intersection-types[Intersection Types]