mirror of
https://github.com/lightpanda-io/browser.git
synced 2025-12-17 08:48:58 +00:00
Introduces an Env.String for persistent strings
If a webapi has a []const u8 parameter, then the page.call_arena is used. This is our favorite arena to use, but if the string value has a lifetime beyond the call, it then needs to be duped again (using page.arena). When a webapi has a Env.String parameter, the page.arena will be used directly to get the value from V8, removing the need for an intermediary dupe in the call_arena. This allows HTMLCollections to be streamlined. They no longer need to dupe the filter (tag name, class name, ...), which means they can no longer fail. It also means that we no longer need to needlessly dupe the string literals.
This commit is contained in:
@@ -10,50 +10,57 @@
|
||||
</body>
|
||||
|
||||
<script src="../testing.js"></script>
|
||||
<script id=exceptions>
|
||||
let content = $('#content');
|
||||
let pe = $('#para-empty');
|
||||
<script id=caseInsensitve>
|
||||
const Ptags = document.getElementsByTagName('P');
|
||||
testing.expectEqual(2, Ptags.length);
|
||||
testing.expectEqual('p', Ptags.item(0).localName);
|
||||
testing.expectEqual('p', Ptags.item(1).localName);
|
||||
</script>
|
||||
|
||||
let getElementsByTagName = document.getElementsByTagName('p');
|
||||
testing.expectEqual(2, getElementsByTagName.length);
|
||||
<script id=all>
|
||||
let allTags = document.getElementsByTagName('*');
|
||||
testing.expectEqual(13, allTags.length);
|
||||
testing.expectEqual('html', allTags.item(0).localName);
|
||||
testing.expectEqual('html', allTags.item(0).localName);
|
||||
testing.expectEqual('head', allTags.item(1).localName);
|
||||
testing.expectEqual('html', allTags.item(0).localName);
|
||||
testing.expectEqual('body', allTags.item(2).localName);
|
||||
testing.expectEqual('div', allTags.item(3).localName);
|
||||
testing.expectEqual('p', allTags.item(7).localName);
|
||||
testing.expectEqual('span', allTags.namedItem('para-empty-child').localName);
|
||||
|
||||
let getElementsByTagNameCI = document.getElementsByTagName('P');
|
||||
testing.expectEqual(2, getElementsByTagNameCI.length);
|
||||
testing.expectEqual('p', getElementsByTagName.item(0).localName);
|
||||
testing.expectEqual('p', getElementsByTagName.item(1).localName);
|
||||
|
||||
let getElementsByTagNameAll = document.getElementsByTagName('*');
|
||||
testing.expectEqual(10, getElementsByTagNameAll.length);
|
||||
testing.expectEqual('html', getElementsByTagNameAll.item(0).localName);
|
||||
testing.expectEqual('html', getElementsByTagNameAll.item(0).localName);
|
||||
testing.expectEqual('head', getElementsByTagNameAll.item(1).localName);
|
||||
testing.expectEqual('html', getElementsByTagNameAll.item(0).localName);
|
||||
testing.expectEqual('body', getElementsByTagNameAll.item(2).localName);
|
||||
testing.expectEqual('div', getElementsByTagNameAll.item(3).localName);
|
||||
testing.expectEqual('p', getElementsByTagNameAll.item(7).localName);
|
||||
testing.expectEqual('span', getElementsByTagNameAll.namedItem('para-empty-child').localName);
|
||||
|
||||
// array like
|
||||
testing.expectEqual('html', getElementsByTagNameAll[0].localName);
|
||||
testing.expectEqual('p', getElementsByTagNameAll[7].localName);
|
||||
testing.expectEqual(undefined, getElementsByTagNameAll[11]);
|
||||
testing.expectEqual('span', getElementsByTagNameAll['para-empty-child'].localName);
|
||||
testing.expectEqual(undefined, getElementsByTagNameAll['foo']);
|
||||
testing.expectEqual('html', allTags[0].localName);
|
||||
testing.expectEqual('p', allTags[7].localName);
|
||||
testing.expectEqual(undefined, allTags[14]);
|
||||
testing.expectEqual('span', allTags['para-empty-child'].localName);
|
||||
testing.expectEqual(undefined, allTags['foo']);
|
||||
</script>
|
||||
|
||||
<script id=element>
|
||||
let content = $('#content');
|
||||
testing.expectEqual(4, content.getElementsByTagName('*').length);
|
||||
testing.expectEqual(2, content.getElementsByTagName('p').length);
|
||||
testing.expectEqual(0, content.getElementsByTagName('div').length);
|
||||
|
||||
testing.expectEqual(1, document.children.length);
|
||||
testing.expectEqual(3, content.children.length);
|
||||
|
||||
// check liveness
|
||||
let p = document.createElement('p');
|
||||
testing.expectEqual('OK live', p.textContent = 'OK live');
|
||||
testing.expectEqual(' And', getElementsByTagName.item(1).textContent);
|
||||
testing.expectEqual(true, content.appendChild(p) != undefined);
|
||||
testing.expectEqual(3, getElementsByTagName.length);
|
||||
testing.expectEqual('OK live', getElementsByTagName.item(2).textContent);
|
||||
testing.expectEqual(true, content.insertBefore(p, pe) != undefined);
|
||||
testing.expectEqual('OK live', getElementsByTagName.item(0).textContent);
|
||||
</script>
|
||||
|
||||
<script id=liveness>
|
||||
const ptags = document.getElementsByTagName('p');
|
||||
testing.expectEqual(2, ptags.length);
|
||||
testing.expectEqual(' And', ptags.item(1).textContent);
|
||||
|
||||
let p = document.createElement('p');
|
||||
p.textContent = 'OK live';
|
||||
// hasn't been added, still 2
|
||||
testing.expectEqual(2, ptags.length);
|
||||
|
||||
testing.expectEqual(true, content.appendChild(p) != undefined);
|
||||
testing.expectEqual(3, ptags.length);
|
||||
testing.expectEqual('OK live', ptags.item(2).textContent);
|
||||
testing.expectEqual(true, content.insertBefore(p, $('#para-empty')) != undefined);
|
||||
testing.expectEqual('OK live', ptags.item(0).textContent);
|
||||
</script>
|
||||
|
||||
Reference in New Issue
Block a user