// eval part var evaluate = function(x, env) { if (Array.isArray(x)) { if (x[0] === 'if') { // if というキーワードだった場合 return String(evaluate(x[1], env)) !== 'false' ? evaluate(x[2], env) : evaluate(x[3], env); } else { // if ではない場合、今までどおりの処理を行う var exps = x.map(function(exp) {return evaluate(exp, env);}); var proc = exps.shift(); return proc.apply(null, exps); } } else { var y = env[x]; return y !== undefined ? y : x; } }; // library var globalEnv = { '+': function(a, b) {return a + b;}, '-': function(a, b) {return a - b;}, '*': function(a, b) {return a * b;}, '/': function(a, b) {return a / b;}, 'mod': function(a, b) {return a % b;}, 'not': function(x) {return !x;}, '=': function(a, b) {return a === b;}, '>': function(a, b) {return a > b;}, '<': function(a, b) {return a < b;}, '<=': function(a, b) {return a <= b;}, '>=': function(a, b) {return a >= b;}, 'alert': function(a) {alert(a);} }; // usage d3.select('#out').text( evaluate(['if', ['<', 5, 6], 1, 2], globalEnv) );
Result: <span id='out' />