Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How does Smalltalk manipulate call stack frames (thisContext)?

The Smalltalk object thisContext look strange and marvelous. I can't understand what it is and how it works. And even how it enables continuations.

For C's call-stack, I can easily imagine how is it implemented and working. But for this... I can't. Please help me to understand it.

like image 850
eonil Avatar asked Jun 14 '11 17:06

eonil


3 Answers

I think it is not an easy question. The stack is reified in the image with instances of MethodContext. A MethodContext can have a sender, which is another MethodContext. That one can have another one...generating a whole stack. MethodContext are instantiated by the VM while executing CompiledMethod (which are also reified in the language).

How MethodContext are mapped to C stack, that depends on the VM. StackVM (CogVM is on top of StackVM) is exactly a VM that better maps MethodContext con C stack.

Apart from the BlueBook that Lukas said, check

http://www.mirandabanda.org/cogblog/ check on the left the posts...

I recommend you to ask in http://lists.squeakfoundation.org/mailman/listinfo/vm-dev

like image 198
Mariano Martinez Peck Avatar answered Nov 13 '22 10:11

Mariano Martinez Peck


The best explanation you can find in Smalltalk-80: The Language and its Implementation, Chapter 26 to 30. The stack frames (contexts) are explained on page 580.

like image 34
Lukas Renggli Avatar answered Nov 13 '22 08:11

Lukas Renggli


It's more correct to say that thisContext is a continuation - the current continuation, in particular.

Imagine a variable c that, just before a MethodContext activates, is set to point to that context. That's thisContext.

like image 3
Frank Shearar Avatar answered Nov 13 '22 08:11

Frank Shearar