runInContext -> evalModule

This commit is contained in:
Futago-za Ryuu 2018-09-25 19:15:16 +01:00
parent 616749377b
commit 14b8b76a79
5 changed files with 14 additions and 16 deletions

View file

@ -67,8 +67,8 @@ const compiler = {
trace: false
} );
// We want `session.vm.runInContext` to return the parser
if ( options.output === "parser" ) options.format = "bare";
// We want `session.vm.evalModule` to return the parser
if ( options.output === "parser" ) options.format = "umd";
util.each( session.passes, stage => {
@ -83,7 +83,7 @@ const compiler = {
switch ( options.output ) {
case "parser":
return session.vm.runInContext( ast.code, options.context );
return session.vm.evalModule( ast.code, options.context );
case "source":
return ast.code;

View file

@ -7,6 +7,7 @@ const GrammarError = require( "../grammar-error" );
const opcodes = require( "./opcodes" );
const parser = require( "../parser" );
const util = require( "../util" );
const vm = require( "../util/vm" );
function fatal( message, location ) {
@ -28,9 +29,7 @@ class Session {
this.parser = config.parser || parser;
this.passes = config.passes || {};
this.visitor = config.visitor || ast.visitor;
this.vm = config.vm || {
runInContext: util.runInContext
};
this.vm = config.vm || vm;
if ( typeof config.warn === "function" ) this.warn = config.warn;
if ( typeof config.error === "function" ) this.error = config.error;

View file

@ -1,26 +1,25 @@
"use strict";
/**
* `eval` the given source, using properties found in `context` as top-level variables.
* `eval` the given source as a CommonJS module, using properties found in `context` as top-level variables.
*
* Based on `vm.runInContext` found in Node.js, this is a cross-env solution.
*/
function runInContext( source, context ) {
function evalModule( source, context ) {
const argumentKeys = Object.keys( context );
const argumentValues = argumentKeys.map( argument => context[ argument ] );
const object = {};
argumentKeys.push( "_peg$object", `_peg$object.result = ${ source };` );
argumentValues.push( object );
const sandbox = { exports: {} };
argumentKeys.push( "module", "exports", source );
argumentValues.push( sandbox, sandbox.exports );
Function( ...argumentKeys )( ...argumentValues );
return object.result;
return sandbox.exports;
}
// Exports
module.exports = { runInContext };
module.exports = { evalModule };

View file

@ -435,7 +435,7 @@ declare namespace peg {
interface ISessionVM {
runInContext( code: string, context?: { [ name: string ]: any; } ): any;
evalModule( code: string, context?: { [ name: string ]: any; } ): any;
}

View file

@ -131,7 +131,7 @@ describe( "plugin API", function () {
function pass( ast ) {
ast.code = "({ parse: function() { return 42; } })";
ast.code = "exports.parse = function() { return 42; }";
}