Skip to content

Latest commit

 

History

History

transform

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

Topology transformations

Beware cycles!

img.png

  • Before: where execution happened before entering into this tag
  • Begin: where execution is expected to be in the beginning of this tag

Usually tags handle their beforePaths: inject pathway from location Before to location Begin, to ensure that execution can get there.

  • End: where execution is expected to end when all the children of the tag are executed
  • After: where execution flow should go after this tag is handled

Usually Before == previous End or parent's Begin, and After == next Begin or parent's After.

  • Finally: either After, if tag takes care of getting from its internal scope to the outer scope, or End if it doesn't

Usually tags do not care about the afterPath and inject nothing. But in some cases this path is super necessary, e.g. returning from the Par branch must be done within that Par branch, as doing it later is too late.

Tag Before Begin End After Finally Force Exit
Default parent.begin OR path path <- begin <- ends force ? <- after: <- ends false
seq - - lastChild.finally - - -
seq/* prev.finally OR default - - next.begin OR parent.after - -
xor/*:0 - - - parent.after - hasExecLater
xor/*:1 prev.ends - - parent.after - hasExecLater
xor - - lastChild.finally - - -
par/* - - <- before parent.after - exportsUsedLater
for - fc.begins(until i) - - - -
noExec - - <- begin - - -