123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- <!doctype html>
- <title>CodeMirror: MscGen mode</title>
- <meta charset="utf-8"/>
- <link rel=stylesheet href="../../doc/docs.css">
- <link rel="stylesheet" href="../../lib/codemirror.css">
- <script src="../../lib/codemirror.js"></script>
- <script src="mscgen.js"></script>
- <style>.CodeMirror {border-top: 1px solid black; border-bottom: 1px solid black;}</style>
- <div id=nav>
- <a href="https://codemirror.net"><h1>CodeMirror</h1><img id=logo src="../../doc/logo.png"></a>
- <ul>
- <li><a href="../../index.html">Home</a>
- <li><a href="../../doc/manual.html">Manual</a>
- <li><a href="https://github.com/codemirror/codemirror">Code</a>
- </ul>
- <ul>
- <li><a href="../index.html">Language modes</a>
- <li><a class=active href="#">MscGen</a>
- </ul>
- </div>
- <article>
- <h2>MscGen mode</h2>
- <div><textarea id="mscgen-code">
- # Sample mscgen program
- # See http://www.mcternan.me.uk/mscgen or
- # https://sverweij.github.io/mscgen_js for more samples
- msc {
- # options
- hscale="1.2";
- # entities/ lifelines
- a [label="Entity A"],
- b [label="Entity B", linecolor="red", arclinecolor="red", textbgcolor="pink"],
- c [label="Entity C"];
- # arcs/ messages
- a => c [label="doSomething(args)"];
- b => c [label="doSomething(args)"];
- c >> * [label="everyone asked me", arcskip="1"];
- c =>> c [label="doing something"];
- c -x * [label="report back", arcskip="1"];
- |||;
- --- [label="shows's over, however ..."];
- b => a [label="did you see c doing something?"];
- a -> b [label="nope"];
- b :> a [label="shall we ask again?"];
- a => b [label="naah"];
- ...;
- }
- </textarea></div>
- <h2>Xù mode</h2>
- <div><textarea id="xu-code">
- # Xù - expansions to MscGen to support inline expressions
- # https://github.com/sverweij/mscgen_js/blob/master/wikum/xu.md
- # More samples: https://sverweij.github.io/mscgen_js
- xu {
- hscale="0.8",
- width="700";
- a,
- b [label="change store"],
- c,
- d [label="necro queue"],
- e [label="natalis queue"],
- f;
- a =>> b [label="get change list()"];
- a alt f [label="changes found"] { /* alt is a xu specific keyword*/
- b >> a [label="list of changes"];
- a =>> c [label="cull old stuff (list of changes)"];
- b loop e [label="for each change"] { // loop is xu specific as well...
- /*
- * Interesting stuff happens.
- */
- c =>> b [label="get change()"];
- b >> c [label="change"];
- c alt e [label="change too old"] {
- c =>> d [label="queue(change)"];
- --- [label="change newer than latest run"];
- c =>> e [label="queue(change)"];
- --- [label="all other cases"];
- ||| [label="leave well alone"];
- };
- };
- c >> a [label="done
- processing"];
- /* shucks! nothing found ...*/
- --- [label="nothing found"];
- b >> a [label="nothing"];
- a note a [label="silent exit"];
- };
- }
- </textarea></div>
- <h2>MsGenny mode</h2>
- <div><textarea id="msgenny-code">
- # MsGenny - simplified version of MscGen / Xù
- # https://github.com/sverweij/mscgen_js/blob/master/wikum/msgenny.md
- # More samples: https://sverweij.github.io/mscgen_js
- a -> b : a -> b (signal);
- a => b : a => b (method);
- b >> a : b >> a (return value);
- a =>> b : a =>> b (callback);
- a -x b : a -x b (lost);
- a :> b : a :> b (emphasis);
- a .. b : a .. b (dotted);
- a -- b : "a -- b straight line";
- a note a : a note a\n(note),
- b box b : b box b\n(action);
- a rbox a : a rbox a\n(reference),
- b abox b : b abox b\n(state/ condition);
- ||| : ||| (empty row);
- ... : ... (omitted row);
- --- : --- (comment);
- </textarea></div>
- <p>
- Simple mode for highlighting MscGen and two derived sequence
- chart languages.
- </p>
- <script>
- var mscgenEditor = CodeMirror.fromTextArea(document.getElementById("mscgen-code"), {
- lineNumbers: true,
- mode: "text/x-mscgen",
- });
- var xuEditor = CodeMirror.fromTextArea(document.getElementById("xu-code"), {
- lineNumbers: true,
- mode: "text/x-xu",
- });
- var msgennyEditor = CodeMirror.fromTextArea(document.getElementById("msgenny-code"), {
- lineNumbers: true,
- mode: "text/x-msgenny",
- });
- </script>
- <p><strong>MIME types defined:</strong>
- <code>text/x-mscgen</code>
- <code>text/x-xu</code>
- <code>text/x-msgenny</code>
- </p>
- </article>
|