var PAUSE = plt.runtime.PAUSE; var makeClosure = plt.baselib.functions.makeClosure; var makeRational = plt.baselib.numbers.makeRational; var makePrimitiveProcedure = plt.baselib.functions.makePrimitiveProcedure; var checkNonNegativeReal = plt.baselib.check.checkNonNegativeReal; var checkString = plt.baselib.check.checkString; var checkProcedure = plt.baselib.check.checkProcedure; // More specific function checkers, based on arity. var checkProcedure1 = plt.baselib.check.makeCheckArgumentType( function(x) { return (plt.baselib.functions.isProcedure(x) && plt.baselib.arity.isArityMatching(x.arity, 1)); }, 'procedure that consumes a world argument'); var checkProcedureWithKey = plt.baselib.check.makeCheckArgumentType( function(x) { return (plt.baselib.functions.isProcedure(x) && plt.baselib.arity.isArityMatching(x.arity, 2)); }, 'procedure that consumes a world argument and a key'); var checkHandler = plt.baselib.check.makeCheckArgumentType( isWorldConfigOption, "world configuration handler"); // The default tick delay is 28 times a second. var DEFAULT_TICK_DELAY = 1/28; EXPORTS['big-bang'] = makeClosure( 'big-bang', plt.baselib.arity.makeArityAtLeast(1), function(MACHINE) { var initialWorldValue = MACHINE.env[MACHINE.env.length - 1]; var handlers = []; for (var i = 1; i < MACHINE.argcount; i++) { handlers.push(checkHandler(MACHINE, 'big-bang', i)); } bigBang(MACHINE, initialWorldValue, handlers); }); EXPORTS['on-tick'] = makePrimitiveProcedure( 'on-tick', plt.baselib.lists.makeList(1, 2), function(MACHINE) { if (MACHINE.argcount === 1) { var f = checkProcedure1(MACHINE, "on-tick", 0); return new OnTick(f, Math.floor(DEFAULT_TICK_DELAY * 1000)); } else if (MACHINE.argcount === 2) { var f = checkProcedure1(MACHINE, "on-tick", 0); var delay = checkNonNegativeReal(MACHINE, "on-tick", 1); return new OnTick(f, Math.floor(jsnums.toFixnum(delay) * 1000)); } }); EXPORTS['to-draw'] = makePrimitiveProcedure( 'to-draw', 1, function(MACHINE) { var f = checkProcedure1(MACHINE, "on-tick", 0); return new ToDraw(f); }); EXPORTS['stop-when'] = makePrimitiveProcedure( 'stop-when', 1, function(MACHINE) { var f = checkProcedure1(MACHINE, "on-tick", 0); return new StopWhen(f); }); EXPORTS['on-key'] = makePrimitiveProcedure( 'on-key', 1, function(MACHINE) { var f = checkProcedureWithKey(MACHINE, "on-key", 0); return new OnKey(f); }); EXPORTS['key=?'] = makePrimitiveProcedure( 'on-key', 2, function(MACHINE) { var k1 = checkString(MACHINE, "key=?", 0); var k2 = checkString(MACHINE, "key=?", 1); return k1.toString().toLowerCase() === k2.toString().toLowerCase(); }); // EXPORTS['on-tick'] = // new CasePrimitive( // 'on-tick', // [new PrimProc('on-tick', // 1, // false, false, // function(f) { // check(f, isFunction, "on-tick", "procedure", 1); // return new OnTickBang(f, // new PrimProc('', 1, false, false, // function(w) { return types.effectDoNothing(); }), // DEFAULT_TICK_DELAY); // }), // new PrimProc('on-tick', // 2, // false, false, // function(f, aDelay) { // check(f, isFunction, "on-tick", "procedure", 1, arguments); // check(aDelay, isNumber, "on-tick", "number", 2, arguments); // return new OnTickBang(f, // new PrimProc('', 1, false, false, // function(w) { return types.effectDoNothing(); }), // aDelay); // }) ]); // EXPORTS['on-tick!'] = // new CasePrimitive('on-tick!', // [new PrimProc('on-tick!', // 2, // false, false, // function(handler, effectHandler) { // check(handler, isFunction, "on-tick!", "procedure", 1, arguments); // check(effectHandler, isFunction, "on-tick!","procedure", 2, arguments); // return new OnTickBang(handler, effectHandler, DEFAULT_TICK_DELAY); // }), // new PrimProc('on-tick!', // 3, // false, false, // function(handler, effectHandler, aDelay) { // check(handler, isFunction, "on-tick!", "procedure", 1, arguments); // check(effectHandler, isFunction, "on-tick!","procedure", 2, arguments); // check(aDelay, isNumber, "on-tick!", "number", 3, arguments); // return new OnTickBang(handler, effectHandler, aDelay); // }) ]);