, Volume 15, Issue 2-3, pp 181-208

Linear Continuation-Passing

Rent the article at a discount

Rent now

* Final gross prices may vary according to local VAT.

Get Access


Continuations can be used to explain a wide variety of control behaviours, including calling/returning (procedures), raising/handling (exceptions), labelled jumping (goto statements), process switching (coroutines), and backtracking. However, continuations are often manipulated in a highly stylised way, and we show that all of these, bar backtracking, in fact use their continuations linearly; this is formalised by taking a target language for CPS transforms that has both intuitionistic and linear function types.