diff --git a/.gitignore b/.gitignore index 0793ff9..1d53c08 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1,4 @@ -/platforms/android/CordovaLib/ant-build/ +/www/js/draftboys.js +/platforms/android/assets/www/ /platforms/android/ant-build/ +/platforms/android/CordovaLib/ant-build/ diff --git a/config.xml b/config.xml index 0f135e0..62143f2 100644 --- a/config.xml +++ b/config.xml @@ -1,5 +1,5 @@ - DRAFTBOYS diff --git a/draftboys.org b/draftboys.org index 807bb30..ddbd289 100644 --- a/draftboys.org +++ b/draftboys.org @@ -73,7 +73,7 @@ will help me practice Cordova, Nim, literate programming, and App Engine. #+NAME: config.xml #+BEGIN_SRC xml - DRAFTBOYS diff --git a/platforms/android/AndroidManifest.xml b/platforms/android/AndroidManifest.xml index 05e1d83..0f7bad8 100644 --- a/platforms/android/AndroidManifest.xml +++ b/platforms/android/AndroidManifest.xml @@ -1,5 +1,5 @@ - + diff --git a/platforms/android/assets/www/cordova.js b/platforms/android/assets/www/cordova.js deleted file mode 100644 index ec9f771..0000000 --- a/platforms/android/assets/www/cordova.js +++ /dev/null @@ -1,1980 +0,0 @@ -// Platform: android -// 24ab6855470f2dc0662624b597c98585e56a1666 -/* - Licensed to the Apache Software Foundation (ASF) under one - or more contributor license agreements. See the NOTICE file - distributed with this work for additional information - regarding copyright ownership. The ASF licenses this file - to you under the Apache License, Version 2.0 (the - "License"); you may not use this file except in compliance - with the License. You may obtain a copy of the License at - - http://www.apache.org/licenses/LICENSE-2.0 - - Unless required by applicable law or agreed to in writing, - software distributed under the License is distributed on an - "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY - KIND, either express or implied. See the License for the - specific language governing permissions and limitations - under the License. -*/ -;(function() { -var PLATFORM_VERSION_BUILD_LABEL = '3.7.1'; -// file: src/scripts/require.js - -/*jshint -W079 */ -/*jshint -W020 */ - -var require, - define; - -(function () { - var modules = {}, - // Stack of moduleIds currently being built. - requireStack = [], - // Map of module ID -> index into requireStack of modules currently being built. - inProgressModules = {}, - SEPARATOR = "."; - - - - function build(module) { - var factory = module.factory, - localRequire = function (id) { - var resultantId = id; - //Its a relative path, so lop off the last portion and add the id (minus "./") - if (id.charAt(0) === ".") { - resultantId = module.id.slice(0, module.id.lastIndexOf(SEPARATOR)) + SEPARATOR + id.slice(2); - } - return require(resultantId); - }; - module.exports = {}; - delete module.factory; - factory(localRequire, module.exports, module); - return module.exports; - } - - require = function (id) { - if (!modules[id]) { - throw "module " + id + " not found"; - } else if (id in inProgressModules) { - var cycle = requireStack.slice(inProgressModules[id]).join('->') + '->' + id; - throw "Cycle in require graph: " + cycle; - } - if (modules[id].factory) { - try { - inProgressModules[id] = requireStack.length; - requireStack.push(id); - return build(modules[id]); - } finally { - delete inProgressModules[id]; - requireStack.pop(); - } - } - return modules[id].exports; - }; - - define = function (id, factory) { - if (modules[id]) { - throw "module " + id + " already defined"; - } - - modules[id] = { - id: id, - factory: factory - }; - }; - - define.remove = function (id) { - delete modules[id]; - }; - - define.moduleMap = modules; -})(); - -//Export for use in node -if (typeof module === "object" && typeof require === "function") { - module.exports.require = require; - module.exports.define = define; -} - -// file: src/cordova.js -define("cordova", function(require, exports, module) { - - -var channel = require('cordova/channel'); -var platform = require('cordova/platform'); - -/** - * Intercept calls to addEventListener + removeEventListener and handle deviceready, - * resume, and pause events. - */ -var m_document_addEventListener = document.addEventListener; -var m_document_removeEventListener = document.removeEventListener; -var m_window_addEventListener = window.addEventListener; -var m_window_removeEventListener = window.removeEventListener; - -/** - * Houses custom event handlers to intercept on document + window event listeners. - */ -var documentEventHandlers = {}, - windowEventHandlers = {}; - -document.addEventListener = function(evt, handler, capture) { - var e = evt.toLowerCase(); - if (typeof documentEventHandlers[e] != 'undefined') { - documentEventHandlers[e].subscribe(handler); - } else { - m_document_addEventListener.call(document, evt, handler, capture); - } -}; - -window.addEventListener = function(evt, handler, capture) { - var e = evt.toLowerCase(); - if (typeof windowEventHandlers[e] != 'undefined') { - windowEventHandlers[e].subscribe(handler); - } else { - m_window_addEventListener.call(window, evt, handler, capture); - } -}; - -document.removeEventListener = function(evt, handler, capture) { - var e = evt.toLowerCase(); - // If unsubscribing from an event that is handled by a plugin - if (typeof documentEventHandlers[e] != "undefined") { - documentEventHandlers[e].unsubscribe(handler); - } else { - m_document_removeEventListener.call(document, evt, handler, capture); - } -}; - -window.removeEventListener = function(evt, handler, capture) { - var e = evt.toLowerCase(); - // If unsubscribing from an event that is handled by a plugin - if (typeof windowEventHandlers[e] != "undefined") { - windowEventHandlers[e].unsubscribe(handler); - } else { - m_window_removeEventListener.call(window, evt, handler, capture); - } -}; - -function createEvent(type, data) { - var event = document.createEvent('Events'); - event.initEvent(type, false, false); - if (data) { - for (var i in data) { - if (data.hasOwnProperty(i)) { - event[i] = data[i]; - } - } - } - return event; -} - - -var cordova = { - define:define, - require:require, - version:PLATFORM_VERSION_BUILD_LABEL, - platformVersion:PLATFORM_VERSION_BUILD_LABEL, - platformId:platform.id, - /** - * Methods to add/remove your own addEventListener hijacking on document + window. - */ - addWindowEventHandler:function(event) { - return (windowEventHandlers[event] = channel.create(event)); - }, - addStickyDocumentEventHandler:function(event) { - return (documentEventHandlers[event] = channel.createSticky(event)); - }, - addDocumentEventHandler:function(event) { - return (documentEventHandlers[event] = channel.create(event)); - }, - removeWindowEventHandler:function(event) { - delete windowEventHandlers[event]; - }, - removeDocumentEventHandler:function(event) { - delete documentEventHandlers[event]; - }, - /** - * Retrieve original event handlers that were replaced by Cordova - * - * @return object - */ - getOriginalHandlers: function() { - return {'document': {'addEventListener': m_document_addEventListener, 'removeEventListener': m_document_removeEventListener}, - 'window': {'addEventListener': m_window_addEventListener, 'removeEventListener': m_window_removeEventListener}}; - }, - /** - * Method to fire event from native code - * bNoDetach is required for events which cause an exception which needs to be caught in native code - */ - fireDocumentEvent: function(type, data, bNoDetach) { - var evt = createEvent(type, data); - if (typeof documentEventHandlers[type] != 'undefined') { - if( bNoDetach ) { - documentEventHandlers[type].fire(evt); - } - else { - setTimeout(function() { - // Fire deviceready on listeners that were registered before cordova.js was loaded. - if (type == 'deviceready') { - document.dispatchEvent(evt); - } - documentEventHandlers[type].fire(evt); - }, 0); - } - } else { - document.dispatchEvent(evt); - } - }, - fireWindowEvent: function(type, data) { - var evt = createEvent(type,data); - if (typeof windowEventHandlers[type] != 'undefined') { - setTimeout(function() { - windowEventHandlers[type].fire(evt); - }, 0); - } else { - window.dispatchEvent(evt); - } - }, - - /** - * Plugin callback mechanism. - */ - // Randomize the starting callbackId to avoid collisions after refreshing or navigating. - // This way, it's very unlikely that any new callback would get the same callbackId as an old callback. - callbackId: Math.floor(Math.random() * 2000000000), - callbacks: {}, - callbackStatus: { - NO_RESULT: 0, - OK: 1, - CLASS_NOT_FOUND_EXCEPTION: 2, - ILLEGAL_ACCESS_EXCEPTION: 3, - INSTANTIATION_EXCEPTION: 4, - MALFORMED_URL_EXCEPTION: 5, - IO_EXCEPTION: 6, - INVALID_ACTION: 7, - JSON_EXCEPTION: 8, - ERROR: 9 - }, - - /** - * Called by native code when returning successful result from an action. - */ - callbackSuccess: function(callbackId, args) { - cordova.callbackFromNative(callbackId, true, args.status, [args.message], args.keepCallback); - }, - - /** - * Called by native code when returning error result from an action. - */ - callbackError: function(callbackId, args) { - // TODO: Deprecate callbackSuccess and callbackError in favour of callbackFromNative. - // Derive success from status. - cordova.callbackFromNative(callbackId, false, args.status, [args.message], args.keepCallback); - }, - - /** - * Called by native code when returning the result from an action. - */ - callbackFromNative: function(callbackId, isSuccess, status, args, keepCallback) { - try { - var callback = cordova.callbacks[callbackId]; - if (callback) { - if (isSuccess && status == cordova.callbackStatus.OK) { - callback.success && callback.success.apply(null, args); - } else if (!isSuccess) { - callback.fail && callback.fail.apply(null, args); - } - /* - else - Note, this case is intentionally not caught. - this can happen if isSuccess is true, but callbackStatus is NO_RESULT - which is used to remove a callback from the list without calling the callbacks - typically keepCallback is false in this case - */ - // Clear callback if not expecting any more results - if (!keepCallback) { - delete cordova.callbacks[callbackId]; - } - } - } - catch (err) { - var msg = "Error in " + (isSuccess ? "Success" : "Error") + " callbackId: " + callbackId + " : " + err; - console && console.log && console.log(msg); - cordova.fireWindowEvent("cordovacallbackerror", { 'message': msg }); - throw err; - } - }, - addConstructor: function(func) { - channel.onCordovaReady.subscribe(function() { - try { - func(); - } catch(e) { - console.log("Failed to run constructor: " + e); - } - }); - } -}; - - -module.exports = cordova; - -}); - -// file: src/android/android/nativeapiprovider.js -define("cordova/android/nativeapiprovider", function(require, exports, module) { - -/** - * Exports the ExposedJsApi.java object if available, otherwise exports the PromptBasedNativeApi. - */ - -var nativeApi = this._cordovaNative || require('cordova/android/promptbasednativeapi'); -var currentApi = nativeApi; - -module.exports = { - get: function() { return currentApi; }, - setPreferPrompt: function(value) { - currentApi = value ? require('cordova/android/promptbasednativeapi') : nativeApi; - }, - // Used only by tests. - set: function(value) { - currentApi = value; - } -}; - -}); - -// file: src/android/android/promptbasednativeapi.js -define("cordova/android/promptbasednativeapi", function(require, exports, module) { - -/** - * Implements the API of ExposedJsApi.java, but uses prompt() to communicate. - * This is used pre-JellyBean, where addJavascriptInterface() is disabled. - */ - -module.exports = { - exec: function(bridgeSecret, service, action, callbackId, argsJson) { - return prompt(argsJson, 'gap:'+JSON.stringify([bridgeSecret, service, action, callbackId])); - }, - setNativeToJsBridgeMode: function(bridgeSecret, value) { - prompt(value, 'gap_bridge_mode:' + bridgeSecret); - }, - retrieveJsMessages: function(bridgeSecret, fromOnlineEvent) { - return prompt(+fromOnlineEvent, 'gap_poll:' + bridgeSecret); - } -}; - -}); - -// file: src/common/argscheck.js -define("cordova/argscheck", function(require, exports, module) { - -var exec = require('cordova/exec'); -var utils = require('cordova/utils'); - -var moduleExports = module.exports; - -var typeMap = { - 'A': 'Array', - 'D': 'Date', - 'N': 'Number', - 'S': 'String', - 'F': 'Function', - 'O': 'Object' -}; - -function extractParamName(callee, argIndex) { - return (/.*?\((.*?)\)/).exec(callee)[1].split(', ')[argIndex]; -} - -function checkArgs(spec, functionName, args, opt_callee) { - if (!moduleExports.enableChecks) { - return; - } - var errMsg = null; - var typeName; - for (var i = 0; i < spec.length; ++i) { - var c = spec.charAt(i), - cUpper = c.toUpperCase(), - arg = args[i]; - // Asterix means allow anything. - if (c == '*') { - continue; - } - typeName = utils.typeName(arg); - if ((arg === null || arg === undefined) && c == cUpper) { - continue; - } - if (typeName != typeMap[cUpper]) { - errMsg = 'Expected ' + typeMap[cUpper]; - break; - } - } - if (errMsg) { - errMsg += ', but got ' + typeName + '.'; - errMsg = 'Wrong type for parameter "' + extractParamName(opt_callee || args.callee, i) + '" of ' + functionName + ': ' + errMsg; - // Don't log when running unit tests. - if (typeof jasmine == 'undefined') { - console.error(errMsg); - } - throw TypeError(errMsg); - } -} - -function getValue(value, defaultValue) { - return value === undefined ? defaultValue : value; -} - -moduleExports.checkArgs = checkArgs; -moduleExports.getValue = getValue; -moduleExports.enableChecks = true; - - -}); - -// file: src/common/base64.js -define("cordova/base64", function(require, exports, module) { - -var base64 = exports; - -base64.fromArrayBuffer = function(arrayBuffer) { - var array = new Uint8Array(arrayBuffer); - return uint8ToBase64(array); -}; - -base64.toArrayBuffer = function(str) { - var decodedStr = typeof atob != 'undefined' ? atob(str) : new Buffer(str,'base64').toString('binary'); - var arrayBuffer = new ArrayBuffer(decodedStr.length); - var array = new Uint8Array(arrayBuffer); - for (var i=0, len=decodedStr.length; i < len; i++) { - array[i] = decodedStr.charCodeAt(i); - } - return arrayBuffer; -}; - -//------------------------------------------------------------------------------ - -/* This code is based on the performance tests at http://jsperf.com/b64tests - * This 12-bit-at-a-time algorithm was the best performing version on all - * platforms tested. - */ - -var b64_6bit = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; -var b64_12bit; - -var b64_12bitTable = function() { - b64_12bit = []; - for (var i=0; i<64; i++) { - for (var j=0; j<64; j++) { - b64_12bit[i*64+j] = b64_6bit[i] + b64_6bit[j]; - } - } - b64_12bitTable = function() { return b64_12bit; }; - return b64_12bit; -}; - -function uint8ToBase64(rawData) { - var numBytes = rawData.byteLength; - var output=""; - var segment; - var table = b64_12bitTable(); - for (var i=0;i> 12]; - output += table[segment & 0xfff]; - } - if (numBytes - i == 2) { - segment = (rawData[i] << 16) + (rawData[i+1] << 8); - output += table[segment >> 12]; - output += b64_6bit[(segment & 0xfff) >> 6]; - output += '='; - } else if (numBytes - i == 1) { - segment = (rawData[i] << 16); - output += table[segment >> 12]; - output += '=='; - } - return output; -} - -}); - -// file: src/common/builder.js -define("cordova/builder", function(require, exports, module) { - -var utils = require('cordova/utils'); - -function each(objects, func, context) { - for (var prop in objects) { - if (objects.hasOwnProperty(prop)) { - func.apply(context, [objects[prop], prop]); - } - } -} - -function clobber(obj, key, value) { - exports.replaceHookForTesting(obj, key); - var needsProperty = false; - try { - obj[key] = value; - } catch (e) { - needsProperty = true; - } - // Getters can only be overridden by getters. - if (needsProperty || obj[key] !== value) { - utils.defineGetter(obj, key, function() { - return value; - }); - } -} - -function assignOrWrapInDeprecateGetter(obj, key, value, message) { - if (message) { - utils.defineGetter(obj, key, function() { - console.log(message); - delete obj[key]; - clobber(obj, key, value); - return value; - }); - } else { - clobber(obj, key, value); - } -} - -function include(parent, objects, clobber, merge) { - each(objects, function (obj, key) { - try { - var result = obj.path ? require(obj.path) : {}; - - if (clobber) { - // Clobber if it doesn't exist. - if (typeof parent[key] === 'undefined') { - assignOrWrapInDeprecateGetter(parent, key, result, obj.deprecated); - } else if (typeof obj.path !== 'undefined') { - // If merging, merge properties onto parent, otherwise, clobber. - if (merge) { - recursiveMerge(parent[key], result); - } else { - assignOrWrapInDeprecateGetter(parent, key, result, obj.deprecated); - } - } - result = parent[key]; - } else { - // Overwrite if not currently defined. - if (typeof parent[key] == 'undefined') { - assignOrWrapInDeprecateGetter(parent, key, result, obj.deprecated); - } else { - // Set result to what already exists, so we can build children into it if they exist. - result = parent[key]; - } - } - - if (obj.children) { - include(result, obj.children, clobber, merge); - } - } catch(e) { - utils.alert('Exception building Cordova JS globals: ' + e + ' for key "' + key + '"'); - } - }); -} - -/** - * Merge properties from one object onto another recursively. Properties from - * the src object will overwrite existing target property. - * - * @param target Object to merge properties into. - * @param src Object to merge properties from. - */ -function recursiveMerge(target, src) { - for (var prop in src) { - if (src.hasOwnProperty(prop)) { - if (target.prototype && target.prototype.constructor === target) { - // If the target object is a constructor override off prototype. - clobber(target.prototype, prop, src[prop]); - } else { - if (typeof src[prop] === 'object' && typeof target[prop] === 'object') { - recursiveMerge(target[prop], src[prop]); - } else { - clobber(target, prop, src[prop]); - } - } - } - } -} - -exports.buildIntoButDoNotClobber = function(objects, target) { - include(target, objects, false, false); -}; -exports.buildIntoAndClobber = function(objects, target) { - include(target, objects, true, false); -}; -exports.buildIntoAndMerge = function(objects, target) { - include(target, objects, true, true); -}; -exports.recursiveMerge = recursiveMerge; -exports.assignOrWrapInDeprecateGetter = assignOrWrapInDeprecateGetter; -exports.replaceHookForTesting = function() {}; - -}); - -// file: src/common/channel.js -define("cordova/channel", function(require, exports, module) { - -var utils = require('cordova/utils'), - nextGuid = 1; - -/** - * Custom pub-sub "channel" that can have functions subscribed to it - * This object is used to define and control firing of events for - * cordova initialization, as well as for custom events thereafter. - * - * The order of events during page load and Cordova startup is as follows: - * - * onDOMContentLoaded* Internal event that is received when the web page is loaded and parsed. - * onNativeReady* Internal event that indicates the Cordova native side is ready. - * onCordovaReady* Internal event fired when all Cordova JavaScript objects have been created. - * onDeviceReady* User event fired to indicate that Cordova is ready - * onResume User event fired to indicate a start/resume lifecycle event - * onPause User event fired to indicate a pause lifecycle event - * - * The events marked with an * are sticky. Once they have fired, they will stay in the fired state. - * All listeners that subscribe after the event is fired will be executed right away. - * - * The only Cordova events that user code should register for are: - * deviceready Cordova native code is initialized and Cordova APIs can be called from JavaScript - * pause App has moved to background - * resume App has returned to foreground - * - * Listeners can be registered as: - * document.addEventListener("deviceready", myDeviceReadyListener, false); - * document.addEventListener("resume", myResumeListener, false); - * document.addEventListener("pause", myPauseListener, false); - * - * The DOM lifecycle events should be used for saving and restoring state - * window.onload - * window.onunload - * - */ - -/** - * Channel - * @constructor - * @param type String the channel name - */ -var Channel = function(type, sticky) { - this.type = type; - // Map of guid -> function. - this.handlers = {}; - // 0 = Non-sticky, 1 = Sticky non-fired, 2 = Sticky fired. - this.state = sticky ? 1 : 0; - // Used in sticky mode to remember args passed to fire(). - this.fireArgs = null; - // Used by onHasSubscribersChange to know if there are any listeners. - this.numHandlers = 0; - // Function that is called when the first listener is subscribed, or when - // the last listener is unsubscribed. - this.onHasSubscribersChange = null; -}, - channel = { - /** - * Calls the provided function only after all of the channels specified - * have been fired. All channels must be sticky channels. - */ - join: function(h, c) { - var len = c.length, - i = len, - f = function() { - if (!(--i)) h(); - }; - for (var j=0; jNative bridge. - POLLING: 0, - // For LOAD_URL to be viable, it would need to have a work-around for - // the bug where the soft-keyboard gets dismissed when a message is sent. - LOAD_URL: 1, - // For the ONLINE_EVENT to be viable, it would need to intercept all event - // listeners (both through addEventListener and window.ononline) as well - // as set the navigator property itself. - ONLINE_EVENT: 2, - // Uses reflection to access private APIs of the WebView that can send JS - // to be executed. - // Requires Android 3.2.4 or above. - PRIVATE_API: 3 - }, - jsToNativeBridgeMode, // Set lazily. - nativeToJsBridgeMode = nativeToJsModes.ONLINE_EVENT, - pollEnabled = false, - messagesFromNative = [], - bridgeSecret = -1; - -function androidExec(success, fail, service, action, args) { - if (bridgeSecret < 0) { - // If we ever catch this firing, we'll need to queue up exec()s - // and fire them once we get a secret. For now, I don't think - // it's possible for exec() to be called since plugins are parsed but - // not run until until after onNativeReady. - throw new Error('exec() called without bridgeSecret'); - } - // Set default bridge modes if they have not already been set. - // By default, we use the failsafe, since addJavascriptInterface breaks too often - if (jsToNativeBridgeMode === undefined) { - androidExec.setJsToNativeBridgeMode(jsToNativeModes.JS_OBJECT); - } - - // Process any ArrayBuffers in the args into a string. - for (var i = 0; i < args.length; i++) { - if (utils.typeName(args[i]) == 'ArrayBuffer') { - args[i] = base64.fromArrayBuffer(args[i]); - } - } - - var callbackId = service + cordova.callbackId++, - argsJson = JSON.stringify(args); - - if (success || fail) { - cordova.callbacks[callbackId] = {success:success, fail:fail}; - } - - var messages = nativeApiProvider.get().exec(bridgeSecret, service, action, callbackId, argsJson); - // If argsJson was received by Java as null, try again with the PROMPT bridge mode. - // This happens in rare circumstances, such as when certain Unicode characters are passed over the bridge on a Galaxy S2. See CB-2666. - if (jsToNativeBridgeMode == jsToNativeModes.JS_OBJECT && messages === "@Null arguments.") { - androidExec.setJsToNativeBridgeMode(jsToNativeModes.PROMPT); - androidExec(success, fail, service, action, args); - androidExec.setJsToNativeBridgeMode(jsToNativeModes.JS_OBJECT); - return; - } else { - androidExec.processMessages(messages, true); - } -} - -androidExec.init = function() { - bridgeSecret = +prompt('', 'gap_init:' + nativeToJsBridgeMode); - channel.onNativeReady.fire(); -}; - -function pollOnceFromOnlineEvent() { - pollOnce(true); -} - -function pollOnce(opt_fromOnlineEvent) { - if (bridgeSecret < 0) { - // This can happen when the NativeToJsMessageQueue resets the online state on page transitions. - // We know there's nothing to retrieve, so no need to poll. - return; - } - var msg = nativeApiProvider.get().retrieveJsMessages(bridgeSecret, !!opt_fromOnlineEvent); - androidExec.processMessages(msg); -} - -function pollingTimerFunc() { - if (pollEnabled) { - pollOnce(); - setTimeout(pollingTimerFunc, 50); - } -} - -function hookOnlineApis() { - function proxyEvent(e) { - cordova.fireWindowEvent(e.type); - } - // The network module takes care of firing online and offline events. - // It currently fires them only on document though, so we bridge them - // to window here (while first listening for exec()-releated online/offline - // events). - window.addEventListener('online', pollOnceFromOnlineEvent, false); - window.addEventListener('offline', pollOnceFromOnlineEvent, false); - cordova.addWindowEventHandler('online'); - cordova.addWindowEventHandler('offline'); - document.addEventListener('online', proxyEvent, false); - document.addEventListener('offline', proxyEvent, false); -} - -hookOnlineApis(); - -androidExec.jsToNativeModes = jsToNativeModes; -androidExec.nativeToJsModes = nativeToJsModes; - -androidExec.setJsToNativeBridgeMode = function(mode) { - if (mode == jsToNativeModes.JS_OBJECT && !window._cordovaNative) { - mode = jsToNativeModes.PROMPT; - } - nativeApiProvider.setPreferPrompt(mode == jsToNativeModes.PROMPT); - jsToNativeBridgeMode = mode; -}; - -androidExec.setNativeToJsBridgeMode = function(mode) { - if (mode == nativeToJsBridgeMode) { - return; - } - if (nativeToJsBridgeMode == nativeToJsModes.POLLING) { - pollEnabled = false; - } - - nativeToJsBridgeMode = mode; - // Tell the native side to switch modes. - // Otherwise, it will be set by androidExec.init() - if (bridgeSecret >= 0) { - nativeApiProvider.get().setNativeToJsBridgeMode(bridgeSecret, mode); - } - - if (mode == nativeToJsModes.POLLING) { - pollEnabled = true; - setTimeout(pollingTimerFunc, 1); - } -}; - -function buildPayload(payload, message) { - var payloadKind = message.charAt(0); - if (payloadKind == 's') { - payload.push(message.slice(1)); - } else if (payloadKind == 't') { - payload.push(true); - } else if (payloadKind == 'f') { - payload.push(false); - } else if (payloadKind == 'N') { - payload.push(null); - } else if (payloadKind == 'n') { - payload.push(+message.slice(1)); - } else if (payloadKind == 'A') { - var data = message.slice(1); - payload.push(base64.toArrayBuffer(data)); - } else if (payloadKind == 'S') { - payload.push(window.atob(message.slice(1))); - } else if (payloadKind == 'M') { - var multipartMessages = message.slice(1); - while (multipartMessages !== "") { - var spaceIdx = multipartMessages.indexOf(' '); - var msgLen = +multipartMessages.slice(0, spaceIdx); - var multipartMessage = multipartMessages.substr(spaceIdx + 1, msgLen); - multipartMessages = multipartMessages.slice(spaceIdx + msgLen + 1); - buildPayload(payload, multipartMessage); - } - } else { - payload.push(JSON.parse(message)); - } -} - -// Processes a single message, as encoded by NativeToJsMessageQueue.java. -function processMessage(message) { - try { - var firstChar = message.charAt(0); - if (firstChar == 'J') { - eval(message.slice(1)); - } else if (firstChar == 'S' || firstChar == 'F') { - var success = firstChar == 'S'; - var keepCallback = message.charAt(1) == '1'; - var spaceIdx = message.indexOf(' ', 2); - var status = +message.slice(2, spaceIdx); - var nextSpaceIdx = message.indexOf(' ', spaceIdx + 1); - var callbackId = message.slice(spaceIdx + 1, nextSpaceIdx); - var payloadMessage = message.slice(nextSpaceIdx + 1); - var payload = []; - buildPayload(payload, payloadMessage); - cordova.callbackFromNative(callbackId, success, status, payload, keepCallback); - } else { - console.log("processMessage failed: invalid message: " + JSON.stringify(message)); - } - } catch (e) { - console.log("processMessage failed: Error: " + e); - console.log("processMessage failed: Stack: " + e.stack); - console.log("processMessage failed: Message: " + message); - } -} - -var isProcessing = false; - -// This is called from the NativeToJsMessageQueue.java. -androidExec.processMessages = function(messages, opt_useTimeout) { - if (messages) { - messagesFromNative.push(messages); - } - // Check for the reentrant case. - if (isProcessing) { - return; - } - if (opt_useTimeout) { - window.setTimeout(androidExec.processMessages, 0); - return; - } - isProcessing = true; - try { - // TODO: add setImmediate polyfill and process only one message at a time. - while (messagesFromNative.length) { - var msg = popMessageFromQueue(); - // The Java side can send a * message to indicate that it - // still has messages waiting to be retrieved. - if (msg == '*' && messagesFromNative.length === 0) { - setTimeout(pollOnce, 0); - return; - } - processMessage(msg); - } - } finally { - isProcessing = false; - } -}; - -function popMessageFromQueue() { - var messageBatch = messagesFromNative.shift(); - if (messageBatch == '*') { - return '*'; - } - - var spaceIdx = messageBatch.indexOf(' '); - var msgLen = +messageBatch.slice(0, spaceIdx); - var message = messageBatch.substr(spaceIdx + 1, msgLen); - messageBatch = messageBatch.slice(spaceIdx + msgLen + 1); - if (messageBatch) { - messagesFromNative.unshift(messageBatch); - } - return message; -} - -module.exports = androidExec; - -}); - -// file: src/common/exec/proxy.js -define("cordova/exec/proxy", function(require, exports, module) { - - -// internal map of proxy function -var CommandProxyMap = {}; - -module.exports = { - - // example: cordova.commandProxy.add("Accelerometer",{getCurrentAcceleration: function(successCallback, errorCallback, options) {...},...); - add:function(id,proxyObj) { - console.log("adding proxy for " + id); - CommandProxyMap[id] = proxyObj; - return proxyObj; - }, - - // cordova.commandProxy.remove("Accelerometer"); - remove:function(id) { - var proxy = CommandProxyMap[id]; - delete CommandProxyMap[id]; - CommandProxyMap[id] = null; - return proxy; - }, - - get:function(service,action) { - return ( CommandProxyMap[service] ? CommandProxyMap[service][action] : null ); - } -}; -}); - -// file: src/common/init.js -define("cordova/init", function(require, exports, module) { - -var channel = require('cordova/channel'); -var cordova = require('cordova'); -var modulemapper = require('cordova/modulemapper'); -var platform = require('cordova/platform'); -var pluginloader = require('cordova/pluginloader'); -var utils = require('cordova/utils'); - -var platformInitChannelsArray = [channel.onNativeReady, channel.onPluginsReady]; - -function logUnfiredChannels(arr) { - for (var i = 0; i < arr.length; ++i) { - if (arr[i].state != 2) { - console.log('Channel not fired: ' + arr[i].type); - } - } -} - -window.setTimeout(function() { - if (channel.onDeviceReady.state != 2) { - console.log('deviceready has not fired after 5 seconds.'); - logUnfiredChannels(platformInitChannelsArray); - logUnfiredChannels(channel.deviceReadyChannelsArray); - } -}, 5000); - -// Replace navigator before any modules are required(), to ensure it happens as soon as possible. -// We replace it so that properties that can't be clobbered can instead be overridden. -function replaceNavigator(origNavigator) { - var CordovaNavigator = function() {}; - CordovaNavigator.prototype = origNavigator; - var newNavigator = new CordovaNavigator(); - // This work-around really only applies to new APIs that are newer than Function.bind. - // Without it, APIs such as getGamepads() break. - if (CordovaNavigator.bind) { - for (var key in origNavigator) { - if (typeof origNavigator[key] == 'function') { - newNavigator[key] = origNavigator[key].bind(origNavigator); - } - else { - (function(k) { - utils.defineGetterSetter(newNavigator,key,function() { - return origNavigator[k]; - }); - })(key); - } - } - } - return newNavigator; -} - -if (window.navigator) { - window.navigator = replaceNavigator(window.navigator); -} - -if (!window.console) { - window.console = { - log: function(){} - }; -} -if (!window.console.warn) { - window.console.warn = function(msg) { - this.log("warn: " + msg); - }; -} - -// Register pause, resume and deviceready channels as events on document. -channel.onPause = cordova.addDocumentEventHandler('pause'); -channel.onResume = cordova.addDocumentEventHandler('resume'); -channel.onDeviceReady = cordova.addStickyDocumentEventHandler('deviceready'); - -// Listen for DOMContentLoaded and notify our channel subscribers. -if (document.readyState == 'complete' || document.readyState == 'interactive') { - channel.onDOMContentLoaded.fire(); -} else { - document.addEventListener('DOMContentLoaded', function() { - channel.onDOMContentLoaded.fire(); - }, false); -} - -// _nativeReady is global variable that the native side can set -// to signify that the native code is ready. It is a global since -// it may be called before any cordova JS is ready. -if (window._nativeReady) { - channel.onNativeReady.fire(); -} - -modulemapper.clobbers('cordova', 'cordova'); -modulemapper.clobbers('cordova/exec', 'cordova.exec'); -modulemapper.clobbers('cordova/exec', 'Cordova.exec'); - -// Call the platform-specific initialization. -platform.bootstrap && platform.bootstrap(); - -// Wrap in a setTimeout to support the use-case of having plugin JS appended to cordova.js. -// The delay allows the attached modules to be defined before the plugin loader looks for them. -setTimeout(function() { - pluginloader.load(function() { - channel.onPluginsReady.fire(); - }); -}, 0); - -/** - * Create all cordova objects once native side is ready. - */ -channel.join(function() { - modulemapper.mapModules(window); - - platform.initialize && platform.initialize(); - - // Fire event to notify that all objects are created - channel.onCordovaReady.fire(); - - // Fire onDeviceReady event once page has fully loaded, all - // constructors have run and cordova info has been received from native - // side. - channel.join(function() { - require('cordova').fireDocumentEvent('deviceready'); - }, channel.deviceReadyChannelsArray); - -}, platformInitChannelsArray); - - -}); - -// file: src/common/init_b.js -define("cordova/init_b", function(require, exports, module) { - -var channel = require('cordova/channel'); -var cordova = require('cordova'); -var platform = require('cordova/platform'); -var utils = require('cordova/utils'); - -var platformInitChannelsArray = [channel.onDOMContentLoaded, channel.onNativeReady]; - -// setting exec -cordova.exec = require('cordova/exec'); - -function logUnfiredChannels(arr) { - for (var i = 0; i < arr.length; ++i) { - if (arr[i].state != 2) { - console.log('Channel not fired: ' + arr[i].type); - } - } -} - -window.setTimeout(function() { - if (channel.onDeviceReady.state != 2) { - console.log('deviceready has not fired after 5 seconds.'); - logUnfiredChannels(platformInitChannelsArray); - logUnfiredChannels(channel.deviceReadyChannelsArray); - } -}, 5000); - -// Replace navigator before any modules are required(), to ensure it happens as soon as possible. -// We replace it so that properties that can't be clobbered can instead be overridden. -function replaceNavigator(origNavigator) { - var CordovaNavigator = function() {}; - CordovaNavigator.prototype = origNavigator; - var newNavigator = new CordovaNavigator(); - // This work-around really only applies to new APIs that are newer than Function.bind. - // Without it, APIs such as getGamepads() break. - if (CordovaNavigator.bind) { - for (var key in origNavigator) { - if (typeof origNavigator[key] == 'function') { - newNavigator[key] = origNavigator[key].bind(origNavigator); - } - else { - (function(k) { - utils.defineGetterSetter(newNavigator,key,function() { - return origNavigator[k]; - }); - })(key); - } - } - } - return newNavigator; -} -if (window.navigator) { - window.navigator = replaceNavigator(window.navigator); -} - -if (!window.console) { - window.console = { - log: function(){} - }; -} -if (!window.console.warn) { - window.console.warn = function(msg) { - this.log("warn: " + msg); - }; -} - -// Register pause, resume and deviceready channels as events on document. -channel.onPause = cordova.addDocumentEventHandler('pause'); -channel.onResume = cordova.addDocumentEventHandler('resume'); -channel.onDeviceReady = cordova.addStickyDocumentEventHandler('deviceready'); - -// Listen for DOMContentLoaded and notify our channel subscribers. -if (document.readyState == 'complete' || document.readyState == 'interactive') { - channel.onDOMContentLoaded.fire(); -} else { - document.addEventListener('DOMContentLoaded', function() { - channel.onDOMContentLoaded.fire(); - }, false); -} - -// _nativeReady is global variable that the native side can set -// to signify that the native code is ready. It is a global since -// it may be called before any cordova JS is ready. -if (window._nativeReady) { - channel.onNativeReady.fire(); -} - -// Call the platform-specific initialization. -platform.bootstrap && platform.bootstrap(); - -/** - * Create all cordova objects once native side is ready. - */ -channel.join(function() { - - platform.initialize && platform.initialize(); - - // Fire event to notify that all objects are created - channel.onCordovaReady.fire(); - - // Fire onDeviceReady event once page has fully loaded, all - // constructors have run and cordova info has been received from native - // side. - channel.join(function() { - require('cordova').fireDocumentEvent('deviceready'); - }, channel.deviceReadyChannelsArray); - -}, platformInitChannelsArray); - -}); - -// file: src/common/modulemapper.js -define("cordova/modulemapper", function(require, exports, module) { - -var builder = require('cordova/builder'), - moduleMap = define.moduleMap, - symbolList, - deprecationMap; - -exports.reset = function() { - symbolList = []; - deprecationMap = {}; -}; - -function addEntry(strategy, moduleName, symbolPath, opt_deprecationMessage) { - if (!(moduleName in moduleMap)) { - throw new Error('Module ' + moduleName + ' does not exist.'); - } - symbolList.push(strategy, moduleName, symbolPath); - if (opt_deprecationMessage) { - deprecationMap[symbolPath] = opt_deprecationMessage; - } -} - -// Note: Android 2.3 does have Function.bind(). -exports.clobbers = function(moduleName, symbolPath, opt_deprecationMessage) { - addEntry('c', moduleName, symbolPath, opt_deprecationMessage); -}; - -exports.merges = function(moduleName, symbolPath, opt_deprecationMessage) { - addEntry('m', moduleName, symbolPath, opt_deprecationMessage); -}; - -exports.defaults = function(moduleName, symbolPath, opt_deprecationMessage) { - addEntry('d', moduleName, symbolPath, opt_deprecationMessage); -}; - -exports.runs = function(moduleName) { - addEntry('r', moduleName, null); -}; - -function prepareNamespace(symbolPath, context) { - if (!symbolPath) { - return context; - } - var parts = symbolPath.split('.'); - var cur = context; - for (var i = 0, part; part = parts[i]; ++i) { - cur = cur[part] = cur[part] || {}; - } - return cur; -} - -exports.mapModules = function(context) { - var origSymbols = {}; - context.CDV_origSymbols = origSymbols; - for (var i = 0, len = symbolList.length; i < len; i += 3) { - var strategy = symbolList[i]; - var moduleName = symbolList[i + 1]; - var module = require(moduleName); - // - if (strategy == 'r') { - continue; - } - var symbolPath = symbolList[i + 2]; - var lastDot = symbolPath.lastIndexOf('.'); - var namespace = symbolPath.substr(0, lastDot); - var lastName = symbolPath.substr(lastDot + 1); - - var deprecationMsg = symbolPath in deprecationMap ? 'Access made to deprecated symbol: ' + symbolPath + '. ' + deprecationMsg : null; - var parentObj = prepareNamespace(namespace, context); - var target = parentObj[lastName]; - - if (strategy == 'm' && target) { - builder.recursiveMerge(target, module); - } else if ((strategy == 'd' && !target) || (strategy != 'd')) { - if (!(symbolPath in origSymbols)) { - origSymbols[symbolPath] = target; - } - builder.assignOrWrapInDeprecateGetter(parentObj, lastName, module, deprecationMsg); - } - } -}; - -exports.getOriginalSymbol = function(context, symbolPath) { - var origSymbols = context.CDV_origSymbols; - if (origSymbols && (symbolPath in origSymbols)) { - return origSymbols[symbolPath]; - } - var parts = symbolPath.split('.'); - var obj = context; - for (var i = 0; i < parts.length; ++i) { - obj = obj && obj[parts[i]]; - } - return obj; -}; - -exports.reset(); - - -}); - -// file: src/android/platform.js -define("cordova/platform", function(require, exports, module) { - -module.exports = { - id: 'android', - bootstrap: function() { - var channel = require('cordova/channel'), - cordova = require('cordova'), - exec = require('cordova/exec'), - modulemapper = require('cordova/modulemapper'); - - // Get the shared secret needed to use the bridge. - exec.init(); - - // TODO: Extract this as a proper plugin. - modulemapper.clobbers('cordova/plugin/android/app', 'navigator.app'); - - var APP_PLUGIN_NAME = Number(cordova.platformVersion.split('.')[0]) >= 4 ? 'CoreAndroid' : 'App'; - - // Inject a listener for the backbutton on the document. - var backButtonChannel = cordova.addDocumentEventHandler('backbutton'); - backButtonChannel.onHasSubscribersChange = function() { - // If we just attached the first handler or detached the last handler, - // let native know we need to override the back button. - exec(null, null, APP_PLUGIN_NAME, "overrideBackbutton", [this.numHandlers == 1]); - }; - - // Add hardware MENU and SEARCH button handlers - cordova.addDocumentEventHandler('menubutton'); - cordova.addDocumentEventHandler('searchbutton'); - - function bindButtonChannel(buttonName) { - // generic button bind used for volumeup/volumedown buttons - var volumeButtonChannel = cordova.addDocumentEventHandler(buttonName + 'button'); - volumeButtonChannel.onHasSubscribersChange = function() { - exec(null, null, APP_PLUGIN_NAME, "overrideButton", [buttonName, this.numHandlers == 1]); - }; - } - // Inject a listener for the volume buttons on the document. - bindButtonChannel('volumeup'); - bindButtonChannel('volumedown'); - - // Let native code know we are all done on the JS side. - // Native code will then un-hide the WebView. - channel.onCordovaReady.subscribe(function() { - exec(onMessageFromNative, null, APP_PLUGIN_NAME, 'messageChannel', []); - exec(null, null, APP_PLUGIN_NAME, "show", []); - }); - } -}; - -function onMessageFromNative(msg) { - var cordova = require('cordova'); - var action = msg.action; - - switch (action) - { - // Button events - case 'backbutton': - case 'menubutton': - case 'searchbutton': - // App life cycle events - case 'pause': - case 'resume': - // Keyboard events - case 'hidekeyboard': - case 'showkeyboard': - // Volume events - case 'volumedownbutton': - case 'volumeupbutton': - cordova.fireDocumentEvent(action); - break; - default: - throw new Error('Unknown event action ' + action); - } -} - -}); - -// file: src/android/plugin/android/app.js -define("cordova/plugin/android/app", function(require, exports, module) { - -var exec = require('cordova/exec'); - -module.exports = { - /** - * Clear the resource cache. - */ - clearCache:function() { - exec(null, null, "App", "clearCache", []); - }, - - /** - * Load the url into the webview or into new browser instance. - * - * @param url The URL to load - * @param props Properties that can be passed in to the activity: - * wait: int => wait msec before loading URL - * loadingDialog: "Title,Message" => display a native loading dialog - * loadUrlTimeoutValue: int => time in msec to wait before triggering a timeout error - * clearHistory: boolean => clear webview history (default=false) - * openExternal: boolean => open in a new browser (default=false) - * - * Example: - * navigator.app.loadUrl("http://server/myapp/index.html", {wait:2000, loadingDialog:"Wait,Loading App", loadUrlTimeoutValue: 60000}); - */ - loadUrl:function(url, props) { - exec(null, null, "App", "loadUrl", [url, props]); - }, - - /** - * Cancel loadUrl that is waiting to be loaded. - */ - cancelLoadUrl:function() { - exec(null, null, "App", "cancelLoadUrl", []); - }, - - /** - * Clear web history in this web view. - * Instead of BACK button loading the previous web page, it will exit the app. - */ - clearHistory:function() { - exec(null, null, "App", "clearHistory", []); - }, - - /** - * Go to previous page displayed. - * This is the same as pressing the backbutton on Android device. - */ - backHistory:function() { - exec(null, null, "App", "backHistory", []); - }, - - /** - * Override the default behavior of the Android back button. - * If overridden, when the back button is pressed, the "backKeyDown" JavaScript event will be fired. - * - * Note: The user should not have to call this method. Instead, when the user - * registers for the "backbutton" event, this is automatically done. - * - * @param override T=override, F=cancel override - */ - overrideBackbutton:function(override) { - exec(null, null, "App", "overrideBackbutton", [override]); - }, - - /** - * Override the default behavior of the Android volume button. - * If overridden, when the volume button is pressed, the "volume[up|down]button" - * JavaScript event will be fired. - * - * Note: The user should not have to call this method. Instead, when the user - * registers for the "volume[up|down]button" event, this is automatically done. - * - * @param button volumeup, volumedown - * @param override T=override, F=cancel override - */ - overrideButton:function(button, override) { - exec(null, null, "App", "overrideButton", [button, override]); - }, - - /** - * Exit and terminate the application. - */ - exitApp:function() { - return exec(null, null, "App", "exitApp", []); - } -}; - -}); - -// file: src/common/pluginloader.js -define("cordova/pluginloader", function(require, exports, module) { - -var modulemapper = require('cordova/modulemapper'); -var urlutil = require('cordova/urlutil'); - -// Helper function to inject a - - - diff --git a/platforms/android/assets/www/js/draftboys.js b/platforms/android/assets/www/js/draftboys.js deleted file mode 100644 index 9c50b6a..0000000 --- a/platforms/android/assets/www/js/draftboys.js +++ /dev/null @@ -1,293 +0,0 @@ -/* Generated by the Nim Compiler v0.10.3 */ -/* (c) 2015 Andreas Rumpf */ - -var framePtr = null; -var excHandler = null; -var lastJSError = null; -var NTI3038 = {size: 0, kind: 17, base: null, node: null, finalizer: null}; -var NTI104 = {size: 0,kind: 31,base: null,node: null,finalizer: null}; -var NTI8887 = {size: 0, kind: 18, base: null, node: null, finalizer: null}; -var NTI3008 = {size: 0, kind: 17, base: null, node: null, finalizer: null}; -var NTI138 = {size: 0,kind: 28,base: null,node: null,finalizer: null}; -var NTI140 = {size: 0,kind: 29,base: null,node: null,finalizer: null}; -var NTI3085 = {size: 0,kind: 22,base: null,node: null,finalizer: null}; -var NTI3024 = {size: 0, kind: 17, base: null, node: null, finalizer: null}; -var NTI3036 = {size: 0, kind: 17, base: null, node: null, finalizer: null}; -var NTI3040 = {size: 0, kind: 17, base: null, node: null, finalizer: null}; -var NNI3040 = {kind: 2, len: 0, offset: 0, typ: null, name: null, sons: []}; -NTI3040.node = NNI3040; -var NNI3036 = {kind: 2, len: 0, offset: 0, typ: null, name: null, sons: []}; -NTI3036.node = NNI3036; -NTI3085.base = NTI3024; -var NNI3024 = {kind: 2, len: 4, offset: 0, typ: null, name: null, sons: [{kind: 1, offset: "parent", len: 0, typ: NTI3085, name: "parent", sons: null}, -{kind: 1, offset: "name", len: 0, typ: NTI140, name: "name", sons: null}, -{kind: 1, offset: "message", len: 0, typ: NTI138, name: "msg", sons: null}, -{kind: 1, offset: "trace", len: 0, typ: NTI138, name: "trace", sons: null}]}; -NTI3024.node = NNI3024; -var NNI3008 = {kind: 2, len: 0, offset: 0, typ: null, name: null, sons: []}; -NTI3008.node = NNI3008; -NTI3024.base = NTI3008; -NTI3036.base = NTI3024; -NTI3040.base = NTI3036; -var NNI8887 = {kind: 2, len: 2, offset: 0, typ: null, name: null, sons: [{kind: 1, offset: "Field0", len: 0, typ: NTI140, name: "Field0", sons: null}, -{kind: 1, offset: "Field1", len: 0, typ: NTI104, name: "Field1", sons: null}]}; -NTI8887.node = NNI8887; -var NNI3038 = {kind: 2, len: 0, offset: 0, typ: null, name: null, sons: []}; -NTI3038.node = NNI3038; -NTI3038.base = NTI3036; -var nim_program_result = [0]; -var globalraisehook_7813 = [null]; -var localraisehook_7818 = [null]; -var outofmemhook_7821 = [null]; -function cstrToNimstr(c_9310) { - var result = []; - for (var i = 0; i < c_9310.length; ++i) { - result[i] = c_9310.charCodeAt(i); - } - result[result.length] = 0; // terminating zero - return result; - } -function arrayConstr(len_10466, value_10467, typ_10468) { - var result = new Array(len_10466); - for (var i = 0; i < len_10466; ++i) result[i] = nimCopy(value_10467, typ_10468); - return result; - } -function SetConstr() { - var result = {}; - for (var i = 0; i < arguments.length; ++i) { - var x = arguments[i]; - if (typeof(x) == "object") { - for (var j = x[0]; j <= x[1]; ++j) { - result[j] = true; - } - } else { - result[x] = true; - } - } - return result; - } -function isfatpointer_10097(ti_10099) { -var result_10100 = false; -BeforeRet: do { -result_10100 = !((SetConstr(17, 16, 4, 18, 27, 19, 23, 22, 21)[ti_10099.base.kind] != undefined)); -break BeforeRet; -} while (false); -return result_10100; -} -function nimCopyAux(dest_10118, src_10119, n_10121) { -switch (n_10121.kind) { -case 0: -break; -case 1: dest_10118[n_10121.offset] = nimCopy(src_10119[n_10121.offset], n_10121.typ); -break; -case 2: L1: do { -var i_10415 = 0; -var HEX3Atmp_10417 = 0; -HEX3Atmp_10417 = (n_10121.len - 1); -var res_10420 = 0; -L2: do { -L3: while (true) { -if (!(res_10420 <= HEX3Atmp_10417)) break L3; -i_10415 = res_10420; -nimCopyAux(dest_10118, src_10119, n_10121.sons[i_10415]); -res_10420 += 1; -} -} while(false); -} while(false); - -break; -case 3: dest_10118[n_10121.offset] = nimCopy(src_10119[n_10121.offset], n_10121.typ); - for (var i = 0; i < n_10121.sons.length; ++i) { - nimCopyAux(dest_10118, src_10119, n_10121.sons[i][1]); - } - -break; -} -} -function nimCopy(x_10114, ti_10115) { -var result_10428 = null; -switch (ti_10115.kind) { -case 21: case 22: case 23: case 5: if (!(isfatpointer_10097(ti_10115))) { -result_10428 = x_10114; -} -else { - result_10428 = [null, 0]; - result_10428[0] = x_10114[0]; - result_10428[1] = x_10114[1]; - } - - -break; -case 19: result_10428 = {}; - for (var key in x_10114) { result_10428[key] = x_10114[key]; } - -break; -case 18: case 17: if (!((ti_10115.base == null))) { -result_10428 = nimCopy(x_10114, ti_10115.base); -} -else { -if ((ti_10115.kind == 17)) { -result_10428 = {m_type: ti_10115};} -else { -result_10428 = {};} -} -nimCopyAux(result_10428, x_10114, ti_10115.node); - -break; -case 24: case 4: case 27: case 16: result_10428 = new Array(x_10114.length); - for (var i = 0; i < x_10114.length; ++i) { - result_10428[i] = nimCopy(x_10114[i], ti_10115.base); - } - -break; -case 28: if (x_10114 !== null) { - result_10428 = x_10114.slice(0); - } - -break; -default: -result_10428 = x_10114; -break; -} -return result_10428; -} -function add_7836(x_7839, x_7839_Idx, y_7840) { -var F={procname:"system.add",prev:framePtr,filename:"lib/system.nim",line:0}; -framePtr = F; - var len = x_7839[0].length-1; - for (var i = 0; i < y_7840.length; ++i) { - x_7839[0][len] = y_7840.charCodeAt(i); - ++len; - } - x_7839[0][len] = 0 - framePtr = framePtr.prev; -} -function auxwritestacktrace_8882(f_8884) { -var result_8885 = [null]; -var it_8890 = f_8884; -var i_8891 = 0; -var total_8892 = 0; -var tempframes_8896 = arrayConstr(64, {Field0: null, Field1: 0}, NTI8887); -L1: do { -L2: while (true) { -if (!(!((it_8890 == null)) && (i_8891 <= 63))) break L2; -tempframes_8896[i_8891].Field0 = it_8890.procname; -tempframes_8896[i_8891].Field1 = it_8890.line; -i_8891 += 1; -total_8892 += 1; -it_8890 = it_8890.prev; -} -} while(false); -L3: do { -L4: while (true) { -if (!!((it_8890 == null))) break L4; -total_8892 += 1; -it_8890 = it_8890.prev; -} -} while(false); -result_8885[0] = cstrToNimstr(""); -if (!((total_8892 == i_8891))) { -result_8885[0] = (result_8885[0].slice(0, -1)).concat(cstrToNimstr("(")); -result_8885[0] = (result_8885[0].slice(0, -1)).concat(cstrToNimstr(((total_8892 - i_8891))+"")); -result_8885[0] = (result_8885[0].slice(0, -1)).concat(cstrToNimstr(" calls omitted) ...\x0A")); -} - -L5: do { -var j_9015 = 0; -var HEX3Atmp_9021 = 0; -HEX3Atmp_9021 = (i_8891 - 1); -var res_9024 = HEX3Atmp_9021; -L6: do { -L7: while (true) { -if (!(0 <= res_9024)) break L7; -j_9015 = res_9024; -add_7836(result_8885, 0, tempframes_8896[j_9015].Field0); -if ((0 < tempframes_8896[j_9015].Field1)) { -result_8885[0] = (result_8885[0].slice(0, -1)).concat(cstrToNimstr(", line: ")); -result_8885[0] = (result_8885[0].slice(0, -1)).concat(cstrToNimstr((tempframes_8896[j_9015].Field1)+"")); -} - -result_8885[0] = (result_8885[0].slice(0, -1)).concat(cstrToNimstr("\x0A")); -res_9024 -= 1; -} -} while(false); -} while(false); -return result_8885[0]; -} -function rawwritestacktrace_9028() { -var result_9030 = null; -if (!((framePtr == null))) { -result_9030 = (cstrToNimstr("Traceback (most recent call last)\x0A").slice(0,-1)).concat(auxwritestacktrace_8882(framePtr)); -framePtr = null; -} -else { -if (!((lastJSError == null))) { -result_9030 = cstrToNimstr(lastJSError.stack); -} -else { -result_9030 = cstrToNimstr("No stack traceback available\x0A"); -} -} -return result_9030; -} -function eqStrings(a_9366, b_9367) { - if (a_9366 == b_9367) return true; - if ((!a_9366) || (!b_9367)) return false; - var alen = a_9366.length; - if (alen != b_9367.length) return false; - for (var i = 0; i < alen; ++i) - if (a_9366[i] != b_9367[i]) return false; - return true; - } -function toJSStr(s_9314) { - var len = s_9314.length-1; - var result = new Array(len); - var fcc = String.fromCharCode; - for (var i = 0; i < len; ++i) { - result[i] = fcc(s_9314[i]); - } - return result.join(""); - } -function raiseException(e_9058, ename_9059) { -var Tmp1; -e_9058.name = ename_9059; -if (!((excHandler == null))) { -excHandler.exc = e_9058; -} -else { -var buf_9201 = [rawwritestacktrace_9028()]; -if (!!(eqStrings(e_9058.message, null))) Tmp1 = false; else {Tmp1 = !((e_9058.message[0] == 0)); }if (Tmp1) { -buf_9201[0] = (buf_9201[0].slice(0, -1)).concat(cstrToNimstr("Error: unhandled exception: ")); -buf_9201[0] = (buf_9201[0].slice(0, -1)).concat(e_9058.message); -} -else { -buf_9201[0] = (buf_9201[0].slice(0, -1)).concat(cstrToNimstr("Error: unhandled exception")); -} - -buf_9201[0] = (buf_9201[0].slice(0, -1)).concat(cstrToNimstr(" [")); -add_7836(buf_9201, 0, ename_9059); -buf_9201[0] = (buf_9201[0].slice(0, -1)).concat(cstrToNimstr("]\x0A")); -alert(toJSStr(buf_9201[0])); -} - -throw e_9058;} -function raiseOverflow() { -var e_9234 = null; -e_9234 = {m_type: NTI3040, parent: null, name: null, message: null, trace: null}; -e_9234.message = cstrToNimstr("over- or underflow"); -raiseException(e_9234, "OverflowError"); -} -function raiseDivByZero() { -var e_9249 = null; -e_9249 = {m_type: NTI3038, parent: null, name: null, message: null, trace: null}; -e_9249.message = cstrToNimstr("division by zero"); -raiseException(e_9249, "DivByZeroError"); -} -function placeholderlistener_17001(event_17004) { -var F={procname:"draftboys.placeholderListener",prev:framePtr,filename:"/home/jaccarmac/src/jaccarmac.com/draftboys/src/draftboys.nim",line:0}; -framePtr = F; -F.line = 4; -document.getElementById("placeholder").innerHTML = "Hello from Nim!"; -framePtr = framePtr.prev; -} -document.addEventListener("deviceready", placeholderlistener_17001); diff --git a/platforms/android/res/xml/config.xml b/platforms/android/res/xml/config.xml index ac6bba8..30ab136 100644 --- a/platforms/android/res/xml/config.xml +++ b/platforms/android/res/xml/config.xml @@ -1,5 +1,5 @@ - + DRAFTBOYS diff --git a/www/js/draftboys.js b/www/js/draftboys.js deleted file mode 100644 index 9c50b6a..0000000 --- a/www/js/draftboys.js +++ /dev/null @@ -1,293 +0,0 @@ -/* Generated by the Nim Compiler v0.10.3 */ -/* (c) 2015 Andreas Rumpf */ - -var framePtr = null; -var excHandler = null; -var lastJSError = null; -var NTI3038 = {size: 0, kind: 17, base: null, node: null, finalizer: null}; -var NTI104 = {size: 0,kind: 31,base: null,node: null,finalizer: null}; -var NTI8887 = {size: 0, kind: 18, base: null, node: null, finalizer: null}; -var NTI3008 = {size: 0, kind: 17, base: null, node: null, finalizer: null}; -var NTI138 = {size: 0,kind: 28,base: null,node: null,finalizer: null}; -var NTI140 = {size: 0,kind: 29,base: null,node: null,finalizer: null}; -var NTI3085 = {size: 0,kind: 22,base: null,node: null,finalizer: null}; -var NTI3024 = {size: 0, kind: 17, base: null, node: null, finalizer: null}; -var NTI3036 = {size: 0, kind: 17, base: null, node: null, finalizer: null}; -var NTI3040 = {size: 0, kind: 17, base: null, node: null, finalizer: null}; -var NNI3040 = {kind: 2, len: 0, offset: 0, typ: null, name: null, sons: []}; -NTI3040.node = NNI3040; -var NNI3036 = {kind: 2, len: 0, offset: 0, typ: null, name: null, sons: []}; -NTI3036.node = NNI3036; -NTI3085.base = NTI3024; -var NNI3024 = {kind: 2, len: 4, offset: 0, typ: null, name: null, sons: [{kind: 1, offset: "parent", len: 0, typ: NTI3085, name: "parent", sons: null}, -{kind: 1, offset: "name", len: 0, typ: NTI140, name: "name", sons: null}, -{kind: 1, offset: "message", len: 0, typ: NTI138, name: "msg", sons: null}, -{kind: 1, offset: "trace", len: 0, typ: NTI138, name: "trace", sons: null}]}; -NTI3024.node = NNI3024; -var NNI3008 = {kind: 2, len: 0, offset: 0, typ: null, name: null, sons: []}; -NTI3008.node = NNI3008; -NTI3024.base = NTI3008; -NTI3036.base = NTI3024; -NTI3040.base = NTI3036; -var NNI8887 = {kind: 2, len: 2, offset: 0, typ: null, name: null, sons: [{kind: 1, offset: "Field0", len: 0, typ: NTI140, name: "Field0", sons: null}, -{kind: 1, offset: "Field1", len: 0, typ: NTI104, name: "Field1", sons: null}]}; -NTI8887.node = NNI8887; -var NNI3038 = {kind: 2, len: 0, offset: 0, typ: null, name: null, sons: []}; -NTI3038.node = NNI3038; -NTI3038.base = NTI3036; -var nim_program_result = [0]; -var globalraisehook_7813 = [null]; -var localraisehook_7818 = [null]; -var outofmemhook_7821 = [null]; -function cstrToNimstr(c_9310) { - var result = []; - for (var i = 0; i < c_9310.length; ++i) { - result[i] = c_9310.charCodeAt(i); - } - result[result.length] = 0; // terminating zero - return result; - } -function arrayConstr(len_10466, value_10467, typ_10468) { - var result = new Array(len_10466); - for (var i = 0; i < len_10466; ++i) result[i] = nimCopy(value_10467, typ_10468); - return result; - } -function SetConstr() { - var result = {}; - for (var i = 0; i < arguments.length; ++i) { - var x = arguments[i]; - if (typeof(x) == "object") { - for (var j = x[0]; j <= x[1]; ++j) { - result[j] = true; - } - } else { - result[x] = true; - } - } - return result; - } -function isfatpointer_10097(ti_10099) { -var result_10100 = false; -BeforeRet: do { -result_10100 = !((SetConstr(17, 16, 4, 18, 27, 19, 23, 22, 21)[ti_10099.base.kind] != undefined)); -break BeforeRet; -} while (false); -return result_10100; -} -function nimCopyAux(dest_10118, src_10119, n_10121) { -switch (n_10121.kind) { -case 0: -break; -case 1: dest_10118[n_10121.offset] = nimCopy(src_10119[n_10121.offset], n_10121.typ); -break; -case 2: L1: do { -var i_10415 = 0; -var HEX3Atmp_10417 = 0; -HEX3Atmp_10417 = (n_10121.len - 1); -var res_10420 = 0; -L2: do { -L3: while (true) { -if (!(res_10420 <= HEX3Atmp_10417)) break L3; -i_10415 = res_10420; -nimCopyAux(dest_10118, src_10119, n_10121.sons[i_10415]); -res_10420 += 1; -} -} while(false); -} while(false); - -break; -case 3: dest_10118[n_10121.offset] = nimCopy(src_10119[n_10121.offset], n_10121.typ); - for (var i = 0; i < n_10121.sons.length; ++i) { - nimCopyAux(dest_10118, src_10119, n_10121.sons[i][1]); - } - -break; -} -} -function nimCopy(x_10114, ti_10115) { -var result_10428 = null; -switch (ti_10115.kind) { -case 21: case 22: case 23: case 5: if (!(isfatpointer_10097(ti_10115))) { -result_10428 = x_10114; -} -else { - result_10428 = [null, 0]; - result_10428[0] = x_10114[0]; - result_10428[1] = x_10114[1]; - } - - -break; -case 19: result_10428 = {}; - for (var key in x_10114) { result_10428[key] = x_10114[key]; } - -break; -case 18: case 17: if (!((ti_10115.base == null))) { -result_10428 = nimCopy(x_10114, ti_10115.base); -} -else { -if ((ti_10115.kind == 17)) { -result_10428 = {m_type: ti_10115};} -else { -result_10428 = {};} -} -nimCopyAux(result_10428, x_10114, ti_10115.node); - -break; -case 24: case 4: case 27: case 16: result_10428 = new Array(x_10114.length); - for (var i = 0; i < x_10114.length; ++i) { - result_10428[i] = nimCopy(x_10114[i], ti_10115.base); - } - -break; -case 28: if (x_10114 !== null) { - result_10428 = x_10114.slice(0); - } - -break; -default: -result_10428 = x_10114; -break; -} -return result_10428; -} -function add_7836(x_7839, x_7839_Idx, y_7840) { -var F={procname:"system.add",prev:framePtr,filename:"lib/system.nim",line:0}; -framePtr = F; - var len = x_7839[0].length-1; - for (var i = 0; i < y_7840.length; ++i) { - x_7839[0][len] = y_7840.charCodeAt(i); - ++len; - } - x_7839[0][len] = 0 - framePtr = framePtr.prev; -} -function auxwritestacktrace_8882(f_8884) { -var result_8885 = [null]; -var it_8890 = f_8884; -var i_8891 = 0; -var total_8892 = 0; -var tempframes_8896 = arrayConstr(64, {Field0: null, Field1: 0}, NTI8887); -L1: do { -L2: while (true) { -if (!(!((it_8890 == null)) && (i_8891 <= 63))) break L2; -tempframes_8896[i_8891].Field0 = it_8890.procname; -tempframes_8896[i_8891].Field1 = it_8890.line; -i_8891 += 1; -total_8892 += 1; -it_8890 = it_8890.prev; -} -} while(false); -L3: do { -L4: while (true) { -if (!!((it_8890 == null))) break L4; -total_8892 += 1; -it_8890 = it_8890.prev; -} -} while(false); -result_8885[0] = cstrToNimstr(""); -if (!((total_8892 == i_8891))) { -result_8885[0] = (result_8885[0].slice(0, -1)).concat(cstrToNimstr("(")); -result_8885[0] = (result_8885[0].slice(0, -1)).concat(cstrToNimstr(((total_8892 - i_8891))+"")); -result_8885[0] = (result_8885[0].slice(0, -1)).concat(cstrToNimstr(" calls omitted) ...\x0A")); -} - -L5: do { -var j_9015 = 0; -var HEX3Atmp_9021 = 0; -HEX3Atmp_9021 = (i_8891 - 1); -var res_9024 = HEX3Atmp_9021; -L6: do { -L7: while (true) { -if (!(0 <= res_9024)) break L7; -j_9015 = res_9024; -add_7836(result_8885, 0, tempframes_8896[j_9015].Field0); -if ((0 < tempframes_8896[j_9015].Field1)) { -result_8885[0] = (result_8885[0].slice(0, -1)).concat(cstrToNimstr(", line: ")); -result_8885[0] = (result_8885[0].slice(0, -1)).concat(cstrToNimstr((tempframes_8896[j_9015].Field1)+"")); -} - -result_8885[0] = (result_8885[0].slice(0, -1)).concat(cstrToNimstr("\x0A")); -res_9024 -= 1; -} -} while(false); -} while(false); -return result_8885[0]; -} -function rawwritestacktrace_9028() { -var result_9030 = null; -if (!((framePtr == null))) { -result_9030 = (cstrToNimstr("Traceback (most recent call last)\x0A").slice(0,-1)).concat(auxwritestacktrace_8882(framePtr)); -framePtr = null; -} -else { -if (!((lastJSError == null))) { -result_9030 = cstrToNimstr(lastJSError.stack); -} -else { -result_9030 = cstrToNimstr("No stack traceback available\x0A"); -} -} -return result_9030; -} -function eqStrings(a_9366, b_9367) { - if (a_9366 == b_9367) return true; - if ((!a_9366) || (!b_9367)) return false; - var alen = a_9366.length; - if (alen != b_9367.length) return false; - for (var i = 0; i < alen; ++i) - if (a_9366[i] != b_9367[i]) return false; - return true; - } -function toJSStr(s_9314) { - var len = s_9314.length-1; - var result = new Array(len); - var fcc = String.fromCharCode; - for (var i = 0; i < len; ++i) { - result[i] = fcc(s_9314[i]); - } - return result.join(""); - } -function raiseException(e_9058, ename_9059) { -var Tmp1; -e_9058.name = ename_9059; -if (!((excHandler == null))) { -excHandler.exc = e_9058; -} -else { -var buf_9201 = [rawwritestacktrace_9028()]; -if (!!(eqStrings(e_9058.message, null))) Tmp1 = false; else {Tmp1 = !((e_9058.message[0] == 0)); }if (Tmp1) { -buf_9201[0] = (buf_9201[0].slice(0, -1)).concat(cstrToNimstr("Error: unhandled exception: ")); -buf_9201[0] = (buf_9201[0].slice(0, -1)).concat(e_9058.message); -} -else { -buf_9201[0] = (buf_9201[0].slice(0, -1)).concat(cstrToNimstr("Error: unhandled exception")); -} - -buf_9201[0] = (buf_9201[0].slice(0, -1)).concat(cstrToNimstr(" [")); -add_7836(buf_9201, 0, ename_9059); -buf_9201[0] = (buf_9201[0].slice(0, -1)).concat(cstrToNimstr("]\x0A")); -alert(toJSStr(buf_9201[0])); -} - -throw e_9058;} -function raiseOverflow() { -var e_9234 = null; -e_9234 = {m_type: NTI3040, parent: null, name: null, message: null, trace: null}; -e_9234.message = cstrToNimstr("over- or underflow"); -raiseException(e_9234, "OverflowError"); -} -function raiseDivByZero() { -var e_9249 = null; -e_9249 = {m_type: NTI3038, parent: null, name: null, message: null, trace: null}; -e_9249.message = cstrToNimstr("division by zero"); -raiseException(e_9249, "DivByZeroError"); -} -function placeholderlistener_17001(event_17004) { -var F={procname:"draftboys.placeholderListener",prev:framePtr,filename:"/home/jaccarmac/src/jaccarmac.com/draftboys/src/draftboys.nim",line:0}; -framePtr = F; -F.line = 4; -document.getElementById("placeholder").innerHTML = "Hello from Nim!"; -framePtr = framePtr.prev; -} -document.addEventListener("deviceready", placeholderlistener_17001); diff --git a/www/js/empty b/www/js/empty new file mode 100644 index 0000000..e69de29