diff --git a/runtime/scripts/jme-variables.js b/runtime/scripts/jme-variables.js index 69b9bcac5..e2abd7dd3 100644 --- a/runtime/scripts/jme-variables.js +++ b/runtime/scripts/jme-variables.js @@ -49,7 +49,9 @@ jme.variables = /** @lends Numbas.jme.variables */ { */ makeJMEFunction: function(fn,scope) { fn.tree = jme.compile(fn.definition,scope,true); - var external_vars = jme.findvars(fn.tree,fn.paramNames.map(function(v) { return jme.normaliseName(v,scope) }),scope); + const nscope = new jme.Scope([scope]); + nscope.addFunction(fn); + var external_vars = jme.findvars(fn.tree,fn.paramNames.map(function(v) { return jme.normaliseName(v,scope) }),nscope); jme.findvarsOps[fn.name] = function(tree,boundvars,scope) { var vars = external_vars.slice(); for(var i=0;i a(x)')),['x'],'findvars on lambda where an argument is another lambda'); deepCloseEqual(assert, Numbas.jme.findvars(Numbas.jme.compile('[x,[y,z]] -> x+y+z+w')),['w'],'findvars on lambda with destructuring'); deepCloseEqual(assert, Numbas.jme.findvars(Numbas.jme.compile('undefined_function(x)')),['x', 'undefined_function'],'Undefined function names are presumed to be missing variables.'); + + const fn = Numbas.jme.variables.makeFunction({ + parameters: [{type:'number', name:'x'}], + definition: 'if(x>0,0,f(x-1))', + name: 'f', + language: 'jme' + }, Numbas.jme.builtinScope); + + const scope = new Numbas.jme.Scope([Numbas.jme.builtinScope]); + scope.addFunction(fn); + const vars = Numbas.jme.findvars(Numbas.jme.compile('f(2)'), scope); + assert.deepEqual(vars, [], "Recursive custom functions don't produce their own names in findvars"); }); QUnit.test('findvars in HTML',function(assert) { diff --git a/tests/numbas-runtime.js b/tests/numbas-runtime.js index 1ccde1af0..a815af157 100644 --- a/tests/numbas-runtime.js +++ b/tests/numbas-runtime.js @@ -19307,7 +19307,9 @@ jme.variables = /** @lends Numbas.jme.variables */ { */ makeJMEFunction: function(fn,scope) { fn.tree = jme.compile(fn.definition,scope,true); - var external_vars = jme.findvars(fn.tree,fn.paramNames.map(function(v) { return jme.normaliseName(v,scope) }),scope); + const nscope = new jme.Scope([scope]); + nscope.addFunction(fn); + var external_vars = jme.findvars(fn.tree,fn.paramNames.map(function(v) { return jme.normaliseName(v,scope) }),nscope); jme.findvarsOps[fn.name] = function(tree,boundvars,scope) { var vars = external_vars.slice(); for(var i=0;i