shift-reducer
Advanced tools
Comparing version 1.0.1 to 1.0.2
280
lib/index.js
"use strict"; | ||
var _extends = function (child, parent) { | ||
child.prototype = Object.create(parent.prototype, { | ||
constructor: { | ||
value: child, | ||
enumerable: false, | ||
writable: true, | ||
configurable: true | ||
} | ||
}); | ||
child.__proto__ = parent; | ||
}; | ||
var Shift = require("shift-ast"); | ||
var MonoidalReducer = require("./monoidal-reducer")["default"]; | ||
exports.MonoidalReducer = MonoidalReducer; | ||
@@ -131,267 +121,3 @@ | ||
} | ||
exports["default"] = reduce; | ||
var Reducer = function Reducer() {}; | ||
exports.Reducer = Reducer; | ||
var MonoidalReducer = (function (Reducer) { | ||
var MonoidalReducer = function MonoidalReducer(monoid) { | ||
var empty = monoid.empty(); | ||
this.identity = function () { | ||
return empty; | ||
}; | ||
var concat = monoid.prototype && monoid.prototype.concat || monoid.concat; | ||
this.append = this.append2 = function (a, b) { | ||
return concat.call(a, b); | ||
}; | ||
}; | ||
_extends(MonoidalReducer, Reducer); | ||
MonoidalReducer.prototype.fromNull = function (a) { | ||
return a == null ? this.identity() : a; | ||
}; | ||
MonoidalReducer.prototype.append3 = function (a, b, c) { | ||
return this.append(this.append(a, b), c); | ||
}; | ||
MonoidalReducer.prototype.append4 = function (a, b, c, d) { | ||
return this.append(this.append3(a, b, c), d); | ||
}; | ||
MonoidalReducer.prototype.fold = function (as, a) { | ||
var _this = this; | ||
return as.reduce(function (memo, x) { | ||
return _this.append(memo, x); | ||
}, a == null ? this.identity() : a); | ||
}; | ||
MonoidalReducer.prototype.reduceArrayExpression = function (node, elements) { | ||
return this.fold(elements.filter(function (x) { | ||
return x != null; | ||
})); | ||
}; | ||
MonoidalReducer.prototype.reduceAssignmentExpression = function (node, binding, expression) { | ||
return this.append(binding, expression); | ||
}; | ||
MonoidalReducer.prototype.reduceBinaryExpression = function (node, left, right) { | ||
return this.append(left, right); | ||
}; | ||
MonoidalReducer.prototype.reduceBlock = function (node, statements) { | ||
return this.fold(statements); | ||
}; | ||
MonoidalReducer.prototype.reduceBlockStatement = function (node, block) { | ||
return block; | ||
}; | ||
MonoidalReducer.prototype.reduceBreakStatement = function (node, label) { | ||
return this.fromNull(label); | ||
}; | ||
MonoidalReducer.prototype.reduceCallExpression = function (node, callee, args) { | ||
return this.fold(args, callee); | ||
}; | ||
MonoidalReducer.prototype.reduceCatchClause = function (node, binding, body) { | ||
return this.append(binding, body); | ||
}; | ||
MonoidalReducer.prototype.reduceComputedMemberExpression = function (node, object, expression) { | ||
return this.append(object, expression); | ||
}; | ||
MonoidalReducer.prototype.reduceConditionalExpression = function (node, test, consequent, alternate) { | ||
return this.append3(test, consequent, alternate); | ||
}; | ||
MonoidalReducer.prototype.reduceContinueStatement = function (node, label) { | ||
return this.fromNull(label); | ||
}; | ||
MonoidalReducer.prototype.reduceDataProperty = function (node, name, expression) { | ||
return this.append(name, expression); | ||
}; | ||
MonoidalReducer.prototype.reduceDebuggerStatement = function (node) { | ||
return this.identity(); | ||
}; | ||
MonoidalReducer.prototype.reduceDoWhileStatement = function (node, body, test) { | ||
return this.append(body, test); | ||
}; | ||
MonoidalReducer.prototype.reduceEmptyStatement = function (node) { | ||
return this.identity(); | ||
}; | ||
MonoidalReducer.prototype.reduceExpressionStatement = function (node, expression) { | ||
return expression; | ||
}; | ||
MonoidalReducer.prototype.reduceForInStatement = function (node, left, right, body) { | ||
return this.append3(left, right, body); | ||
}; | ||
MonoidalReducer.prototype.reduceForStatement = function (node, init, test, update, body) { | ||
return this.append4(this.fromNull(init), this.fromNull(test), this.fromNull(update), body); | ||
}; | ||
MonoidalReducer.prototype.reduceFunctionBody = function (node, directives, statements) { | ||
return this.append(this.fold(directives), this.fold(statements)); | ||
}; | ||
MonoidalReducer.prototype.reduceFunctionDeclaration = function (node, name, parameters, body) { | ||
return this.append(this.fold(parameters, name), body); | ||
}; | ||
MonoidalReducer.prototype.reduceFunctionExpression = function (node, name, parameters, body) { | ||
return this.append(this.fold(parameters, this.fromNull(name)), body); | ||
}; | ||
MonoidalReducer.prototype.reduceGetter = function (node, name, body) { | ||
return this.append(name, body); | ||
}; | ||
MonoidalReducer.prototype.reduceIdentifier = function (node) { | ||
return this.identity(); | ||
}; | ||
MonoidalReducer.prototype.reduceIdentifierExpression = function (node, name) { | ||
return name; | ||
}; | ||
MonoidalReducer.prototype.reduceIfStatement = function (node, test, consequent, alternate) { | ||
return this.append3(test, consequent, this.fromNull(alternate)); | ||
}; | ||
MonoidalReducer.prototype.reduceLabeledStatement = function (node, label, body) { | ||
return this.append(label, body); | ||
}; | ||
MonoidalReducer.prototype.reduceLiteralBooleanExpression = function (node) { | ||
return this.identity(); | ||
}; | ||
MonoidalReducer.prototype.reduceLiteralNullExpression = function (node) { | ||
return this.identity(); | ||
}; | ||
MonoidalReducer.prototype.reduceLiteralNumericExpression = function (node) { | ||
return this.identity(); | ||
}; | ||
MonoidalReducer.prototype.reduceLiteralRegExpExpression = function (node) { | ||
return this.identity(); | ||
}; | ||
MonoidalReducer.prototype.reduceLiteralStringExpression = function (node) { | ||
return this.identity(); | ||
}; | ||
MonoidalReducer.prototype.reduceNewExpression = function (node, callee, args) { | ||
return this.fold(args, callee); | ||
}; | ||
MonoidalReducer.prototype.reduceObjectExpression = function (node, properties) { | ||
return this.fold(properties); | ||
}; | ||
MonoidalReducer.prototype.reducePostfixExpression = function (node, operand) { | ||
return operand; | ||
}; | ||
MonoidalReducer.prototype.reducePrefixExpression = function (node, operand) { | ||
return operand; | ||
}; | ||
MonoidalReducer.prototype.reducePropertyName = function (node) { | ||
return this.identity(); | ||
}; | ||
MonoidalReducer.prototype.reduceReturnStatement = function (node, expression) { | ||
return this.fromNull(expression); | ||
}; | ||
MonoidalReducer.prototype.reduceScript = function (node, body) { | ||
return body; | ||
}; | ||
MonoidalReducer.prototype.reduceSetter = function (node, name, parameter, body) { | ||
return this.append3(name, parameter, body); | ||
}; | ||
MonoidalReducer.prototype.reduceStaticMemberExpression = function (node, object, property) { | ||
return this.append(object, property); | ||
}; | ||
MonoidalReducer.prototype.reduceSwitchCase = function (node, test, consequent) { | ||
return this.fold(consequent, test); | ||
}; | ||
MonoidalReducer.prototype.reduceSwitchDefault = function (node, consequent) { | ||
return this.fold(consequent); | ||
}; | ||
MonoidalReducer.prototype.reduceSwitchStatement = function (node, discriminant, cases) { | ||
return this.fold(cases, discriminant); | ||
}; | ||
MonoidalReducer.prototype.reduceSwitchStatementWithDefault = function (node, discriminant, preDefaultCases, defaultCase, postDefaultCases) { | ||
return this.append4(discriminant, this.fold(preDefaultCases), defaultCase, this.fold(postDefaultCases)); | ||
}; | ||
MonoidalReducer.prototype.reduceThisExpression = function (node) { | ||
return this.identity(); | ||
}; | ||
MonoidalReducer.prototype.reduceThrowStatement = function (node, expression) { | ||
return this.fromNull(expression); | ||
}; | ||
MonoidalReducer.prototype.reduceTryCatchStatement = function (node, block, catchClause) { | ||
return this.append(block, catchClause); | ||
}; | ||
MonoidalReducer.prototype.reduceTryFinallyStatement = function (node, block, catchClause, finalizer) { | ||
return this.append3(block, this.fromNull(catchClause), finalizer); | ||
}; | ||
MonoidalReducer.prototype.reduceUnknownDirective = function (node) { | ||
return this.identity(); | ||
}; | ||
MonoidalReducer.prototype.reduceUseStrictDirective = function (node) { | ||
return this.identity(); | ||
}; | ||
MonoidalReducer.prototype.reduceVariableDeclaration = function (node, declarators) { | ||
return this.fold(declarators); | ||
}; | ||
MonoidalReducer.prototype.reduceVariableDeclarationStatement = function (node, declaration) { | ||
return declaration; | ||
}; | ||
MonoidalReducer.prototype.reduceVariableDeclarator = function (node, binding, init) { | ||
return this.append(binding, this.fromNull(init)); | ||
}; | ||
MonoidalReducer.prototype.reduceWhileStatement = function (node, test, body) { | ||
return this.append(test, body); | ||
}; | ||
MonoidalReducer.prototype.reduceWithStatement = function (node, object, body) { | ||
return this.append(object, body); | ||
}; | ||
return MonoidalReducer; | ||
})(Reducer); | ||
exports.MonoidalReducer = MonoidalReducer; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/index.js"],"names":[],"mappings":"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","file":"src/index.js","sourcesContent":["/**\n * Copyright 2014 Shape Security, Inc.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\")\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport * as Shift from \"shift-ast\"\n\n\nfunction recurse(branch) {\n  return function(reducer, node) {\n    let branchNode = node[branch];\n    return DRIVER[branchNode.type](reducer, branchNode);\n  };\n}\n\nfunction recurseMaybe(branch) {\n  return function(reducer, node) {\n    let branchNode = node[branch];\n    if (branchNode == null) return null;\n    return DRIVER[branchNode.type](reducer, branchNode);\n  };\n}\n\nfunction recurseList(branch) {\n  return function(reducer, node) {\n    return [].map.call(node[branch], (n) => DRIVER[n.type](reducer, n));\n  };\n}\n\nfunction recurseListMaybe(branch) {\n  return function(reducer, node) {\n    return [].map.call(node[branch], (n) => {\n      if (n == null) return null;\n      return DRIVER[n.type](reducer, n);\n    });\n  };\n}\n\nconst REDUCER_SPEC = {\n  ArrayExpression: [recurseListMaybe('elements')],\n  AssignmentExpression: [recurse('binding'), recurse('expression')],\n  BinaryExpression: [recurse('left'), recurse('right')],\n  Block: [recurseList('statements')],\n  BlockStatement: [recurse('block')],\n  BreakStatement: [recurseMaybe('label')],\n  CallExpression: [recurse('callee'), recurseList('arguments')],\n  CatchClause: [recurse('binding'), recurse('body')],\n  ComputedMemberExpression: [recurse('object'), recurse('expression')],\n  ConditionalExpression: [recurse('test'), recurse('consequent'), recurse('alternate')],\n  ContinueStatement: [recurseMaybe('label')],\n  DataProperty: [recurse('name'), recurse('expression')],\n  DebuggerStatement: [],\n  DoWhileStatement: [recurse('body'), recurse('test')],\n  EmptyStatement: [],\n  ExpressionStatement: [recurse('expression')],\n  ForInStatement: [recurse('left'), recurse('right'), recurse('body')],\n  ForStatement: [recurseMaybe('init'), recurseMaybe('test'), recurseMaybe('update'), recurse('body')],\n  FunctionBody: [recurseList('directives'), recurseList('statements')],\n  FunctionDeclaration: [recurse('name'), recurseList('parameters'), recurse('body')],\n  FunctionExpression: [recurseMaybe('name'), recurseList('parameters'), recurse('body')],\n  Getter: [recurse('name'), recurse('body')],\n  Identifier: [],\n  IdentifierExpression: [recurse('identifier')],\n  IfStatement: [recurse('test'), recurse('consequent'), recurseMaybe('alternate')],\n  LabeledStatement: [recurse('label'), recurse('body')],\n  LiteralBooleanExpression: [],\n  LiteralNullExpression: [],\n  LiteralNumericExpression: [],\n  LiteralRegExpExpression: [],\n  LiteralStringExpression: [],\n  NewExpression: [recurse('callee'), recurseList('arguments')],\n  ObjectExpression: [recurseList('properties')],\n  PostfixExpression: [recurse('operand')],\n  PrefixExpression: [recurse('operand')],\n  PropertyName: [],\n  ReturnStatement: [recurseMaybe('expression')],\n  Script: [recurse('body')],\n  Setter: [recurse('name'), recurse('parameter'), recurse('body')],\n  StaticMemberExpression: [recurse('object'), recurse('property')],\n  SwitchCase: [recurse('test'), recurseList('consequent')],\n  SwitchDefault: [recurseList('consequent')],\n  SwitchStatement: [recurse('discriminant'), recurseList('cases')],\n  SwitchStatementWithDefault: [recurse('discriminant'), recurseList('preDefaultCases'), recurse('defaultCase'), recurseList('postDefaultCases')],\n  ThisExpression: [],\n  ThrowStatement: [recurse('expression')],\n  TryCatchStatement: [recurse('body'), recurse('catchClause')],\n  TryFinallyStatement: [recurse('body'), recurseMaybe('catchClause'), recurse('finalizer')],\n  UnknownDirective: [],\n  UseStrictDirective: [],\n  VariableDeclaration: [recurseList('declarators')],\n  VariableDeclarationStatement: [recurse('declaration')],\n  VariableDeclarator: [recurse('binding'), recurseMaybe('init')],\n  WhileStatement: [recurse('test'), recurse('body')],\n  WithStatement: [recurse('object'), recurse('body')],\n};\n\nconst DRIVER = (function(){\n  var o = Object.create(null);\n  for(let T in REDUCER_SPEC) {\n    if(!{}.hasOwnProperty.call(REDUCER_SPEC, T)) continue;\n    let reducingFunctionName = 'reduce' + T;\n    o[T] = function(reducer, node) {\n      return reducer[reducingFunctionName].apply(reducer, [node].concat(\n        REDUCER_SPEC[T].map((f) => f(reducer, node))\n      ));\n    };\n  }\n  return o;\n}());\n\n\nexport default function reduce(reducer, reducible) {\n  return DRIVER[reducible.type](reducer, reducible);\n}\n\n\nexport class Reducer { }\n\nexport class MonoidalReducer extends Reducer {\n  constructor(monoid) {\n    let empty = monoid.empty();\n    this.identity = () => empty;\n    let concat = monoid.prototype && monoid.prototype.concat || monoid.concat;\n    this.append = this.append2 = (a, b) => concat.call(a, b);\n  }\n\n  fromNull(a) {\n    return a == null ? this.identity() : a;\n  }\n  append3(a, b, c) {\n    return this.append(this.append(a, b), c);\n  }\n  append4(a, b, c, d) {\n    return this.append(this.append3(a, b, c), d);\n  }\n  fold(as, a) {\n    return as.reduce((memo, x) => this.append(memo, x), a == null ? this.identity() : a);\n  }\n\n  reduceArrayExpression(node, elements) {\n    return this.fold(elements.filter((x) => x != null));\n  }\n  reduceAssignmentExpression(node, binding, expression) {\n    return this.append(binding, expression);\n  }\n  reduceBinaryExpression(node, left, right) {\n    return this.append(left, right);\n  }\n  reduceBlock(node, statements) {\n    return this.fold(statements);\n  }\n  reduceBlockStatement(node, block) {\n    return block;\n  }\n  reduceBreakStatement(node, label) {\n    return this.fromNull(label);\n  }\n  reduceCallExpression(node, callee, args) {\n    return this.fold(args, callee);\n  }\n  reduceCatchClause(node, binding, body) {\n    return this.append(binding, body);\n  }\n  reduceComputedMemberExpression(node, object, expression) {\n    return this.append(object, expression);\n  }\n  reduceConditionalExpression(node, test, consequent, alternate) {\n    return this.append3(test, consequent, alternate);\n  }\n  reduceContinueStatement(node, label) {\n    return this.fromNull(label);\n  }\n  reduceDataProperty(node, name, expression) {\n    return this.append(name, expression);\n  }\n  reduceDebuggerStatement(node) {\n    return this.identity();\n  }\n  reduceDoWhileStatement(node, body, test) {\n    return this.append(body, test);\n  }\n  reduceEmptyStatement(node) {\n    return this.identity();\n  }\n  reduceExpressionStatement(node, expression) {\n    return expression;\n  }\n  reduceForInStatement(node, left, right, body) {\n    return this.append3(left, right, body);\n  }\n  reduceForStatement(node, init, test, update, body) {\n    return this.append4(this.fromNull(init), this.fromNull(test), this.fromNull(update), body);\n  }\n  reduceFunctionBody(node, directives, statements) {\n    return this.append(this.fold(directives), this.fold(statements));\n  }\n  reduceFunctionDeclaration(node, name, parameters, body) {\n    return this.append(this.fold(parameters, name), body);\n  }\n  reduceFunctionExpression(node, name, parameters, body) {\n    return this.append(this.fold(parameters, this.fromNull(name)), body);\n  }\n  reduceGetter(node, name, body) {\n    return this.append(name, body);\n  }\n  reduceIdentifier(node) {\n    return this.identity();\n  }\n  reduceIdentifierExpression(node, name) {\n    return name;\n  }\n  reduceIfStatement(node, test, consequent, alternate) {\n    return this.append3(test, consequent, this.fromNull(alternate));\n  }\n  reduceLabeledStatement(node, label, body) {\n    return this.append(label, body);\n  }\n  reduceLiteralBooleanExpression(node) {\n    return this.identity();\n  }\n  reduceLiteralNullExpression(node) {\n    return this.identity();\n  }\n  reduceLiteralNumericExpression(node) {\n    return this.identity();\n  }\n  reduceLiteralRegExpExpression(node) {\n    return this.identity();\n  }\n  reduceLiteralStringExpression(node) {\n    return this.identity();\n  }\n  reduceNewExpression(node, callee, args) {\n    return this.fold(args, callee);\n  }\n  reduceObjectExpression(node, properties) {\n    return this.fold(properties);\n  }\n  reducePostfixExpression(node, operand) {\n    return operand;\n  }\n  reducePrefixExpression(node, operand) {\n    return operand;\n  }\n  reducePropertyName(node) {\n    return this.identity();\n  }\n  reduceReturnStatement(node, expression) {\n    return this.fromNull(expression);\n  }\n  reduceScript(node, body) {\n    return body;\n  }\n  reduceSetter(node, name, parameter, body) {\n    return this.append3(name, parameter, body);\n  }\n  reduceStaticMemberExpression(node, object, property) {\n    return this.append(object, property);\n  }\n  reduceSwitchCase(node, test, consequent) {\n    return this.fold(consequent, test);\n  }\n  reduceSwitchDefault(node, consequent) {\n    return this.fold(consequent);\n  }\n  reduceSwitchStatement(node, discriminant, cases) {\n    return this.fold(cases, discriminant);\n  }\n  reduceSwitchStatementWithDefault(node, discriminant, preDefaultCases, defaultCase, postDefaultCases) {\n    return this.append4(discriminant, this.fold(preDefaultCases), defaultCase, this.fold(postDefaultCases));\n  }\n  reduceThisExpression(node) {\n    return this.identity();\n  }\n  reduceThrowStatement(node, expression) {\n    return this.fromNull(expression);\n  }\n  reduceTryCatchStatement(node, block, catchClause) {\n    return this.append(block, catchClause);\n  }\n  reduceTryFinallyStatement(node, block, catchClause, finalizer) {\n    return this.append3(block, this.fromNull(catchClause), finalizer);\n  }\n  reduceUnknownDirective(node) {\n    return this.identity();\n  }\n  reduceUseStrictDirective(node) {\n    return this.identity();\n  }\n  reduceVariableDeclaration(node, declarators) {\n    return this.fold(declarators);\n  }\n  reduceVariableDeclarationStatement(node, declaration) {\n    return declaration;\n  }\n  reduceVariableDeclarator(node, binding, init) {\n    return this.append(binding, this.fromNull(init));\n  }\n  reduceWhileStatement(node, test, body) {\n    return this.append(test, body);\n  }\n  reduceWithStatement(node, object, body) {\n    return this.append(object, body);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/index.js"],"names":[],"mappings":";;IAgBY,KAAK;;IACV,eAAe;QACd,eAAe,GAAf,eAAe;;;;AAGvB,SAAS,OAAO,CAAC,MAAM,EAAE;AACvB,SAAO,UAAS,OAAO,EAAE,IAAI,EAAE;AAC7B,QAAI,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;AAC9B,WAAO,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;GACrD,CAAC;CACH;;AAED,SAAS,YAAY,CAAC,MAAM,EAAE;AAC5B,SAAO,UAAS,OAAO,EAAE,IAAI,EAAE;AAC7B,QAAI,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;AAC9B,QAAI,UAAU,IAAI,IAAI,EAAE,OAAO,IAAI,CAAC;AACpC,WAAO,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;GACrD,CAAC;CACH;;AAED,SAAS,WAAW,CAAC,MAAM,EAAE;AAC3B,SAAO,UAAS,OAAO,EAAE,IAAI,EAAE;AAC7B,WAAO,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,UAAC,CAAC;aAAK,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;KAAA,CAAC,CAAC;GACrE,CAAC;CACH;;AAED,SAAS,gBAAgB,CAAC,MAAM,EAAE;AAChC,SAAO,UAAS,OAAO,EAAE,IAAI,EAAE;AAC7B,WAAO,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,UAAC,CAAC,EAAK;AACtC,UAAI,CAAC,IAAI,IAAI,EAAE,OAAO,IAAI,CAAC;AAC3B,aAAO,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;KACnC,CAAC,CAAC;GACJ,CAAC;CACH;;AAED,IAAM,YAAY,GAAG;AACnB,iBAAe,EAAE,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC;AAC/C,sBAAoB,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC;AACjE,kBAAgB,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;AACrD,OAAK,EAAE,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;AAClC,gBAAc,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;AAClC,gBAAc,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;AACvC,gBAAc,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC;AAC7D,aAAW,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;AAClD,0BAAwB,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC;AACpE,uBAAqB,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;AACrF,mBAAiB,EAAE,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;AAC1C,cAAY,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC;AACtD,mBAAiB,EAAE,EAAE;AACrB,kBAAgB,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;AACpD,gBAAc,EAAE,EAAE;AAClB,qBAAmB,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;AAC5C,gBAAc,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;AACpE,cAAY,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,YAAY,CAAC,MAAM,CAAC,EAAE,YAAY,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;AACnG,cAAY,EAAE,CAAC,WAAW,CAAC,YAAY,CAAC,EAAE,WAAW,CAAC,YAAY,CAAC,CAAC;AACpE,qBAAmB,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,WAAW,CAAC,YAAY,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;AAClF,oBAAkB,EAAE,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,WAAW,CAAC,YAAY,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;AACtF,QAAM,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;AAC1C,YAAU,EAAE,EAAE;AACd,sBAAoB,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;AAC7C,aAAW,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,YAAY,CAAC,EAAE,YAAY,CAAC,WAAW,CAAC,CAAC;AAChF,kBAAgB,EAAE,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;AACrD,0BAAwB,EAAE,EAAE;AAC5B,uBAAqB,EAAE,EAAE;AACzB,0BAAwB,EAAE,EAAE;AAC5B,yBAAuB,EAAE,EAAE;AAC3B,yBAAuB,EAAE,EAAE;AAC3B,eAAa,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC;AAC5D,kBAAgB,EAAE,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;AAC7C,mBAAiB,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;AACvC,kBAAgB,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;AACtC,cAAY,EAAE,EAAE;AAChB,iBAAe,EAAE,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;AAC7C,QAAM,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;AACzB,QAAM,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;AAChE,wBAAsB,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC;AAChE,YAAU,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,WAAW,CAAC,YAAY,CAAC,CAAC;AACxD,eAAa,EAAE,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;AAC1C,iBAAe,EAAE,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,WAAW,CAAC,OAAO,CAAC,CAAC;AAChE,4BAA0B,EAAE,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,WAAW,CAAC,iBAAiB,CAAC,EAAE,OAAO,CAAC,aAAa,CAAC,EAAE,WAAW,CAAC,kBAAkB,CAAC,CAAC;AAC9I,gBAAc,EAAE,EAAE;AAClB,gBAAc,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;AACvC,mBAAiB,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC;AAC5D,qBAAmB,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,YAAY,CAAC,aAAa,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;AACzF,kBAAgB,EAAE,EAAE;AACpB,oBAAkB,EAAE,EAAE;AACtB,qBAAmB,EAAE,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;AACjD,8BAA4B,EAAE,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;AACtD,oBAAkB,EAAE,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,YAAY,CAAC,MAAM,CAAC,CAAC;AAC9D,gBAAc,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;AAClD,eAAa,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,EACpD,CAAC;;AAEF,IAAM,MAAM,GAAG,CAAC,YAAU;AACxB,MAAI,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;SAC5B,KAAI,IAAI,CAAC,IAAI,YAAY,EAAE;0BAKR,CAAC;AAJlB,UAAG,CAAC,EAAE,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,EAAE,kBAAS;AACtD,UAAI,oBAAoB,GAAG,QAAQ,GAAG,CAAC,CAAC;AACxC,OAAC,CAAC,CAAC,CAAC,GAAG,UAAS,OAAO,EAAE,IAAI,EAAE;AAC7B,eAAO,OAAO,CAAC,oBAAoB,CAAC,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,CAC/D,YAAY,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,UAAC,CAAC;iBAAK,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC;SAAA,CAAC,CAC7C,CAAC,CAAC;OACJ,CAAC;OAFe,CAAC;;;GAGnB;AACD,SAAO,CAAC,CAAC;CACV,EAAE,CAAC,CAAC;;;AAGU,SAAS,MAAM,CAAC,OAAO,EAAE,SAAS,EAAE;AACjD,SAAO,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;CACnD;qBAFuB,MAAM","file":"src/index.js","sourcesContent":["/**\n * Copyright 2014 Shape Security, Inc.\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\")\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\nimport * as Shift from \"shift-ast\"\nimport MonoidalReducer from \"./monoidal-reducer\"\nexport {MonoidalReducer};\n\n\nfunction recurse(branch) {\n  return function(reducer, node) {\n    let branchNode = node[branch];\n    return DRIVER[branchNode.type](reducer, branchNode);\n  };\n}\n\nfunction recurseMaybe(branch) {\n  return function(reducer, node) {\n    let branchNode = node[branch];\n    if (branchNode == null) return null;\n    return DRIVER[branchNode.type](reducer, branchNode);\n  };\n}\n\nfunction recurseList(branch) {\n  return function(reducer, node) {\n    return [].map.call(node[branch], (n) => DRIVER[n.type](reducer, n));\n  };\n}\n\nfunction recurseListMaybe(branch) {\n  return function(reducer, node) {\n    return [].map.call(node[branch], (n) => {\n      if (n == null) return null;\n      return DRIVER[n.type](reducer, n);\n    });\n  };\n}\n\nconst REDUCER_SPEC = {\n  ArrayExpression: [recurseListMaybe('elements')],\n  AssignmentExpression: [recurse('binding'), recurse('expression')],\n  BinaryExpression: [recurse('left'), recurse('right')],\n  Block: [recurseList('statements')],\n  BlockStatement: [recurse('block')],\n  BreakStatement: [recurseMaybe('label')],\n  CallExpression: [recurse('callee'), recurseList('arguments')],\n  CatchClause: [recurse('binding'), recurse('body')],\n  ComputedMemberExpression: [recurse('object'), recurse('expression')],\n  ConditionalExpression: [recurse('test'), recurse('consequent'), recurse('alternate')],\n  ContinueStatement: [recurseMaybe('label')],\n  DataProperty: [recurse('name'), recurse('expression')],\n  DebuggerStatement: [],\n  DoWhileStatement: [recurse('body'), recurse('test')],\n  EmptyStatement: [],\n  ExpressionStatement: [recurse('expression')],\n  ForInStatement: [recurse('left'), recurse('right'), recurse('body')],\n  ForStatement: [recurseMaybe('init'), recurseMaybe('test'), recurseMaybe('update'), recurse('body')],\n  FunctionBody: [recurseList('directives'), recurseList('statements')],\n  FunctionDeclaration: [recurse('name'), recurseList('parameters'), recurse('body')],\n  FunctionExpression: [recurseMaybe('name'), recurseList('parameters'), recurse('body')],\n  Getter: [recurse('name'), recurse('body')],\n  Identifier: [],\n  IdentifierExpression: [recurse('identifier')],\n  IfStatement: [recurse('test'), recurse('consequent'), recurseMaybe('alternate')],\n  LabeledStatement: [recurse('label'), recurse('body')],\n  LiteralBooleanExpression: [],\n  LiteralNullExpression: [],\n  LiteralNumericExpression: [],\n  LiteralRegExpExpression: [],\n  LiteralStringExpression: [],\n  NewExpression: [recurse('callee'), recurseList('arguments')],\n  ObjectExpression: [recurseList('properties')],\n  PostfixExpression: [recurse('operand')],\n  PrefixExpression: [recurse('operand')],\n  PropertyName: [],\n  ReturnStatement: [recurseMaybe('expression')],\n  Script: [recurse('body')],\n  Setter: [recurse('name'), recurse('parameter'), recurse('body')],\n  StaticMemberExpression: [recurse('object'), recurse('property')],\n  SwitchCase: [recurse('test'), recurseList('consequent')],\n  SwitchDefault: [recurseList('consequent')],\n  SwitchStatement: [recurse('discriminant'), recurseList('cases')],\n  SwitchStatementWithDefault: [recurse('discriminant'), recurseList('preDefaultCases'), recurse('defaultCase'), recurseList('postDefaultCases')],\n  ThisExpression: [],\n  ThrowStatement: [recurse('expression')],\n  TryCatchStatement: [recurse('body'), recurse('catchClause')],\n  TryFinallyStatement: [recurse('body'), recurseMaybe('catchClause'), recurse('finalizer')],\n  UnknownDirective: [],\n  UseStrictDirective: [],\n  VariableDeclaration: [recurseList('declarators')],\n  VariableDeclarationStatement: [recurse('declaration')],\n  VariableDeclarator: [recurse('binding'), recurseMaybe('init')],\n  WhileStatement: [recurse('test'), recurse('body')],\n  WithStatement: [recurse('object'), recurse('body')],\n};\n\nconst DRIVER = (function(){\n  var o = Object.create(null);\n  for(let T in REDUCER_SPEC) {\n    if(!{}.hasOwnProperty.call(REDUCER_SPEC, T)) continue;\n    let reducingFunctionName = 'reduce' + T;\n    o[T] = function(reducer, node) {\n      return reducer[reducingFunctionName].apply(reducer, [node].concat(\n        REDUCER_SPEC[T].map((f) => f(reducer, node))\n      ));\n    };\n  }\n  return o;\n}());\n\n\nexport default function reduce(reducer, reducible) {\n  return DRIVER[reducible.type](reducer, reducible);\n}\n"]} |
{ | ||
"name": "shift-reducer", | ||
"version": "1.0.1", | ||
"version": "1.0.2", | ||
"description": "reducer for the Shift AST format", | ||
@@ -5,0 +5,0 @@ "author": "Shape Security Labs", |
@@ -74,2 +74,10 @@ Shift Reducer | ||
### Fantasy Land | ||
![Fantasy Land logo](https://github.com/fantasyland/fantasy-land/raw/master/logo.png "Fantasy Land") | ||
The `MonoidalReducer` is compatible with [Fantasy Land](https://github.com/fantasyland/fantasy-land) Monoids. | ||
## Contributing | ||
@@ -76,0 +84,0 @@ |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
60295
5
109
302
1