Files
yoga/src/transpile.html

99 lines
2.4 KiB
HTML
Raw Normal View History

<script src="Layout.js"></script>
<style>
textarea {
height: 200px;
width: 800px;
border: 1px solid black;
font-size: 12px;
font-family: monospace;
}
</style>
<h1>layoutCode</h1>
<textarea id="layout_code" onclick="this.select()"></textarea>
<script>
document.getElementById('layout_code').value = computeLayout.layoutNode.toString()
.replace(/\.children\.length/g, '.children_count')
.replace(/layout\[dim/g, 'layout.dimensions[dim')
.replace(/layout\[pos/g, 'layout.position[pos')
.replace(/layout\[leading/g, 'layout.position[leading')
.replace(/style\[dim/g, 'style.dimensions[dim')
2014-04-18 15:48:44 -07:00
.replace(/node.children\[i\]/g, '&node.children[i]')
.replace(/node\./g, 'node->')
.replace(/child\./g, 'child->')
.replace(/var\/\*([^\/]+)\*\//g, '$1')
.replace(/\n /g, '\n');
</script>
2014-04-18 17:15:03 -07:00
<h1>Tests</h1>
<textarea id="test_code" onclick="this.select()"></textarea>
<script>
var currentTest = '';
var allTests = [];
var layoutTestUtils = {
testLayout: function(node, expectedLayout) {
allTests.push({name: currentTest, node: node, expectedLayout: expectedLayout});
},
testRandomLayout: function(node, i) {
}
};
function describe(name, cb) { cb(); }
function it(name, cb) { currentTest = name; cb(); }
</script>
<script src="__tests__/Layout-test.js"></script>
<script>
function printLayout(test) {
var level = 1;
var res = [];
function add(str) {
res.push(indent(level) + str);
}
function indent(level) {
var result = '';
for (var i = 0; i < level; ++i) {
result += ' ';
}
return result;
}
function rec(node) {
if (node.children) {
add('init_css_node_children(node, ' + node.children.length + ');');
add('css_node_t *outer_node = node;');
add('{');
level++;
add('css_node_t *node;');
for (var i = 0; i < node.children.length; ++i) {
add('node = &outer_node->children[' + i + '];');
rec(node.children[i]);
}
level--;
add('}');
}
}
add('{');
level++;
add('printf("%s", "' + test.name.replace(/"/g, '\\"') + '\\n");');
add('css_node_t *root_node = new_css_node();');
add('');
add('css_node_t *node = root_node;');
rec(test.node);
add('layoutNode(root_node);');
add('print_style(root_node, 0);');
add('print_layout(root_node, 0);');
add('free_css_node(root_node);');
level--;
add('}');
return res.join('\n');
}
document.getElementById('test_code').value = allTests.map(printLayout).join('\n\n');
</script>