-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathcamxes.html
executable file
·73 lines (64 loc) · 2.5 KB
/
camxes.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
<!doctype html>
<html>
<body>
<meta charset='utf-8' />
<span style="font: 15px arial, sans-serif;">Type any Lojban text in the following textarea. The result will be parsed as you type:</span>
<br /><br />
<form id="form1" name="form1" method="post" action="" style="width:100%">
<textarea id="input_textarea" style="width:100%" rows="8" autofocus></textarea>
<br />
<span style="font: 15px arial, sans-serif;">Output mode: </span>
<select id="optlist" onChange="run_camxes()">
<option>Raw output</option>
<option>Condensed</option>
<option id="default">Prettified</option>
<option>Prettified + selmaho</option>
<option>Prettified + sm ext</option>
<option>Prettified --fm</option>
<option>Prettified --fm + selmaho</option>
<option>Prettified --fm + sm ext</option>
</select>
<span style="padding-left: 32px; text-align: right; font-size: 12px;">
<a href="camxes.js.peg" target="_blank">[ Grammar file ]</a>
</span>
<span style="padding-left: 24px; text-align: right; font-size: 12px;">
<a href="camxes-exp.html">[ Switch to experimental grammar ]</a>
</span>
</form>
<div style="display:block; overflow: scroll; max-height:24em; border: solid 1px; padding: 10px; background-color: #DDDDFF;"
height="24em">
<pre style="white-space: pre-wrap;"><code id="parse_result" width="100%" height="100%"> </code></pre>
</div>
<script type="text/javascript" src="jquery-1.9.1.min.js"></script>
<script type="text/javascript" src="camxes.js"></script>
<script type="text/javascript" src="camxes_preproc.js"></script>
<script type="text/javascript" src="camxes_postproc.js"></script>
<script>
document.getElementById("default").defaultSelected = true;
/*
* Binding the function run_camxes() to keyup event on demo_textarea by using jQuery
*/
$('#input_textarea').bind( "keyup",
function(e) {
run_camxes();
} );
function run_camxes() {
try {
var input = $('#input_textarea').val();
input = camxes_preprocessing(input);
var result = camxes.parse(input);
} catch (e) {
$('#parse_result').text( e.toString() );
return;
}
var result_str = JSON.stringify(result, undefined, 2);
/* We get the output mode selected in the combobox */
var mode = document.getElementById("optlist").selectedIndex;
/* Postprocessing — if mode == 0, the below function won't modify camxes' output */
result_str = camxes_postprocessing(result_str, mode); // @camxes_postproc.js
/* Retrieve the result */
$('#parse_result').text( result_str );
}
</script>
</body>
</html>