Skip to content

Instantly share code, notes, and snippets.

View HTMLMarqueeElement.js
"use strict";
const conversions = require("webidl-conversions");
const utils = require("./utils.js");
const impl = utils.implSymbol;
const HTMLElement = require("./HTMLElement.js");
function HTMLMarqueeElement() {
throw new TypeError("Illegal constructor");
domenic / infinite-list-with-shadow-stuff.html
Last active Mar 7, 2018
View infinite-list-with-shadow-stuff.html
<!-- Clean light DOM: -->
<std-list id="list">
<div class="item">0 - Domenic</div>
<div class="item">1 - Ojan</div>
<div class="item">2 - Drew</div>
<div class="item">3 - Kevin</div>
<div class="item">4 - Gray</div>
<!-- Via this structure: -->
domenic /
Last active Nov 30, 2017
Contra Bruce Lawson's "Editing the W3C HTML5 spec"

A response to

Unfortunately this post contains a lot of inaccuracies. For example, the claim that the WHATWG HTML Standard is future-facing and for incubation is false. Such additions are explicitly against the WHATWG working mode: see the sections on Additions and New Proposals.

It also misunderstands the outline algorithm, which isn't a requirement on browsers, but instead guidance for developers as to how to structure their pages. As such it's not some kind of speculative browser feature as this post characterizes it. (It's bad guidance for developers—but the proper fix for that isn't to include some warning box saying "this feature, which isn't meant for browsers anyway, isn't implemented in browsers" like the W3C HTML fork does. The proper fix is outlined <a href="

domenic / private-static-1.js
Created Nov 30, 2017
Why private static methods are important
View private-static-1.js
// Today, with underscore-prefixed "private"
class Point {
constructor(x, y) {
this._x = x;
this._y = y;
length() {
return Math.sqrt(squareLengthHelper(this));
domenic /
Created Oct 5, 2017
FTL implies causality violation

(From a friend one mine; I'm just hosting this here.)

Issue 1: Relativity of Simultaneousness:

Your buddy Einstein is riding the interstellar express train. All the lights are off, but just as it passes your observation platform, he turns on a lamp in the middle of the train. You and he have taken bets on which end of the train, front or back, will light up first. As expected, your video cameras on the platform record the rear of the train lighting up first, since, as the light spreads out from the original location of the lamp, the rear of the train moves slightly closer to the source, while the front end is moving away. However, Einstein reports that his equipment shows both ends lit up simultaneously.

Both of you are correct. In your reference frame the events "light reaches front of train" and "light reaches rear of train" are not simultaneous, even though in Einstein's they are are.

Issue 2: Superluminal Travel

domenic / overconstrainederror.js
Created Sep 29, 2017
OverconstrainedError in V8 extras
View overconstrainederror.js
(function (global, binding, v8) {
const captureStackTrace = global.Error.captureStackTrace;
const defineProperty = global.Object.defineProperty;
const setPrototypeOf = global.Object.setPrototypeOf;
const Error = global.Error;
function OverconstrainedError(constraint, message = undefined) {
const obj = new Error();
// This complicated dance is necessary to emulate
domenic / call-graph.svg
Last active Aug 28, 2017
Exponential module call graph
View call-graph.svg
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
domenic / to-run-2.yaml
Last active Aug 20, 2017
New jsdom WPT manifest format
View to-run-2.yaml
DIR: dom/collections
HTMLCollection-as-proto-length-get-throws.html: [fail,]
HTMLCollection-supported-property-indices.html: [fail, Named versus indexed properties trickiness]
HTMLCollection-supported-property-names.html: [fail, Names vs. ids priority and effect on enumeration order]
domstringmap-supported-property-names.html: [fail, DOMStringMap not implemented]
DIR: dom/events
domenic / promise-finally-observability.js
Last active Aug 12, 2017
Promise.prototype.finally observability
View promise-finally-observability.js
// Current spec
function finally(onFinally) {
let C = SpeciesConstructor(this);
return this.then(
x => new C(r => r(onFinally())).then(() => x),
e => new C(r => r(onFinally())).then(() => { throw e; })
// Proposed, but rejected (potentially because of a miscommunication) spec
domenic /
Created Jun 7, 2017
Async generator next vs. return


async function* f() {
  const x = Promise.resolve(1);
  const y = Promise.resolve(2);
  const fromX = yield x;
  return y;