[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Demystifying Continuations



Hi All,

Coming from a Smalltalk implementers background, I have found myself
quite confused by the plethora of almost mystical descriptions
surrounding the term "continuation" in popular CS literature. 

To my less enlightened brain, continuations seem to be a very simple
concept that is much more easily understood in terms of stacks,
call-chains, and frames (activation-records/contexts).

Simply put, from all I've read and all I can tell they are:

A cloneable reified objectification of a stack (call-chain w/closures).

In other words, the stack is objectified as a collection of
pending/in-progress function/method calls. 

The collection elements are pending function/methods (call-chain)
frames/activation-records [typically linked from child to parent].

The frames/activation-records are closures. Meaning that all their local
state is captured within the aggregate that represents the
frame/activation-record/context.

Since (in a Smalltalk implementation) these things are all objects, we
can copy them (cloneable). And, in Smalltalk, a <Context> is executable
and otherwise manipulatable through a wide range of MOP facilities. 

We can start, restart, or otherwise configure a context anyway we want.
In most Smalltalks the entire debugger architecture is built through the
use of contexts and related MOP services.

So a callcc idea is really just a return to the currently configured
"previous context".  Where, in statically typed and compiled languages
we typically have not access to the stack nor do we have an
objectification of the stack that allows us to restructure it
dynamically through MOP/Context services.
================

Having said all that, have I described and/or captured what a
continuation is? Are there any special nuances I have left out?

-- SIDE NOTE ON NATIVE THREADS --
Further noting that since a continuation is really a capturing of state
both "for" and "within" a given execution context, there are technical
issues with creating continuations on native OS threads. 

Where a native OS thread had significant thread-local state, and
OS/Process characteristics that a "classic" continuation architecture
would not include. On systems like Win32 we can use fibers to create an
efficient continuation architecture [where we can copy in/out stack
ranges and TIB information]. 

This allows us to create generally safe continuations that include
native DLL/EXE library calls within the call-chain.
-- END SIDE NOTE ON NATIVE THREADS --

-- Dave S. [SmallScript Corp]

SmallScript for the AOS & .NET Platforms
David.Simmons@SmallScript.com | http://www.smallscript.org