WIP, some builtins, some fixes for new parser version

This commit is contained in:
Sven Slootweg 2023-09-09 14:33:02 +02:00
parent 42d44661b3
commit 883e691efe
21 changed files with 389 additions and 234 deletions

1
.gitignore vendored
View file

@ -1,3 +1,4 @@
node_modules node_modules
node_modules.bak
private-notes.txt private-notes.txt
old old

View file

@ -5,6 +5,7 @@
"main": "index.js", "main": "index.js",
"scripts": { "scripts": {
"test": "tape tests/**/* | tap-difflet", "test": "tape tests/**/* | tap-difflet",
"test-raw": "tape tests/**/*",
"eval": "DEBUG_NIX=1 node run.js" "eval": "DEBUG_NIX=1 node run.js"
}, },
"repository": { "repository": {
@ -35,8 +36,9 @@
"split-filter": "^1.1.3", "split-filter": "^1.1.3",
"tap-difflet": "^0.7.2", "tap-difflet": "^0.7.2",
"tape": "^5.5.0", "tape": "^5.5.0",
"tree-sitter": "^0.20.2",
"tree-sitter-javascript": "^0.19.0", "tree-sitter-javascript": "^0.19.0",
"tree-sitter-nix": "cstrahan/tree-sitter-nix" "tree-sitter-nix": "^0.0.2"
}, },
"devDependencies": { "devDependencies": {
"@joepie91/eslint-config": "^1.1.0", "@joepie91/eslint-config": "^1.1.0",

3
src/builtins/README.md Normal file
View file

@ -0,0 +1,3 @@
This folder contains implementations of the various `builtins` in Nix.
The way the exported functions are expressed here is subtly different from the rest of the codebase; arrow functions are used instead of regular functions. This is because Nix does not *really** have multi-argument functions, and so multi-argument functions need to be expressed as single-argument functions that return other single-argument functions. The only way to ergonomically express this is with nested arrow functions.

View file

@ -0,0 +1,11 @@
"use strict";
module.exports = ($attributeSet) => ($attributesToRemove) => {
let newAttributeSet = { ... $attributeSet() };
for (let $attribute of $attributesToRemove()) {
delete newAttributeSet[$attribute()];
}
return newAttributeSet;
};

9
src/builtins/seq.js Normal file
View file

@ -0,0 +1,9 @@
"use strict";
module.exports = ($a) => ($b) => {
// First evaluate the first argument...
$a();
// ... then evaluate and return the second argument.
return $b();
};

View file

@ -0,0 +1,49 @@
"use strict";
module.exports = ($version) => {
let version = $version();
// FIXME: assert string
let parts = [];
let currentPart = "";
let isNumber = null;
function finalizePart() {
if (currentPart !== "") {
// NOTE: Numbers get added to the list as strings anyway. This is really weird considering `nix-env -u`s comparison logic, but it's how upstream Nix works too.
parts.push(currentPart);
currentPart = "";
isNumber = null;
}
}
// SPEC: Is it correct to assume that only the ASCII character set is supported here?
// TODO: Replace this with a proper parser some day; maybe use it as a testcase for protocolkit?
for (let i = 0; i < version.length; i++) {
let code = version.charCodeAt(i);
if (code >= 48 && code <= 57) {
// Digit
if (isNumber !== true) {
finalizePart();
isNumber = true;
}
currentPart += version[i];
} else if ((code >= 65 && code <= 90) || (code >= 97 && code <= 122)) {
// Letter (uppercase and lowercase respectively)
if (isNumber !== false) {
finalizePart();
isNumber = false;
}
currentPart += version[i];
} else {
finalizePart();
}
}
finalizePart();
return parts;
};

View file

@ -11,64 +11,15 @@ module.exports = function evaluate(nixCode) {
} }
const builtins = { const builtins = {
seq: lazyWrap(($a) => ($b) => { seq: lazyWrap(require("./builtins/seq")),
// First evaluate the first argument... splitVersion: lazyWrap(require("./builtins/split-version")),
$a(); removeAttrs: lazyWrap(require("./builtins/remove-attrs")),
// ... then evaluate and return the second argument.
return $b();
}),
splitVersion: lazyWrap(($version) => {
let version = $version();
// FIXME: assert string
let parts = [];
let currentPart = "";
let isNumber = null;
function finalizePart() {
if (currentPart !== "") {
// NOTE: Numbers get added to the list as strings anyway. This is really weird considering `nix-env -u`s comparison logic, but it's how upstream Nix works too.
parts.push(currentPart);
currentPart = "";
isNumber = null;
}
}
// FIXME: Is it correct to assume that only the ASCII character set is supported here?
// TODO: Replace this with a proper parser some day
for (let i = 0; i < version.length; i++) {
let code = version.charCodeAt(i);
if (code >= 48 && code <= 57) {
// Digit
if (isNumber !== true) {
finalizePart();
isNumber = true;
}
currentPart += version[i];
} else if ((code >= 65 && code <= 90) || (code >= 97 && code <= 122)) {
// Letter (uppercase and lowercase respectively)
if (isNumber !== false) {
finalizePart();
isNumber = false;
}
currentPart += version[i];
} else {
finalizePart();
}
}
finalizePart();
return parts;
})
}; };
const api = { const api = {
builtins: () => builtins, builtins: lazyWrap(builtins),
// NOTE: `builtins` properties are already lazy-wrapped
removeAttrs: builtins.removeAttrs,
$memoize: function (func) { $memoize: function (func) {
let isCalled = false; let isCalled = false;
let storedResult; let storedResult;

View file

@ -3,6 +3,24 @@
const matchValue = require("match-value"); const matchValue = require("match-value");
const asExpression = require("as-expression"); const asExpression = require("as-expression");
const FIELD_MAPPINGS = {
attrset_expression: {
binding_set: "MERGE"
},
rec_attrset_expression: {
binding_set: "MERGE"
},
let_attrset_expression: {
binding_set: "MERGE"
},
};
function mergeNode(parent, child) {
// NOTE: Mutates parent!
let { type, ... childArgs } = child;
Object.assign(parent, childArgs);
}
// TODO: Refactor this // TODO: Refactor this
function convertStringNodeParts(node) { function convertStringNodeParts(node) {
let fullText = node.text; let fullText = node.text;
@ -65,6 +83,7 @@ function convertNode(node) {
: { type: "token", text: node.text } : { type: "token", text: node.text }
if (node.fields != null) { if (node.fields != null) {
// console.log({ node, fields: node.fields, children: node.children });
for (let field of node.fields) { for (let field of node.fields) {
let children = node[field]; let children = node[field];
let fieldName = field.replace(/Nodes?$/, ""); let fieldName = field.replace(/Nodes?$/, "");
@ -79,10 +98,26 @@ function convertNode(node) {
} }
}); });
} }
let nodeFieldMappings = FIELD_MAPPINGS[node.type];
if (nodeFieldMappings != null) {
node.children.forEach((child, i) => {
let mapTo = nodeFieldMappings[child.type];
if (mapTo === "MERGE") {
// This means we should elide the child node, and merge it into the node we're currently processing; this is used to deal with non-hidden layers of indirection
mergeNode(result, convertNode(child));
} else if (mapTo != null) {
// TODO: Support for multi-child fields?
result[mapTo] = convertNode(child);
}
});
}
} }
// Special case: if we don't provide a Babel-compatible top-level Program entry, traversal will fail // Special case: if we don't provide a Babel-compatible top-level Program entry, traversal will fail
if (type === "source_expression") { if (type === "source_code") {
return { return {
type: "Program", type: "Program",
sourceType: "script", sourceType: "script",
@ -90,73 +125,91 @@ function convertNode(node) {
}; };
} }
// Special case: this is just a wrapper for an identifier, and we don't really want to keep this wrapper
if (type === "variable_expression") {
return convertNode(node.nameNode);
}
// The below section is based on `alias` expressions throughout the grammar, and the rules in https://github.com/cstrahan/tree-sitter-nix/blob/83ee5993560bf15854c69b77d92e34456f8fb655/grammar.js#L53-L59 // The below section is based on `alias` expressions throughout the grammar, and the rules in https://github.com/cstrahan/tree-sitter-nix/blob/83ee5993560bf15854c69b77d92e34456f8fb655/grammar.js#L53-L59
if (type === "identifier" || type === "attr_identifier") { if (type === "identifier" || type === "attr_identifier") {
// FIXME: attr_identifier gone?
result.name = node.text; result.name = node.text;
} else if (type === "integer" || type === "float") { } else if (type === "integer_expression" || type === "float_expression") {
result.value = node.text; result.value = node.text;
} else if (type === "string") { } else if (type === "string_expression") {
result.parts = convertStringNodeParts(node); result.parts = convertStringNodeParts(node);
} else if (type === "path" || type === "hpath") { } else if (type === "path_expression" || type === "hpath_expression") {
result.path = node.text; result.path = node.text;
} else if (type === "spath") { } else if (type === "spath_expression") {
// Strip the < and > // Strip the < and >
result.path = node.text.slice(1, -1); result.path = node.text.slice(1, -1);
} else if (type === "uri") { } else if (type === "uri_expression") {
result.uri = node.text; result.uri = node.text;
} }
if (type === "binary") { if (type === "binary_expression") {
// Unpack the anonymous token // Unpack the anonymous token
result.operator = result.operator.text; result.operator = result.operator.text;
} }
if (type === "rec_attrset") { if (type === "rec_attrset_expression") {
result.recursive = true; result.recursive = true;
} else if (type === "attrset") { } else if (type === "attrset") {
result.recursive = false; result.recursive = false;
} }
// FIXME: Is this code still needed after the parser updates?
if (type === "inherit") { if (type === "inherit") {
// We're inheriting from scope here, so the source expression is explicitly not set // We're inheriting from scope here, so the source expression is explicitly not set
result.expression = null; result.expression = result.expression ?? null;
} else if (type === "inherit_from") { } else if (type === "inherit_from") {
// Already set // Already set
} }
if (type === "list_expression") {
// TODO: Can this sort of renaming be done more neatly?
result.elements = result.element;
delete result.element;
}
// console.log(result); // console.log(result);
result.type = matchValue(result.type, { result.type = matchValue(result.type, {
source_expression: "NixProgram", source_code: "NixProgram",
token: "NixAnonymousToken", token: "NixAnonymousToken",
path: "NixPathLiteral", path_expression: "NixPathLiteral",
hpath: "NixHomePathLiteral", hpath_expression: "NixHomePathLiteral", /* FIXME: Do we have interpolation support here yet? */
spath: "NixEnvironmentPathLiteral", spath_expression: "NixEnvironmentPathLiteral",
uri: "NixURILiteral", uri_expression: "NixURILiteral",
integer: "NixIntegerLiteral", integer_expression: "NixIntegerLiteral",
float: "NixFloatLiteral", float_expression: "NixFloatLiteral",
string: "NixStringLiteral", string_expression: "NixStringLiteral",
parenthesized: "NixParenthesizedExpression", parenthesized_expression: "NixParenthesizedExpression",
attrset: "NixAttributeSet", attrset_expression: "NixAttributeSet",
rec_attrset: "NixAttributeSet", rec_attrset_expression: "NixAttributeSet",
let: "NixLetIn", binding_set: "NixAttributeSetBindings",
let_attrset: "NixLetAttributeSet", let_expression: "NixLetIn",
let_attrset_expression: "NixLetAttributeSet",
identifier: "NixIdentifier", identifier: "NixIdentifier",
attr_identifier: "NixAttributeIdentifier", attr_identifier: "NixAttributeIdentifier", // FIXME: Gone?
attrpath: "NixAttributePath", attrpath: "NixAttributePath",
inherit: "NixInherit", inherit: "NixInherit",
inherit_from: "NixInherit", inherit_from: "NixInherit",
attrs_inherited: "NixInheritAttributes", inherited_attrs: "NixInheritAttributes",
attrs_inherited_from: "NixInheritAttributes", attrs_inherited_from: "NixInheritAttributes", // FIXME: Gone?
bind: "NixBinding", binding: "NixBinding",
binary: "NixBinaryOperation", binary_expression: "NixBinaryOperation",
app: "NixFunctionCall", apply_expression: "NixFunctionCall",
select: "NixAttributeSelection", select_expression: "NixAttributeSelection",
interpolation: "NixInterpolationExpression", interpolation: "NixInterpolationExpression",
list_expression: "NixListLiteral",
with_expression: "NixWithExpression",
// Function definitions // Function definitions
function: "NixFunctionDefinition", function_expression: "NixFunctionDefinition",
formals: "NixUnpackedAttributes", formals: "NixUnpackedAttributes",
formal: "NixUnpackedAttribute", formal: "NixUnpackedAttribute",
// _: (value) => value
// FIXME: assert_expression? if_expression? unary_expression? has_attr_expression? apply_expression? indented_string_expression? binding_set?
}); });
return result; return result;

View file

@ -59,7 +59,7 @@ let tmplRecursiveBinding = template(`
function isDynamicBinding(binding) { function isDynamicBinding(binding) {
return binding.attrpath.attr[0].type !== "NixAttributeIdentifier"; return binding.attrpath.attr[0].type !== "NixIdentifier";
} }
function objectNormal(bindings) { function objectNormal(bindings) {
@ -126,8 +126,7 @@ module.exports = {
assert(node.attrpath.type === "NixAttributePath"); assert(node.attrpath.type === "NixAttributePath");
return node.attrpath.attr.reduce((last, identifier) => { return node.attrpath.attr.reduce((last, identifier) => {
assert(identifier.type === "NixAttributeIdentifier"); // console.log({identifier});
return callLazyWrapper(types.memberExpression(last, types.identifier(identifier.name))); return callLazyWrapper(types.memberExpression(last, types.identifier(identifier.name)));
}, node.expression); }, node.expression);
}); });
@ -151,7 +150,7 @@ module.exports = {
// }; // };
// }); // });
let bindings = node.bind.map((binding) => { let bindings = node.binding.map((binding) => {
assert(binding.attrpath.attr.length === 1); // Nested attributes should have been desugared by this point assert(binding.attrpath.attr.length === 1); // Nested attributes should have been desugared by this point
return { return {

View file

@ -4,21 +4,21 @@
const unreachable = require("@joepie91/unreachable")("jsNix"); const unreachable = require("@joepie91/unreachable")("jsNix");
const NoChange = require("astformer/actions/no-change"); // FIXME const NoChange = require("astformer/actions/no-change"); // FIXME
const { NixAttributeIdentifier, NixAttributeSet, NixBinding } = require("./util/nix-types"); const { NixIdentifier, NixAttributeSet, NixBinding } = require("./util/nix-types");
function isAttributeSet(node) { function isAttributeSet(node) {
return (node.type === "NixAttributeSet"); return (node.type === "NixAttributeSet");
} }
function mergeAttributeSets(a, b) { function mergeAttributeSets(a, b) {
return NixAttributeSet([ ... a.bind, ... b.bind ]); return NixAttributeSet([ ... a.binding, ... b.binding ]);
} }
function mergeBindings(name, a, b) { function mergeBindings(name, a, b) {
let attributes = mergeAttributeSets(unpackBindingValue(a), unpackBindingValue(b)); let attributes = mergeAttributeSets(unpackBindingValue(a), unpackBindingValue(b));
return NixBinding( return NixBinding(
[ NixAttributeIdentifier(name) ], [ NixIdentifier(name) ],
attributes attributes
); );
} }
@ -51,14 +51,14 @@ module.exports = {
let newStaticBindings = {}; let newStaticBindings = {};
let dynamicBindings = []; let dynamicBindings = [];
for (let binding of node.bind) { for (let binding of node.binding) {
if (binding.type === "NixBinding") { if (binding.type === "NixBinding") {
if (binding.attrpath.attr.length > 1) { if (binding.attrpath.attr.length > 1) {
neededDesugaring = true; neededDesugaring = true;
} }
let firstAttribute = binding.attrpath.attr[0]; let firstAttribute = binding.attrpath.attr[0];
let isStaticAttribute = firstAttribute.type === "NixAttributeIdentifier"; let isStaticAttribute = firstAttribute.type === "NixIdentifier";
if (isStaticAttribute) { if (isStaticAttribute) {
let attributeName = firstAttribute.name; let attributeName = firstAttribute.name;

View file

@ -10,7 +10,8 @@ module.exports = {
name: "desugar-inherits", name: "desugar-inherits",
visitors: { visitors: {
NixAttributeSet: (node) => { NixAttributeSet: (node) => {
let [ inherits, regularBindings ] = splitFilter(node.bind, (binding) => binding.type === "NixInherit"); // console.dir(node, {depth:null})
let [ inherits, regularBindings ] = splitFilter(node.binding, (binding) => binding.type === "NixInherit");
if (inherits.length === 0) { if (inherits.length === 0) {
return NoChange; return NoChange;
@ -21,7 +22,7 @@ module.exports = {
tempName: `$temp$${tempCounter++}`, tempName: `$temp$${tempCounter++}`,
sourceExpression: inherit.expression, sourceExpression: inherit.expression,
names: inherit.attrs.attr.map((attribute) => { names: inherit.attrs.attr.map((attribute) => {
assert(attribute.type === "NixAttributeIdentifier"); assert(attribute.type === "NixIdentifier");
return attribute.name; return attribute.name;
}) })
}; };
@ -29,7 +30,7 @@ module.exports = {
let letBindings = inherits_.map((inherit) => { let letBindings = inherits_.map((inherit) => {
return nixTypes.NixBinding( return nixTypes.NixBinding(
[ nixTypes.NixAttributeIdentifier(inherit.tempName) ], [ nixTypes.NixIdentifier(inherit.tempName) ],
inherit.sourceExpression inherit.sourceExpression
); );
}); });
@ -37,10 +38,10 @@ module.exports = {
let inheritedAttributeBindings = inherits_.flatMap((inherit) => { let inheritedAttributeBindings = inherits_.flatMap((inherit) => {
return inherit.names.map((name) => { return inherit.names.map((name) => {
return nixTypes.NixBinding( return nixTypes.NixBinding(
[ nixTypes.NixAttributeIdentifier(name) ], [ nixTypes.NixIdentifier(name) ],
nixTypes.NixAttributeSelection( nixTypes.NixAttributeSelection(
nixTypes.NixIdentifier(inherit.tempName), nixTypes.NixIdentifier(inherit.tempName),
[ nixTypes.NixAttributeIdentifier(name) ] [ nixTypes.NixIdentifier(name) ]
) )
); );
}); });

View file

@ -8,7 +8,7 @@ const _nixTypes = require("./util/nix-types");
function isValidBodyAttribute(binding) { function isValidBodyAttribute(binding) {
assert(binding.attrpath.type === "NixAttributePath"); assert(binding.attrpath.type === "NixAttributePath");
assert(binding.attrpath.attr.length > 0); assert(binding.attrpath.attr.length > 0);
assert(binding.attrpath.attr[0].type === "NixAttributeIdentifier"); assert(binding.attrpath.attr[0].type === "NixIdentifier");
if (binding.attrpath.attr[0].name === "body") { if (binding.attrpath.attr[0].name === "body") {
if (binding.attrpath.attr.length > 1) { if (binding.attrpath.attr.length > 1) {
@ -27,7 +27,7 @@ module.exports = {
NixLetAttributeSet: (node) => { NixLetAttributeSet: (node) => {
// We save a bunch of complexity here by directly translating to a recursive attribute set instead of `let..in`; our JS representation of `let..in` is *functionally* identical to how a LetAttributeSet works. We just use a different attribute name to represent the returned evaluation. // We save a bunch of complexity here by directly translating to a recursive attribute set instead of `let..in`; our JS representation of `let..in` is *functionally* identical to how a LetAttributeSet works. We just use a different attribute name to represent the returned evaluation.
let [ bodyBindings, actualBindings ] = splitFilter(node.bind, (binding) => isValidBodyAttribute(binding)); let [ bodyBindings, actualBindings ] = splitFilter(node.binding, (binding) => isValidBodyAttribute(binding));
if (bodyBindings.length === 0) { if (bodyBindings.length === 0) {
// TODO: Display source code position + snippet // TODO: Display source code position + snippet

View file

@ -5,10 +5,11 @@ const types = require("@babel/types");
const template = require("@babel/template").default; const template = require("@babel/template").default;
const templateExpression = require("./util/template-expression"); const templateExpression = require("./util/template-expression");
const NoChange = require("astformer/actions/no-change");
// FIXME: Auto-generate argument list based on exposed API surface? // FIXME: Auto-generate argument list based on exposed API surface?
let tmplModule = template(` let tmplModule = template(`
module.exports = function({ builtins, $memoize, $handleArgument, $assertUniqueKeys }) { module.exports = function({ builtins, removeAttrs, $memoize, $handleArgument, $assertUniqueKeys }) {
return %%contents%%; return %%contents%%;
}; };
`); `);
@ -17,6 +18,24 @@ let tmplIdentifierReference = templateExpression(`(
%%name%%() %%name%%()
)`); )`);
let tmplWithWrapper = templateExpression(`
(() => {
const %%contextName%% = %%setupCode%%;
return %%body%%;
})()
`);
let tmplImplicitContextNested = templateExpression(`
Object.assign(Object.create(%%parent%%), %%environment%%)
`);
let tmplImplicitContextTop = templateExpression(`
Object.assign({}, %%environment%%)
`);
let implicitContextCounter = 0;
let trivial = { let trivial = {
name: "trivial-transforms", name: "trivial-transforms",
visitors: { visitors: {
@ -30,24 +49,58 @@ let trivial = {
return tmplModule({ contents: node.body[0] }); return tmplModule({ contents: node.body[0] });
}); });
}, },
NixAttributePath: (_node, { setContext }) => {
// This ensures that attribute paths get excluded from being processed as an identifier, now that the parser no longer distinguishes between attribute identifiers and regular identifiers
setContext([ "attr" ], "identifierType", "attributePath");
return NoChange;
},
NixIdentifier: (node, { getContext }) => { NixIdentifier: (node, { getContext }) => {
// FIXME: Mangle reserved keywords like `const` // FIXME: Mangle reserved keywords like `const`
let safeName = (node.name === "import")
? "$import"
: node.name;
if (getContext("identifierType") === "define") { if (getContext("identifierType") === "define") {
return types.identifier(node.name); return types.identifier(safeName);
} else if (getContext("identifierType") === "attributePath") {
// Do nothing, this will get removed from the tree in attribute set handling
return NoChange;
} else { // reference } else { // reference
return tmplIdentifierReference({ name: node.name }); return tmplIdentifierReference({ name: safeName });
} }
}, },
NixBinaryOperation: (_node, { defer }) => { NixBinaryOperation: (_node, { defer }) => {
return defer((node) => { return defer((node) => {
// FIXME: Verify that all the 'operator' values match between Nix and JS! // FIXME: Verify that all the 'operator' values match between Nix and JS!
// FIXME: Need to replace this with utility functions to deal with eg. paths
return types.binaryExpression(node.operator, node.left, node.right); return types.binaryExpression(node.operator, node.left, node.right);
}); });
},
NixWithExpression: (node, { defer, setContext, getContext }) => {
// TODO: Can we optimize for the fast case (no nested `with`) by referencing the source attrset directly?
let parentContext = getContext("implicitContext");
let hasParent = (parentContext != null);
let contextName = `$implicit${implicitContextCounter++}`;
setContext(null, "implicitContext", contextName);
let setupCode = (hasParent)
? tmplImplicitContextNested({ environment: node.environment, parent: parentContext })
: tmplImplicitContextTop({ environment: node.environment });
return defer((node) => {
return tmplWithWrapper({
contextName: contextName,
setupCode: setupCode,
body: node.body
});
});
} }
} }
}; };
module.exports = [ module.exports = [
// FIXME: desugar-search-path
require("./desugar-inherits"), require("./desugar-inherits"),
require("./desugar-attrsets"), require("./desugar-attrsets"),
require("./desugar-let-attribute-set"), require("./desugar-let-attribute-set"),
@ -55,6 +108,7 @@ module.exports = [
require("./mangle-identifiers"), require("./mangle-identifiers"),
require("./let-in"), require("./let-in"),
require("./literals"), require("./literals"),
require("./lists"),
require("./functions"), require("./functions"),
require("./attribute-sets"), require("./attribute-sets"),
trivial, trivial,

View file

@ -7,7 +7,7 @@ module.exports = {
visitors: { visitors: {
NixLetIn: (node) => { NixLetIn: (node) => {
return nixTypes.JSNixLet( return nixTypes.JSNixLet(
node.bind, node.binding,
node.body node.body
); );
} }

19
src/transformers/lists.js Normal file
View file

@ -0,0 +1,19 @@
"use strict";
const types = require("@babel/types");
const lazyWrapper = require("./templates/lazy-wrapper");
module.exports = {
name: "lists",
visitors: {
NixListLiteral: (_node, { defer }) => {
return defer((node) => {
return types.arrayExpression(
node.elements.map((element) => {
return lazyWrapper(element);
})
);
});
}
}
};

View file

@ -2,12 +2,18 @@
const types = require("@babel/types"); const types = require("@babel/types");
const splitFilter = require("split-filter"); const splitFilter = require("split-filter");
const templateExpression = require("./util/template-expression");
let tmplPathLiteral = templateExpression(`
$path(%%path%%)
`);
module.exports = { module.exports = {
name: "literals", name: "literals",
visitors: { visitors: {
NixIntegerLiteral: (node) => types.numericLiteral(parseInt(node.value)), NixIntegerLiteral: (node) => types.numericLiteral(parseInt(node.value)),
NixFloatLiteral: (node) => types.numericLiteral(parseFloat(node.value)), NixFloatLiteral: (node) => types.numericLiteral(parseFloat(node.value)),
NixPathLiteral: (node) => tmplPathLiteral({ path: types.stringLiteral(node.path) }),
NixStringLiteral: (node, { defer }) => { NixStringLiteral: (node, { defer }) => {
if (node.parts.length === 1 && node.parts[0].type === "NixInterpolationLiteral") { if (node.parts.length === 1 && node.parts[0].type === "NixInterpolationLiteral") {
// Fast case; just a simple, non-interpolated string literal // Fast case; just a simple, non-interpolated string literal
@ -22,6 +28,6 @@ module.exports = {
); );
}); });
} }
} },
} }
}; };

View file

@ -18,7 +18,7 @@ function mangleNode(node) {
module.exports = { module.exports = {
name: "mangle-identifiers", name: "mangle-identifiers",
visitors: { visitors: {
NixAttributeIdentifier: mangleNode, // NixAttributeIdentifier: mangleNode,
NixIdentifier: mangleNode NixIdentifier: mangleNode
} }
}; };

View file

@ -8,6 +8,7 @@ module.exports = function objectLiteral(entries) {
if (typeof key === "string") { if (typeof key === "string") {
return types.objectProperty(types.stringLiteral(key), value, false); return types.objectProperty(types.stringLiteral(key), value, false);
} else { } else {
// console.dir({entries}, {depth:null});
return types.objectProperty(key, value, true); return types.objectProperty(key, value, true);
} }
}) })

View file

@ -71,11 +71,11 @@ let types = module.exports = {
types.NixAttributeSet([ types.NixAttributeSet([
... bindings, ... bindings,
types.NixBinding( types.NixBinding(
[ types.NixAttributeIdentifier("$letBody") ], [ types.NixIdentifier("$letBody") ],
body body
) )
], true), ], true),
[ types.NixAttributeIdentifier("$letBody") ] [ types.NixIdentifier("$letBody") ]
); );
} }
}; };

View file

@ -1,51 +1,55 @@
"use strict"; "use strict";
const tape = require("tape-catch"); try {
const fs = require("fs"); const tape = require("tape-catch");
const path = require("path"); const fs = require("fs");
const util = require("util"); const path = require("path");
const evaluate = require("../src/evaluate"); const util = require("util");
const evaluate = require("../src/evaluate");
const NIX_SOURCE_REPO = process.env.NIX_SOURCE_REPO; const NIX_SOURCE_REPO = process.env.NIX_SOURCE_REPO;
if (NIX_SOURCE_REPO == null) { if (NIX_SOURCE_REPO == null) {
throw new Error(`To run the upstream Nix language tests, you must specify a NIX_SOURCE_REPO environment variable, that points at the root of a local checkout of the Git repository for Nix`); throw new Error(`To run the upstream Nix language tests, you must specify a NIX_SOURCE_REPO environment variable, that points at the root of a local checkout of the Git repository for Nix`);
}
const testsPath = path.join(NIX_SOURCE_REPO, "tests/lang");
let tests = fs.readdirSync(testsPath)
.filter((entry) => entry.endsWith(".exp"))
.map((entry) => entry.replace(/\.exp$/, ""));
function formatResultNode(node) {
if (typeof node === "string") {
return `"${node.replace(/"/g, '\\"')}"`;
} else if (Array.isArray(node)) {
return `[ ${node.map(formatResultNode).join(" ")} ]`;
} else {
return node.toString();
} }
}
for (let test of tests) { const testsPath = path.join(NIX_SOURCE_REPO, "tests/lang");
try {
let expression = fs.readFileSync(path.join(testsPath, `${test}.nix`), "utf8");
let expectedResult = fs.readFileSync(path.join(testsPath, `${test}.exp`), "utf8").replace(/\n$/, "");
tape(`Nix upstream language tests - ${test}`, (test) => { let tests = fs.readdirSync(testsPath)
test.plan(1); .filter((entry) => entry.endsWith(".exp"))
.map((entry) => entry.replace(/\.exp$/, ""));
let result = formatResultNode(evaluate(expression).value); function formatResultNode(node) {
if (typeof node === "string") {
test.equals(expectedResult, result); return `"${node.replace(/"/g, '\\"')}"`;
}); } else if (Array.isArray(node)) {
} catch (error) { return `[ ${node.map(formatResultNode).join(" ")} ]`;
// FIXME: This would currently cause ENOENTs during evaluation (eg. reading a file from Nix itself) to be ignored
if (error.code === "ENOENT") {
// skip
} else { } else {
throw error; return node.toString();
} }
} }
for (let test of tests) {
try {
let expression = fs.readFileSync(path.join(testsPath, `${test}.nix`), "utf8");
let expectedResult = fs.readFileSync(path.join(testsPath, `${test}.exp`), "utf8").replace(/\n$/, "");
tape(`Nix upstream language tests - ${test}`, (test) => {
test.plan(1);
let result = formatResultNode(evaluate(expression).value);
test.equals(expectedResult, result);
});
} catch (error) {
// FIXME: This would currently cause ENOENTs during evaluation (eg. reading a file from Nix itself) to be ignored
if (error.code === "ENOENT") {
// skip
} else {
throw error;
}
}
}
} catch (error) {
console.error(error);
} }

162
yarn.lock
View file

@ -487,12 +487,7 @@ ajv@^6.10.0, ajv@^6.12.4:
ansi-regex@^2.0.0: ansi-regex@^2.0.0:
version "2.1.1" version "2.1.1"
resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df" resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df"
integrity sha1-w7M6te42DYbg5ijwRorn7yfWVN8= integrity sha512-TIGnTpdo+E3+pCyAluZvtED5p5wCqLdezCyhPZzKPcxvFplEt4i+W7OONCKgeZFT3+y5NZZfOOS/Bdcanm1MYA==
ansi-regex@^3.0.0:
version "3.0.0"
resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.0.tgz#ed0317c322064f79466c02966bddb605ab37d998"
integrity sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=
ansi-regex@^5.0.1: ansi-regex@^5.0.1:
version "5.0.1" version "5.0.1"
@ -689,7 +684,7 @@ chownr@^1.1.1:
code-point-at@^1.0.0: code-point-at@^1.0.0:
version "1.1.0" version "1.1.0"
resolved "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz#0d070b4d043a5bea33a2f1a40e2edb3d9a4ccf77" resolved "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz#0d070b4d043a5bea33a2f1a40e2edb3d9a4ccf77"
integrity sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c= integrity sha512-RpAVKQA5T63xEj6/giIbUEtZwJ4UFIc3ZtvEkiaUERylqe8xb5IvqcgOurZLahv93CLKfxcw5YI+DZcUBRyLXA==
color-convert@^1.9.0: color-convert@^1.9.0:
version "1.9.3" version "1.9.3"
@ -733,7 +728,7 @@ concat-map@0.0.1:
console-control-strings@^1.0.0, console-control-strings@~1.1.0: console-control-strings@^1.0.0, console-control-strings@~1.1.0:
version "1.1.0" version "1.1.0"
resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e"
integrity sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4= integrity sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ==
convert-source-map@^1.7.0: convert-source-map@^1.7.0:
version "1.8.0" version "1.8.0"
@ -842,12 +837,12 @@ defined@^1.0.0:
delegates@^1.0.0: delegates@^1.0.0:
version "1.0.0" version "1.0.0"
resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a" resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a"
integrity sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o= integrity sha512-bd2L678uiWATM6m5Z1VzNCErI3jiGzt6HGY8OVICs40JQq/HALfbyNJmp0UDakEY4pMMaN0Ly5om/B1VI/+xfQ==
detect-libc@^1.0.3: detect-libc@^1.0.3:
version "1.0.3" version "1.0.3"
resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-1.0.3.tgz#fa137c4bd698edf55cd5cd02ac559f91a4c4ba9b" resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-1.0.3.tgz#fa137c4bd698edf55cd5cd02ac559f91a4c4ba9b"
integrity sha1-+hN8S9aY7fVc1c0CrFWfkaTEups= integrity sha512-pGjwhsmsp4kL2RTz08wcOlGN83otlqHeD/Z5T8GXZB+/YcpQ/dgo+lbU8ZsGxV0HIvqqxo9l7mqYwyYMD9bKDg==
diff@1.0: diff@1.0:
version "1.0.8" version "1.0.8"
@ -897,6 +892,11 @@ electron-to-chromium@^1.3.830:
resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.3.842.tgz#641e414012dded277468892c0156cb01984f4f6f" resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.3.842.tgz#641e414012dded277468892c0156cb01984f4f6f"
integrity sha512-P/nDMPIYdb2PyqCQwhTXNi5JFjX1AsDVR0y6FrHw752izJIAJ+Pn5lugqyBq4tXeRSZBMBb2ZGvRGB1djtELEQ== integrity sha512-P/nDMPIYdb2PyqCQwhTXNi5JFjX1AsDVR0y6FrHw752izJIAJ+Pn5lugqyBq4tXeRSZBMBb2ZGvRGB1djtELEQ==
emoji-regex@^8.0.0:
version "8.0.0"
resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37"
integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==
end-of-stream@^1.1.0, end-of-stream@^1.4.1: end-of-stream@^1.1.0, end-of-stream@^1.4.1:
version "1.4.4" version "1.4.4"
resolved "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" resolved "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0"
@ -1193,7 +1193,7 @@ functional-red-black-tree@^1.0.1:
gauge@~2.7.3: gauge@~2.7.3:
version "2.7.4" version "2.7.4"
resolved "https://registry.yarnpkg.com/gauge/-/gauge-2.7.4.tgz#2c03405c7538c39d7eb37b317022e325fb018bf7" resolved "https://registry.yarnpkg.com/gauge/-/gauge-2.7.4.tgz#2c03405c7538c39d7eb37b317022e325fb018bf7"
integrity sha1-LANAXHU4w51+s3sxcCLjJfsBi/c= integrity sha512-14x4kjc6lkD3ltw589k0NrPD6cCNTD6CWoVUNpB85+DrtONoZn+Rug6xZU5RvSC4+TZPxA5AnBibQYAvZn41Hg==
dependencies: dependencies:
aproba "^1.0.3" aproba "^1.0.3"
console-control-strings "^1.0.0" console-control-strings "^1.0.0"
@ -1239,7 +1239,7 @@ get-symbol-description@^1.0.0:
github-from-package@0.0.0: github-from-package@0.0.0:
version "0.0.0" version "0.0.0"
resolved "https://registry.yarnpkg.com/github-from-package/-/github-from-package-0.0.0.tgz#97fb5d96bfde8973313f20e8288ef9a167fa64ce" resolved "https://registry.yarnpkg.com/github-from-package/-/github-from-package-0.0.0.tgz#97fb5d96bfde8973313f20e8288ef9a167fa64ce"
integrity sha1-l/tdlr/eiXMxPyDoKI75oWf6ZM4= integrity sha512-SyHy3T1v2NUXn29OsWdxmK6RwHD+vkj3v8en8AOBZ1wBQ/hCAQ5bAQTD02kW4W9tUp/3Qh6J8r9EvntiyCmOOw==
glob-parent@^6.0.1: glob-parent@^6.0.1:
version "6.0.2" version "6.0.2"
@ -1323,7 +1323,7 @@ has-tostringtag@^1.0.0:
has-unicode@^2.0.0: has-unicode@^2.0.0:
version "2.0.1" version "2.0.1"
resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9"
integrity sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk= integrity sha512-8Rf9Y83NBReMnx0gFzA8JImQACstCYWUplepDa9xprwwtmgEZUF0h/i5xSA625zB/I37EtrswSST6OXxwaaIJQ==
has@^1.0.3: has@^1.0.3:
version "1.0.3" version "1.0.3"
@ -1464,14 +1464,14 @@ is-finite@^1.0.0, is-finite@^1.0.1:
is-fullwidth-code-point@^1.0.0: is-fullwidth-code-point@^1.0.0:
version "1.0.0" version "1.0.0"
resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz#ef9e31386f031a7f0d643af82fde50c457ef00cb" resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz#ef9e31386f031a7f0d643af82fde50c457ef00cb"
integrity sha1-754xOG8DGn8NZDr4L95QxFfvAMs= integrity sha512-1pqUqRjkhPJ9miNq9SwMfdvi6lBJcd6eFxvfaivQhaH3SgisfiuudvFntdKOmxuee/77l+FPjKrQjWvmPjWrRw==
dependencies: dependencies:
number-is-nan "^1.0.0" number-is-nan "^1.0.0"
is-fullwidth-code-point@^2.0.0: is-fullwidth-code-point@^3.0.0:
version "2.0.0" version "3.0.0"
resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f" resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d"
integrity sha1-o7MKXE8ZkYMWeqq5O+764937ZU8= integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==
is-glob@^4.0.0, is-glob@^4.0.3: is-glob@^4.0.0, is-glob@^4.0.3:
version "4.0.3" version "4.0.3"
@ -1583,7 +1583,7 @@ isarray@^2.0.5:
isarray@~1.0.0: isarray@~1.0.0:
version "1.0.0" version "1.0.0"
resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11"
integrity sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE= integrity sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==
isexe@^2.0.0: isexe@^2.0.0:
version "2.0.0" version "2.0.0"
@ -1719,11 +1719,16 @@ minimist@^0.2.0:
resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.2.1.tgz#827ba4e7593464e7c221e8c5bed930904ee2c455" resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.2.1.tgz#827ba4e7593464e7c221e8c5bed930904ee2c455"
integrity sha512-GY8fANSrTMfBVfInqJAY41QkOM+upUTytK1jZ0c8+3HdHrJxBJ3rF5i9moClXTE8uUSnUo8cAsCoxDXvSY4DHg== integrity sha512-GY8fANSrTMfBVfInqJAY41QkOM+upUTytK1jZ0c8+3HdHrJxBJ3rF5i9moClXTE8uUSnUo8cAsCoxDXvSY4DHg==
minimist@^1.1.3, minimist@^1.2.0, minimist@^1.2.3, minimist@^1.2.5: minimist@^1.1.3, minimist@^1.2.5:
version "1.2.5" version "1.2.5"
resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602"
integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==
minimist@^1.2.0, minimist@^1.2.3:
version "1.2.8"
resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.8.tgz#c1a464e7693302e082a075cee0c057741ac4772c"
integrity sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==
mkdirp-classic@^0.5.2, mkdirp-classic@^0.5.3: mkdirp-classic@^0.5.2, mkdirp-classic@^0.5.3:
version "0.5.3" version "0.5.3"
resolved "https://registry.yarnpkg.com/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz#fa10c9115cc6d8865be221ba47ee9bed78601113" resolved "https://registry.yarnpkg.com/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz#fa10c9115cc6d8865be221ba47ee9bed78601113"
@ -1734,11 +1739,16 @@ ms@2.1.2:
resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009"
integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==
nan@^2.12.1, nan@^2.14.0, nan@^2.14.2: nan@^2.12.1:
version "2.15.0" version "2.15.0"
resolved "https://registry.yarnpkg.com/nan/-/nan-2.15.0.tgz#3f34a473ff18e15c1b5626b62903b5ad6e665fee" resolved "https://registry.yarnpkg.com/nan/-/nan-2.15.0.tgz#3f34a473ff18e15c1b5626b62903b5ad6e665fee"
integrity sha512-8ZtvEnA2c5aYCZYd1cvgdnU6cqwixRoYg70xPLWUws5ORTa/lnw+u4amixRS/Ac5U5mQVgp9pnlSUnbNWFaWZQ== integrity sha512-8ZtvEnA2c5aYCZYd1cvgdnU6cqwixRoYg70xPLWUws5ORTa/lnw+u4amixRS/Ac5U5mQVgp9pnlSUnbNWFaWZQ==
nan@^2.14.0, nan@^2.17.0:
version "2.17.0"
resolved "https://registry.yarnpkg.com/nan/-/nan-2.17.0.tgz#c0150a2368a182f033e9aa5195ec76ea41a199cb"
integrity sha512-2ZTgtl0nJsO0KQCjEpxcIr5D+Yv90plTitZt9JBfQvVJDS5seMl3FOvsh3+9CoYWXf/1l5OaZzzF6nDm4cagaQ==
napi-build-utils@^1.0.1: napi-build-utils@^1.0.1:
version "1.0.2" version "1.0.2"
resolved "https://registry.yarnpkg.com/napi-build-utils/-/napi-build-utils-1.0.2.tgz#b1fddc0b2c46e380a0b7a76f984dd47c41a13806" resolved "https://registry.yarnpkg.com/napi-build-utils/-/napi-build-utils-1.0.2.tgz#b1fddc0b2c46e380a0b7a76f984dd47c41a13806"
@ -1749,7 +1759,7 @@ natural-compare@^1.4.0:
resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7"
integrity sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc= integrity sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=
node-abi@^2.7.0: node-abi@^2.21.0:
version "2.30.1" version "2.30.1"
resolved "https://registry.yarnpkg.com/node-abi/-/node-abi-2.30.1.tgz#c437d4b1fe0e285aaf290d45b45d4d7afedac4cf" resolved "https://registry.yarnpkg.com/node-abi/-/node-abi-2.30.1.tgz#c437d4b1fe0e285aaf290d45b45d4d7afedac4cf"
integrity sha512-/2D0wOQPgaUWzVSVgRMx+trKJRC2UG4SUc4oCJoXx9Uxjtp0Vy3/kt7zcbxHF8+Z/pK3UloLWzBISg72brfy1w== integrity sha512-/2D0wOQPgaUWzVSVgRMx+trKJRC2UG4SUc4oCJoXx9Uxjtp0Vy3/kt7zcbxHF8+Z/pK3UloLWzBISg72brfy1w==
@ -1761,11 +1771,6 @@ node-releases@^1.1.75:
resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-1.1.75.tgz#6dd8c876b9897a1b8e5a02de26afa79bb54ebbfe" resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-1.1.75.tgz#6dd8c876b9897a1b8e5a02de26afa79bb54ebbfe"
integrity sha512-Qe5OUajvqrqDSy6wrWFmMwfJ0jVgwiw4T3KqmbTcZ62qW0gQkheXYhcFM1+lOVcGUoRxcEcfyvFMAnDgaF1VWw== integrity sha512-Qe5OUajvqrqDSy6wrWFmMwfJ0jVgwiw4T3KqmbTcZ62qW0gQkheXYhcFM1+lOVcGUoRxcEcfyvFMAnDgaF1VWw==
noop-logger@^0.1.1:
version "0.1.1"
resolved "https://registry.yarnpkg.com/noop-logger/-/noop-logger-0.1.1.tgz#94a2b1633c4f1317553007d8966fd0e841b6a4c2"
integrity sha1-lKKxYzxPExdVMAfYlm/Q6EG2pMI=
normalize-package-data@^2.3.2, normalize-package-data@^2.3.4: normalize-package-data@^2.3.2, normalize-package-data@^2.3.4:
version "2.5.0" version "2.5.0"
resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz#e66db1838b200c1dfc233225d12cb36520e234a8" resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz#e66db1838b200c1dfc233225d12cb36520e234a8"
@ -1789,7 +1794,7 @@ npmlog@^4.0.1:
number-is-nan@^1.0.0: number-is-nan@^1.0.0:
version "1.0.1" version "1.0.1"
resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d" resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d"
integrity sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0= integrity sha512-4jbtZXNAsfZbAHiiqjLPBiCl16dES1zI4Hpzzxw61Tk+loF+sBDBKx1ICKKKwIqQ7M0mFn1TmkN7euSncWgHiQ==
object-assign@^4.0.1, object-assign@^4.1.0: object-assign@^4.0.1, object-assign@^4.1.0:
version "4.1.1" version "4.1.1"
@ -1915,10 +1920,10 @@ plur@^1.0.0:
resolved "https://registry.yarnpkg.com/plur/-/plur-1.0.0.tgz#db85c6814f5e5e5a3b49efc28d604fec62975156" resolved "https://registry.yarnpkg.com/plur/-/plur-1.0.0.tgz#db85c6814f5e5e5a3b49efc28d604fec62975156"
integrity sha1-24XGgU9eXlo7Se/CjWBP7GKXUVY= integrity sha1-24XGgU9eXlo7Se/CjWBP7GKXUVY=
prebuild-install@^5.0.0: prebuild-install@^6.0.1:
version "5.3.6" version "6.1.4"
resolved "https://registry.yarnpkg.com/prebuild-install/-/prebuild-install-5.3.6.tgz#7c225568d864c71d89d07f8796042733a3f54291" resolved "https://registry.yarnpkg.com/prebuild-install/-/prebuild-install-6.1.4.tgz#ae3c0142ad611d58570b89af4986088a4937e00f"
integrity sha512-s8Aai8++QQGi4sSbs/M1Qku62PFK49Jm1CbgXklGz4nmHveDq0wzJkg7Na5QbnO1uNH8K7iqx2EQ/mV0MZEmOg== integrity sha512-Z4vpywnK1lBg+zdPCVCsKq0xO66eEV9rWo2zrROGGiRS4JtueBOdlB1FnY8lcy7JsUud/Q3ijUxyWN26Ika0vQ==
dependencies: dependencies:
detect-libc "^1.0.3" detect-libc "^1.0.3"
expand-template "^2.0.3" expand-template "^2.0.3"
@ -1926,15 +1931,13 @@ prebuild-install@^5.0.0:
minimist "^1.2.3" minimist "^1.2.3"
mkdirp-classic "^0.5.3" mkdirp-classic "^0.5.3"
napi-build-utils "^1.0.1" napi-build-utils "^1.0.1"
node-abi "^2.7.0" node-abi "^2.21.0"
noop-logger "^0.1.1"
npmlog "^4.0.1" npmlog "^4.0.1"
pump "^3.0.0" pump "^3.0.0"
rc "^1.2.7" rc "^1.2.7"
simple-get "^3.0.3" simple-get "^3.0.3"
tar-fs "^2.0.0" tar-fs "^2.0.0"
tunnel-agent "^0.6.0" tunnel-agent "^0.6.0"
which-pm-runs "^1.0.0"
prelude-ls@^1.2.1: prelude-ls@^1.2.1:
version "1.2.1" version "1.2.1"
@ -2013,9 +2016,9 @@ read-pkg@^1.0.0:
string_decoder "~0.10.x" string_decoder "~0.10.x"
readable-stream@^2.0.6: readable-stream@^2.0.6:
version "2.3.7" version "2.3.8"
resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz#1eca1cf711aef814c04f62252a36a62f6cb23b57" resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.8.tgz#91125e8042bba1b9887f49345f6277027ce8be9b"
integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== integrity sha512-8p0AUk4XODgIewSi0l8Epjs+EVnWiK7NoDIEGU0HhE7+ZyY8D1IMY7odu5lRrFXGg71L15KG8QrPmum45RTtdA==
dependencies: dependencies:
core-util-is "~1.0.0" core-util-is "~1.0.0"
inherits "~2.0.3" inherits "~2.0.3"
@ -2026,9 +2029,9 @@ readable-stream@^2.0.6:
util-deprecate "~1.0.1" util-deprecate "~1.0.1"
readable-stream@^3.1.1, readable-stream@^3.4.0: readable-stream@^3.1.1, readable-stream@^3.4.0:
version "3.6.0" version "3.6.2"
resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.0.tgz#337bbda3adc0706bd3e024426a286d4b4b2c9198" resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-3.6.2.tgz#56a9b36ea965c00c5a93ef31eb111a0f11056967"
integrity sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA== integrity sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==
dependencies: dependencies:
inherits "^2.0.3" inherits "^2.0.3"
string_decoder "^1.1.1" string_decoder "^1.1.1"
@ -2131,7 +2134,7 @@ semver@^6.3.0:
set-blocking@~2.0.0: set-blocking@~2.0.0:
version "2.0.0" version "2.0.0"
resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7"
integrity sha1-BF+XgtARrppoA93TgrJDkrPYkPc= integrity sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==
shebang-command@^2.0.0: shebang-command@^2.0.0:
version "2.0.0" version "2.0.0"
@ -2155,9 +2158,9 @@ side-channel@^1.0.3, side-channel@^1.0.4:
object-inspect "^1.9.0" object-inspect "^1.9.0"
signal-exit@^3.0.0: signal-exit@^3.0.0:
version "3.0.3" version "3.0.7"
resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.3.tgz#a1410c2edd8f077b08b4e253c8eacfcaf057461c" resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.7.tgz#a9a1767f8af84155114eaabd73f99273c8f59ad9"
integrity sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA== integrity sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==
simple-concat@^1.0.0: simple-concat@^1.0.0:
version "1.0.1" version "1.0.1"
@ -2165,9 +2168,9 @@ simple-concat@^1.0.0:
integrity sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q== integrity sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q==
simple-get@^3.0.3: simple-get@^3.0.3:
version "3.1.0" version "3.1.1"
resolved "https://registry.yarnpkg.com/simple-get/-/simple-get-3.1.0.tgz#b45be062435e50d159540b576202ceec40b9c6b3" resolved "https://registry.yarnpkg.com/simple-get/-/simple-get-3.1.1.tgz#cc7ba77cfbe761036fbfce3d021af25fc5584d55"
integrity sha512-bCR6cP+aTdScaQCnQKbPKtJOKDp/hj9EDLJo3Nw4y1QksqaovlW/bnptB6/c1e+qmNIDHRK+oXFDdEqBT8WzUA== integrity sha512-CQ5LTKGfCpvE1K0n2us+kuMPbk/q0EKl82s4aheV9oXjFEz6W/Y7oQFVJuU6QG77hRT4Ghb5RURteF5vnWjupA==
dependencies: dependencies:
decompress-response "^4.2.0" decompress-response "^4.2.0"
once "^1.3.1" once "^1.3.1"
@ -2217,19 +2220,20 @@ sprintf-js@~1.0.2:
string-width@^1.0.1: string-width@^1.0.1:
version "1.0.2" version "1.0.2"
resolved "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz#118bdf5b8cdc51a2a7e70d211e07e2b0b9b107d3" resolved "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz#118bdf5b8cdc51a2a7e70d211e07e2b0b9b107d3"
integrity sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M= integrity sha512-0XsVpQLnVCXHJfyEs8tC0zpTVIr5PKKsQtkT29IwupnPTjtPmQ3xT/4yCREF9hYkV/3M3kzcUTSAZT6a6h81tw==
dependencies: dependencies:
code-point-at "^1.0.0" code-point-at "^1.0.0"
is-fullwidth-code-point "^1.0.0" is-fullwidth-code-point "^1.0.0"
strip-ansi "^3.0.0" strip-ansi "^3.0.0"
"string-width@^1.0.2 || 2": "string-width@^1.0.2 || 2 || 3 || 4":
version "2.1.1" version "4.2.3"
resolved "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz#ab93f27a8dc13d28cac815c462143a6d9012ae9e" resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010"
integrity sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw== integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==
dependencies: dependencies:
is-fullwidth-code-point "^2.0.0" emoji-regex "^8.0.0"
strip-ansi "^4.0.0" is-fullwidth-code-point "^3.0.0"
strip-ansi "^6.0.1"
string.prototype.trim@^1.2.5: string.prototype.trim@^1.2.5:
version "1.2.5" version "1.2.5"
@ -2278,17 +2282,10 @@ string_decoder@~1.1.1:
strip-ansi@^3.0.0, strip-ansi@^3.0.1: strip-ansi@^3.0.0, strip-ansi@^3.0.1:
version "3.0.1" version "3.0.1"
resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf"
integrity sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8= integrity sha512-VhumSSbBqDTP8p2ZLKj40UjBCV4+v8bUSEpUb4KjRgWk9pbqGF4REFj6KEagidb2f/M6AzC0EmFyDNGaw9OCzg==
dependencies: dependencies:
ansi-regex "^2.0.0" ansi-regex "^2.0.0"
strip-ansi@^4.0.0:
version "4.0.0"
resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-4.0.0.tgz#a8479022eb1ac368a871389b635262c505ee368f"
integrity sha1-qEeQIusaw2iocTibY1JixQXuNo8=
dependencies:
ansi-regex "^3.0.0"
strip-ansi@^6.0.1: strip-ansi@^6.0.1:
version "6.0.1" version "6.0.1"
resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9"
@ -2318,7 +2315,7 @@ strip-json-comments@^3.1.0, strip-json-comments@^3.1.1:
strip-json-comments@~2.0.1: strip-json-comments@~2.0.1:
version "2.0.1" version "2.0.1"
resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a"
integrity sha1-PFMZQukIwml8DsNEhYwobHygpgo= integrity sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ==
supports-color@^5.3.0: supports-color@^5.3.0:
version "5.5.0" version "5.5.0"
@ -2454,20 +2451,20 @@ tree-sitter-javascript@^0.19.0:
dependencies: dependencies:
nan "^2.12.1" nan "^2.12.1"
tree-sitter-nix@cstrahan/tree-sitter-nix: tree-sitter-nix@^0.0.2:
version "0.0.2" version "0.0.2"
resolved "https://codeload.github.com/cstrahan/tree-sitter-nix/tar.gz/83ee5993560bf15854c69b77d92e34456f8fb655" resolved "https://registry.yarnpkg.com/tree-sitter-nix/-/tree-sitter-nix-0.0.2.tgz#f40176270961a1d969a6d36e43a08526e2bde94f"
integrity sha512-rPYc7NUi6hPOyFSoVdCVC9feqBk0kJ0Z3ftTWXo1ubyyKzPM5tJP6mD6xYl0gN45oh9GHGzvTbOmmwIk0XOj5A==
dependencies: dependencies:
nan "^2.14.2" nan "^2.17.0"
tree-sitter "^0.19.0"
tree-sitter@^0.19.0: tree-sitter@^0.20.2:
version "0.19.0" version "0.20.2"
resolved "https://registry.yarnpkg.com/tree-sitter/-/tree-sitter-0.19.0.tgz#68c4cfa12b34752d69162b81ad233f3e6fc4a70d" resolved "https://registry.yarnpkg.com/tree-sitter/-/tree-sitter-0.20.2.tgz#d5227966635d5e27dabd6744b28618d5c43cea77"
integrity sha512-jw/BNCCRB9RCq/GFGU0VuhchGlIIlYRQFnjXgPKG3fBIo+c3ImuPITtAHJJ4XgTBNfeAQmt8XC4wShgBw8tgdg== integrity sha512-xyaEOl3zgsYWfZ9LfByPZBFfllsOoccm0Y2DY564iYuzmjg4vWd9nd0hcjh5qhq4uIG5LvSACTHcB5RPu9iuxQ==
dependencies: dependencies:
nan "^2.14.0" nan "^2.14.0"
prebuild-install "^5.0.0" prebuild-install "^6.0.1"
trim-newlines@^1.0.0: trim-newlines@^1.0.0:
version "1.0.0" version "1.0.0"
@ -2477,7 +2474,7 @@ trim-newlines@^1.0.0:
tunnel-agent@^0.6.0: tunnel-agent@^0.6.0:
version "0.6.0" version "0.6.0"
resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd" resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd"
integrity sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0= integrity sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w==
dependencies: dependencies:
safe-buffer "^5.0.1" safe-buffer "^5.0.1"
@ -2513,7 +2510,7 @@ uri-js@^4.2.2:
util-deprecate@^1.0.1, util-deprecate@~1.0.1: util-deprecate@^1.0.1, util-deprecate@~1.0.1:
version "1.0.2" version "1.0.2"
resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf"
integrity sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8= integrity sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==
v8-compile-cache@^2.0.3: v8-compile-cache@^2.0.3:
version "2.3.0" version "2.3.0"
@ -2549,11 +2546,6 @@ which-collection@^1.0.1:
is-weakmap "^2.0.1" is-weakmap "^2.0.1"
is-weakset "^2.0.1" is-weakset "^2.0.1"
which-pm-runs@^1.0.0:
version "1.0.0"
resolved "https://registry.yarnpkg.com/which-pm-runs/-/which-pm-runs-1.0.0.tgz#670b3afbc552e0b55df6b7780ca74615f23ad1cb"
integrity sha1-Zws6+8VS4LVd9rd4DKdGFfI60cs=
which-typed-array@^1.1.2: which-typed-array@^1.1.2:
version "1.1.7" version "1.1.7"
resolved "https://registry.yarnpkg.com/which-typed-array/-/which-typed-array-1.1.7.tgz#2761799b9a22d4b8660b3c1b40abaa7739691793" resolved "https://registry.yarnpkg.com/which-typed-array/-/which-typed-array-1.1.7.tgz#2761799b9a22d4b8660b3c1b40abaa7739691793"
@ -2574,11 +2566,11 @@ which@^2.0.1:
isexe "^2.0.0" isexe "^2.0.0"
wide-align@^1.1.0: wide-align@^1.1.0:
version "1.1.3" version "1.1.5"
resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.3.tgz#ae074e6bdc0c14a431e804e624549c633b000457" resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.5.tgz#df1d4c206854369ecf3c9a4898f1b23fbd9d15d3"
integrity sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA== integrity sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg==
dependencies: dependencies:
string-width "^1.0.2 || 2" string-width "^1.0.2 || 2 || 3 || 4"
word-wrap@^1.2.3: word-wrap@^1.2.3:
version "1.2.3" version "1.2.3"
@ -2588,7 +2580,7 @@ word-wrap@^1.2.3:
wrappy@1: wrappy@1:
version "1.0.2" version "1.0.2"
resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f"
integrity sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8= integrity sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==
"xtend@>=4.0.0 <4.1.0-0": "xtend@>=4.0.0 <4.1.0-0":
version "4.0.2" version "4.0.2"