mirror of
				https://github.com/TriliumNext/Notes.git
				synced 2025-10-25 08:42:58 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			152 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			152 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <!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>
 | 
