Show last authors
1
2
3 {{toc/}}
4
5 = The SC Language (SCL) and its graphical representation (SCG) =
6
7 As mentioned in the introduction SCL is a minimal language. It consists of seven statements.
8
9 [[image:attach:SCL_SCG_instructions.png]]
10
11 The SCG is a labelled graph //G = (S, E)//, whereas
12
13 * the nodes S correspond to the statements of the program
14 * and the edges E reflect the sequential execution ordering
15
16 ABO example:
17
18 |=(((
19 ABO SCL
20 )))|=(((
21 ABO SCG
22 )))
23 |(((
24 [[image:attach:SCL_ABO_scl.png]]
25 )))|(((
26 [[image:attach:SCL_ABO_scg.png]]
27 )))
28
29 = The SCL Meta-model =
30
31 The SC language is implemented in the plugin de.cau.cs.kieler.scl and created via xtext. The xtext grammar file is de.cau.cs.kieler.scl.SCL.xtext.
32
33 [[image:attach:SCL_metamodel.png]]
34
35 * Every SCL program is contained in a **Program**
36 * A **Program** and concurrent threads of a parallel statement a **AbstractThreads**
37 * **AbstractThreads** contain a list of **Statements**
38 * A **Statement** can either be a **InstructionStatement** and contains a single instruction or an **EmptyStatement**
39 * **EmptyStatements** do not contain an instruction, but can hold a label or an annotation
40 * An instruction is a **Conditional**, a **Pause**, a **Goto**, an **Assignment**, a **Parallel** or a new **StatementScope**