Ruby  2.5.0dev(2017-10-22revision60238)
Typedefs | Functions
vm.h File Reference

Go to the source code of this file.

Typedefs

typedef typedefRUBY_SYMBOL_EXPORT_BEGIN struct rb_vm_struct ruby_vm_t
 

Functions

int ruby_vm_destruct (ruby_vm_t *vm)
 
void ruby_vm_at_exit (void(*func)(ruby_vm_t *))
 ruby_vm_at_exit registers a function func to be invoked when a VM passed away. More...
 

Typedef Documentation

◆ ruby_vm_t

typedef typedefRUBY_SYMBOL_EXPORT_BEGIN struct rb_vm_struct ruby_vm_t

Definition at line 32 of file vm.h.

Function Documentation

◆ ruby_vm_at_exit()

void ruby_vm_at_exit ( void(*)(ruby_vm_t *)  func)

ruby_vm_at_exit registers a function func to be invoked when a VM passed away.

Functions registered this way runs in reverse order of registration, just like END {} block does. The difference is its timing to be triggered. ruby_vm_at_exit functions runs when a VM passed away, while END {} blocks runs just before a VM is passing away.

You cannot register a function to another VM than where you are in. So where to register is intuitive, omitted. OTOH the argument func cannot know which VM it is in because at the time of invocation, the VM has already died and there is no execution context. The VM itself is passed as the first argument to it.

Parameters
[in]functhe function to register.

◆ ruby_vm_destruct()

int ruby_vm_destruct ( ruby_vm_t vm)