2016-01-13 22:45:08 +01:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
|
|
|
<head>
|
|
|
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
2016-02-15 19:51:05 +01:00
|
|
|
<title>NimYAML - Testing Ground</title>
|
2016-01-13 22:45:08 +01:00
|
|
|
|
|
|
|
<link href="docutils.css" rel="stylesheet" type="text/css"/>
|
|
|
|
<link href="style.css" rel="stylesheet" type="text/css"/>
|
|
|
|
|
|
|
|
<link href='http://fonts.googleapis.com/css?family=Raleway:400,600,900' rel='stylesheet' type='text/css'/>
|
|
|
|
<link href='http://fonts.googleapis.com/css?family=Source+Code+Pro:400,500,600' rel='stylesheet' type='text/css'/>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<header>
|
2016-02-25 22:45:48 +01:00
|
|
|
<a class="pagetitle" href="index.html">NimYAML</a>
|
2016-01-13 22:45:08 +01:00
|
|
|
<a href="index.html">Home</a>
|
|
|
|
<a href="testing.html">Testing Ground</a>
|
2016-02-15 22:56:36 +01:00
|
|
|
<span>Docs:</span>
|
2016-02-15 19:51:05 +01:00
|
|
|
<a href="api.html">Overview</a>
|
2016-02-15 22:56:36 +01:00
|
|
|
<a href="serialization.html">Serialization</a>
|
2016-01-13 22:45:08 +01:00
|
|
|
<a href="yaml.html">Module yaml</a>
|
|
|
|
</header>
|
|
|
|
<article id="documentId">
|
|
|
|
<div class="container">
|
|
|
|
<h1 class="title">Testing Ground</h1>
|
2016-02-15 19:51:05 +01:00
|
|
|
<p>Input is being processed on the fly by a friendly web service and
|
|
|
|
Output is updated as you type.</p>
|
2016-02-16 20:09:27 +01:00
|
|
|
</div>
|
|
|
|
</article>
|
|
|
|
<section id="testingground">
|
|
|
|
<table style="width: 100%; table-layout: fixed">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>Input</th>
|
|
|
|
<th>Output</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
<tr>
|
|
|
|
<td style="width: 50%; height: 550px; vertical-align: top;">
|
|
|
|
<textarea id="yaml-input" style="width: 100%; height: 100%">
|
2016-01-13 22:45:08 +01:00
|
|
|
- test some
|
|
|
|
- {YAML: here}
|
|
|
|
- foo: bar
|
|
|
|
? [1, 2, 3]
|
|
|
|
: !!str "string"
|
|
|
|
-
|
|
|
|
? &a anchor
|
|
|
|
: !!bool yes
|
|
|
|
? reference to anchor
|
|
|
|
: *a</textarea>
|
2016-02-16 20:09:27 +01:00
|
|
|
</td>
|
|
|
|
<td style="width: 50%; vertical-align: top; height: 550px; padding-left: 10px">
|
|
|
|
<div style="width:100%; height:100%; overflow: scroll">
|
|
|
|
<pre id="yaml-output" style="width: 100%"/>
|
|
|
|
</div>
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
<div id="style-options">
|
|
|
|
<div class="style-option">Output style:</div>
|
|
|
|
<div class="style-option">
|
|
|
|
<input type="radio" name="style" id="style-minimal" value="minimal"/>
|
|
|
|
<label for="style-minimal">Minimal</label>
|
|
|
|
</div>
|
|
|
|
<div class="style-option">
|
|
|
|
<input type="radio" name="style" id="style-default" value="default"/>
|
|
|
|
<label for="style-default">Default</label>
|
|
|
|
</div>
|
|
|
|
<div class="style-option">
|
|
|
|
<input type="radio" name="style" id="style-canonical" value="canonical" checked="checked"/>
|
|
|
|
<label for="style-canonical">Canonical</label>
|
|
|
|
</div>
|
|
|
|
<div class="style-option">
|
|
|
|
<input type="radio" name="style" id="style-block" value="block"/>
|
|
|
|
<label for="style-block">Block Only</label>
|
|
|
|
</div>
|
|
|
|
<div class="style-option">
|
|
|
|
<input type="radio" name="style" id="style-json" value="json"/>
|
|
|
|
<label for="style-json">JSON</label>
|
|
|
|
</div>
|
2016-02-18 15:53:28 +01:00
|
|
|
<div class="style-option">
|
|
|
|
<input type="radio" name="style" id="style-tokens" value="tokens"/>
|
|
|
|
<label for="style-tokens">Tokens</label>
|
|
|
|
</div>
|
2016-01-13 22:45:08 +01:00
|
|
|
</div>
|
2016-02-16 20:09:27 +01:00
|
|
|
</section>
|
|
|
|
<script type="text/javascript">
|
2016-01-13 23:11:03 +01:00
|
|
|
function setTextContent(element, text) {
|
|
|
|
while (element.firstChild!==null) {
|
|
|
|
element.removeChild(element.firstChild); // remove all existing content
|
|
|
|
}
|
|
|
|
element.appendChild(document.createTextNode(text));
|
|
|
|
}
|
2016-01-13 22:45:08 +01:00
|
|
|
function parse() {
|
|
|
|
var r = new XMLHttpRequest();
|
|
|
|
var params = "style=" + encodeURIComponent(document.querySelector(
|
|
|
|
"input[name=style]:checked").value) + "&input=" + encodeURIComponent(
|
|
|
|
document.getElementById("yaml-input").value);
|
|
|
|
r.open("POST", "http://flyx.org:5000", true);
|
|
|
|
r.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
|
|
|
|
r.onreadystatechange = function() {
|
|
|
|
if (r.readyState == 4) {
|
|
|
|
var output = document.getElementById("yaml-output");
|
|
|
|
if (r.status == 200) {
|
|
|
|
var result = JSON.parse(r.responseText);
|
|
|
|
switch(result.code) {
|
|
|
|
case 0:
|
2016-01-13 23:11:03 +01:00
|
|
|
setTextContent(output, result.output);
|
2016-01-13 22:45:08 +01:00
|
|
|
output.style.color = "black";
|
|
|
|
break;
|
|
|
|
case 1:
|
2016-01-13 23:11:03 +01:00
|
|
|
setTextContent(output, "Parser error at line " + result.line +
|
2016-01-13 22:45:08 +01:00
|
|
|
", column " + result.column + ":\n" + result.message +
|
2016-01-13 23:11:03 +01:00
|
|
|
"\n\n" + result.detail);
|
2016-01-13 22:45:08 +01:00
|
|
|
output.style.color = "orange";
|
|
|
|
break;
|
|
|
|
case 2:
|
2016-01-13 23:11:03 +01:00
|
|
|
setTextContent(output, "Presenter error:\n" + result.message);
|
2016-01-13 22:45:08 +01:00
|
|
|
output.style.color = "orange";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
} else if (r.status == 0) {
|
2016-01-13 23:11:03 +01:00
|
|
|
setTextContent(output,
|
|
|
|
"YAML parser server does not seem to be available.");
|
2016-01-13 22:45:08 +01:00
|
|
|
output.style.color = "red";
|
|
|
|
} else {
|
2016-01-13 23:11:03 +01:00
|
|
|
setTextContent(output, "Status: " + r.status +
|
|
|
|
"\nException occurred on server:\n\n" + r.responseText);
|
2016-01-13 22:45:08 +01:00
|
|
|
output.style.color = "red";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
r.send(params);
|
|
|
|
}
|
|
|
|
document.getElementById("yaml-input").addEventListener('input', parse,
|
|
|
|
false);
|
|
|
|
var radios = document.querySelectorAll("input[name=style]");
|
|
|
|
for (var i = 0; i < radios.length; ++i) {
|
|
|
|
radios[i].onclick = parse;
|
|
|
|
}
|
|
|
|
parse();
|
2016-02-16 20:09:27 +01:00
|
|
|
</script>
|
|
|
|
</body>
|
2016-02-18 15:53:28 +01:00
|
|
|
</html>
|