Much like all dynamically typed languages are poor statically typed languages, typed functional programming languages (corresponding to intuitionistic logic) are subsumed by linear logic. Girard articulates this unity in the logical context. Let us gloss the functional programming side of things.
Linear logic allows us to recover intuitionistic fragment via the exponential modality \( ! \). \( !A \) is the perennialization of \( A \); one translates intuitionistic formulas as
\( A \rightarrow B := !A \multimap B \\ A \vee B := !A \oplus !B \\ A \wedge B := !A \otimes !B \)
Programming languages such as ATS and Rust do things differently,
associating linearity/perenniality with a named
type; a value of type ptr
(say) is perennial and can be duplicated and discarded as in C,
while a value of type list
is linear and must be used exactly once. Values
which are stack-allocated or stored in registers are perennial while
heap-allocated values are linear.
Though Rust focuses on manual memory management, values backed by a garbage
collector fit into this scheme: functional languages correspond to
intuitionistic logic, and their values are perennial and should be typed like i64
in Rust.
Conversely, functional languages could add linear types in this way, distinguishing mutable arrays or pointers as linear.
Conclusion
Any new general-purpose language without linear types is already obsolete. Users should be wary of new languages that do not bother to offer linear types.