diff --git a/gitlab-pages/website/pages/en/index.js b/gitlab-pages/website/pages/en/index.js index 8c9cac7de..0f63faeb1 100644 --- a/gitlab-pages/website/pages/en/index.js +++ b/gitlab-pages/website/pages/en/index.js @@ -9,10 +9,73 @@ const React = require("react"); const CompLibrary = require("../../core/CompLibrary.js"); +const hljs = require("highlight.js"); + const MarkdownBlock = CompLibrary.MarkdownBlock; /* Used to read markdown */ const Container = CompLibrary.Container; const GridBlock = CompLibrary.GridBlock; +const pascaligoHighlighting = ` +function pascaligo(hljs) { + return { + case_insensitive: true, + keywords: 'and begin block case const contains down else end fail for ' + + 'from function if in is list map mod nil not of or patch ' + + 'procedure record remove set skip step then to type var while' + , + literal: 'true false unit int string some none', + lexemes: '[a-z_]\\w*!?' + + } +} +` + +const pre = "```"; + +const pascaligoExample = `${pre}pascaligo +// variant defining pseudo multi-entrypoint actions +type action is + | Increment + | Decrement + +function add(const a: int ; const b: int): int is + block { skip } with a + b + +function subtract(const a: int ; const b: int): int is + block { skip } with a - b + +// real entrypoint that re-routes the flow based on the action provided +function main(const p: action ; const s: int): (list(operation) * int) is +block { skip } with ((nil: list(operation)), + case p of + | Increment(n) -> add(s, n) + | Decrement(n) -> subtract(s, n) +end) +${ pre} `; + +const cameligoExample = `${pre}ocaml +type storage = int + +(* variant defining pseudo multi-entrypoint actions *) + +type action = + | Increment of int + | Decrement of int + +let add (a: int) (b: int): int = a + b + +let subtract (a: int) (b: int): int = a - b + +(* real entrypoint that re-routes the flow based on + the action provided *) +let%entry main(p : action) storage = + let storage = + match p with + | Increment n -> add storage n + | Decrement n -> subtract storage n + in (([] : operation list), storage) +${ pre} `; + const PascalLIGOTab = () => (
-
- // variant defining pseudo multi-entrypoint actions
-
- type action is
-
| Increment of int
-
| Decrement of int
-
-
- function add (const a : int ; const b : int) : int is
-
block {"{ skip }"} with a + b
-
- function subtract (const a : int ; const b : int) : int is
-
block {"{ skip }"} with a - b
-
- // real entrypoint that re-routes the flow based on the action
- provided
-
- function main (const p : action ; const s : int) : (list(operation)
- * int) is
-
block {"{ skip }"} with ((nil : list(operation)),
-
case p of
-
| Increment(n) -> add(s, n)
-
| Decrement(n) -> subtract(s, n)
-
end)
-
-
-
-
-
-
- type storage = int
-
- (* variant defining pseudo multi-entrypoint actions *)
-
- type action =
| Increment of int
-
| Decrement of int
-
-
- let add (a: int) (b: int) : int = a + b
-
- let subtract (a: int) (b: int) : int = a - b
-
- (* real entrypoint that re-routes the flow based on the action
- provided *)
-
-
- let%entry main (p : action) storage =
let storage =
match
- p with
-
| Increment n -> add storage n
| Decrement n -> subtract
- storage n
in (([] : operation list), storage)
-
-
-
- - We are not alone in this world -- here're some guys who support us + We are not alone in this world -- here're some people who support us