Essential Effects for C

submited by
Style Pass
2025-01-18 19:30:38

In this discussion proposal we suggest that C would be improved by extending the core type system into a type and effect system, that forces functions and blocks to declare which classes of effects will result from their evaluation. We show how this can be used to improve composability in metaprogramming, and can be used to define MISRA-style restrictions more easily through signatures expressed in the core language. The extended notion of type allows us to model C's primitive language constructs as operators with a checkable signature.

A formalized effect system keeps track of the side effects of expressions and statements in a program at a finer level of granularity than usually expressible in C.

An effect system is usually combined with a type system, so that the side effects potentially involved in the production of a value are tracked, alongside the type of the result value. Effect systems may be either fully static, or partially value-dependent.

where expr is the object or expression being typed, type is its in-language or dialect type (such as the C Standard language type or the MISRA essential type), { effect } is a union of all effects triggered by the evaluation of expr, and region is the name of a category of objects or memory to which those effects may apply.

Leave a Comment