diff options
author | Samy Pessé <samypesse@gmail.com> | 2014-08-10 14:44:06 -0700 |
---|---|---|
committer | Samy Pessé <samypesse@gmail.com> | 2014-08-11 07:36:52 -0700 |
commit | 6c62d75eae4001793dd10702efca7d0b30e3eb39 (patch) | |
tree | 7617f56217485dbf4cc5e71c54992069e67470cc /theme/javascript/utils/execute.js | |
parent | bcfcf3d9792b6e6e3e27e250e6d2d64232e67f5a (diff) | |
download | gitbook-6c62d75eae4001793dd10702efca7d0b30e3eb39.zip gitbook-6c62d75eae4001793dd10702efca7d0b30e3eb39.tar.gz gitbook-6c62d75eae4001793dd10702efca7d0b30e3eb39.tar.bz2 |
Remove exercises execution
Diffstat (limited to 'theme/javascript/utils/execute.js')
-rwxr-xr-x | theme/javascript/utils/execute.js | 97 |
1 files changed, 0 insertions, 97 deletions
diff --git a/theme/javascript/utils/execute.js b/theme/javascript/utils/execute.js deleted file mode 100755 index eb2a19b..0000000 --- a/theme/javascript/utils/execute.js +++ /dev/null @@ -1,97 +0,0 @@ -define([ - "execute/javascript" -], function(javascript) { - var LANGUAGES = { - "javascript": javascript - }; - - - var evalJS = function(lang, code, callback) { - var ready = false; - var finished = false; - - var finish = function() { - if(finished) { - return console.error('Already finished'); - } - finished = true; - return callback.apply(null, arguments); - }; - - var repl; - - // Handles all our events - var eventHandler = function(data, eventType) { - console.log([eventType, data]); - switch(eventType) { - case 'progress': - // Update UI loading bar - break; - case 'timeout': - finish(new Error(data)); - break; - case 'result': - finish(null, { - value: data, - type: 'result' - }); - break; - case 'error': - if(ready) { - return finish(null, { - value: data, - type: 'error' - }); - } - return finish(new Error(data)); - break - case 'ready': - // We're good to get results and stuff back now - ready = true; - // Eval our code now that the runtime is ready - repl.eval(code); - break; - default: - console.log('Unhandled event =', eventType, 'data =', data); - } - }; - - repl = new lang.REPL({ - input: eventHandler, - output: eventHandler, - result: eventHandler, - error: eventHandler, - progress: eventHandler, - timeout: { - time: 30000, - callback: eventHandler - } - }); - - repl.loadLanguage(lang.id, eventHandler); - }; - - var execute = function(lang, solution, validation, context, callback) { - // Language data - var langd = LANGUAGES[lang]; - - // Check language is supported - if (!langd) return callback(new Error("Language '"+lang+"' not available for execution")); - - // Validate with validation code - var code = [ - context, - solution, - langd.assertCode, - validation, - ].join(langd.sep); - evalJS(langd, code, function(err, res) { - if(err) return callback(err); - - if (res.type == "error") callback(new Error(res.value)); - else callback(null, res.value); - }); - }; - - return execute; -}); |