From 6d437b815662c5d3df44458a45e65f14fbf5c80f Mon Sep 17 00:00:00 2001 From: Sean Wells Date: Mon, 27 Jul 2015 16:56:00 -0700 Subject: [PATCH] fix(bug fix): added proper string conversion for R numeric/integer inputs For R inputs, added: - parseInt() and parseFloat() for JavaScript strings that are of type number. Closes #5 --- browser/deployr.js | 21 +++++++++------------ browser/deployr.min.js | 2 +- 2 files changed, 10 insertions(+), 13 deletions(-) diff --git a/browser/deployr.js b/browser/deployr.js index d91f621..1da26b8 100644 --- a/browser/deployr.js +++ b/browser/deployr.js @@ -7909,6 +7909,9 @@ module.exports = Base.extend(RTypes, { }, numeric: function () { + // support `String` numbers (e.g. "1.2") + this.value = parseFloat(this.value); + return this.assert({ type: this.deployr.RNUMERIC, name: this.name, @@ -7918,6 +7921,9 @@ module.exports = Base.extend(RTypes, { }, integer: function () { + // support `String` integer (e.g. "15") + this.value = parseInt(this.value, 10); + return this.assert({ type: this.deployr.RINTEGER, name: this.name, @@ -8354,19 +8360,9 @@ module.exports = Base.extend({ switch (rinput.type) { case deployr.RNUMERIC : case deployr.RNUMERIC_VECTOR : - case deployr.RNUMERIC_VECTOR : - fn = Lang.isNumber; - // support string numbers - var val = parseFloat(value); - value = isNaN(val) ? value : val; - break; - case deployr.RINTEGER : case deployr.RINTEGER_VECTOR : fn = Lang.isNumber; - // support string numbers - var val = parseFloat(value); - value = isNaN(val) ? value : val; break; case deployr.RBOOLEAN : @@ -8398,7 +8394,8 @@ module.exports = Base.extend({ if (fn && !fn(value)) { throw new Error('RInputFormatError: ' + '"' + value + - '" is not a valid "' + rinput.type + '" type.'); + '" is not a valid "' + rinput.type + '" type for input ' + + '"' + rinput.name + '"'); } } @@ -10531,4 +10528,4 @@ module.exports={ },{}]},{},[1])(1) }); -//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","deployr.js","apis.json","lib/deprecated.js","lib/emitter.js","lib/encoder.js","lib/es.js","lib/lang.js","lib/logger.js","lib/optional.js","lib/queue.js","lib/rinput.js","lib/rinputs.js","lib/rtypes.js","lib/selfish.js","lib/utils.js","node_modules/browserify/lib/_empty.js","node_modules/browserify/node_modules/process/browser.js","node_modules/d.js/lib/D.js","node_modules/superagent/lib/client.js","node_modules/superagent/node_modules/component-emitter/index.js","node_modules/superagent/node_modules/reduce-component/index.js","package.json"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC92CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/aA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtyJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3TA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9HA;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","(function (process){\n/*!\n * Copyright (C) 2010-2015 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nvar win         = (typeof window !== 'undefined'),   \n    request     = require('superagent'),\n    D           = require('d.js'),\n    fs          = require('fs'),\n    apis        = require('./apis.json'), \n    EventStream = require('./lib/es'),\n    utils       = require('./lib/utils'),\n    Lang        = require('./lib/lang'),   \n    Logger      = require('./lib/logger'),   \n    Queue       = require('./lib/queue'),\n    Emitter     = require('./lib/emitter'),\n    encoder     = require('./lib/encoder'),\n    Base        = require('./lib/selfish').Base,\n    RInput      = require('./lib/rinput'),    \n    RInputs     = require('./lib/rinputs'),\n    merge       = utils.merge;\n\n/*\n * Turn global logging off by default\n */\nLogger.setLevel(Logger.OFF);\n\n/*\n * Global options that persist through all DeployR requests.\n */\nvar globalOptions = { \n  cors: false,\n  logging: false,\n  sticky: false,\n  cookies: null,\n  host: '',\n  allowSelfSignedSSLCert: false,\n  maxRequests: null, // no socket pooling in http.Agent\n  events:{},\n  set: function(prop, value) { \n    if (prop !== 'set') { \n      if (prop === 'host' && value) {         \n         // Be more forgiving on the entered DeployR 'endpoint':\n         //   - http(s)://dhost:port\n         //   - http(s)://dhost:port/deployr\n         //   - dhost:port\n         //   - dhost:port/deployr         \n         value = value.replace(/\\/*$|\\/*deployr\\/*$/, '');\n         value = (new RegExp('^(http|https)://', 'i')).test(value) ? value : \n            'http://' + value;\n      }\n\n      this[prop] = value; \n    } \n  }\n};\n\n/*\n * The top-level DeployR API response entities.\n */\nvar TOPLEVEL_ENTITIES = [\n  'user', \n  'project', \n  'workspace', \n  'execution', \n  'directory', \n  'repository', \n  'packages' \n];\n\n/*\n * Notify global IO error events accessible by all subscribers across requests.\n */\nfunction raiseGlobalErrors(api, res) {\n  var code    = res.deployr ? res.deployr.response.errorCode : res.status,\n      context = this;\n\n  // -- global events if provided --\n  if (globalOptions.events) {\n    if (!res.deployr) {\n      res = res.text;\n    }\n\n    context = globalOptions.events.ctx || context;\n\n    // -- general global failure --\n    if (globalOptions.events.error) {\n      globalOptions.events.error.apply(context, [api, res]);\n    }\n\n    // -- HTTP or DeployR global errors --    \n    if (globalOptions.events[code]) {\n      globalOptions.events[code].apply(context, [api, res]);\n    }\n  }\n}\n\n/**\n * The `DeployR` request class is a utility that brokers HTTP requests through a \n * simplified fluid interface to DeployR.\n *\n * @module deployr\n * @for deployr\n */\nvar DeployR = Base.extend(Emitter, RInputs, {\n\n  /**\n   * The `DeployR` Request class is a utility that brokers HTTP requests through \n   * a simplified fluid interface to DeployR.\n   * \n   * @class \n   * @constructor\n   * @param {String} api The DeployR API\n   * @param {Object} link The object literal containing the previous request.\n   * @api private\n   */\n  initialize: function initialize(api, link) {\n     Emitter.initialize.call(this, {});\n  \n     var opts = globalOptions;\n\n     if (!apis[api]) { throw new Error('Invalid API \"' + api + '\"'); }\n    \n     this.api        = merge({ 'call': api }, apis[api]);    \n     this.link       = link || {};\n     this.q          = this.link.queue || new Queue();\n     this.deferred   = this.link.deferred || D();\n     this.cookies    = this.link.cookies;\n     this.logger     = Logger.get(api, Logger.OFF); // transaction-level logging\n     this.params     = {};\n     this.inputs     = []; // rinputs list \n     this.outputs    = []; // routput object list\n     this.rstream    = false;\n     this.delayed    = false;\n     this.globalEvts = true; // suppress|raise global events fot this `io`     \n     this.file       = null; \n     this.entities   = null; \n     this.ioFilter   = function() { return true; };\n\n     // preset deployr's assigned response format for `this` api\n     this.data({ format: this.api.format });\n\n     // wrap superagent for the heavy lifting     \n     this.req = \n        request[this.api.method.toLowerCase()](opts.host + '/deployr' + api);\n     this.req.timeout(20 * 60 * 1000); // default timeout --> 20 minutes\n\n     // All CORS deployr calls require sticky sessions\n     if (win && globalOptions.cors) { this.req.withCredentials(); }\n\n     // Node.js - access an SSL endpoint with self signed certs for testing|dev\n     if (!win && globalOptions.allowSelfSignedSSLCert) {\n        process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';        \n     }\n  },\n\n  /**\n   * Binds the scope context for the configured `.end()` and `.error()` event    \n   * handler callbacks on this request.\n   *\n   * @method ctx\n   * @param {Object} context The `this` object for the configured `.end()` and\n   * `.error()` event handlers on this request.\n   * @api public   \n   */ \n  ctx: function (context) {\n    this.scope = context || this;\n\n    return this;\n  },\n\n  /**\n   * Suppress or raise global events for this `io` request.\n   *\n   * @method global\n   * @param {Boolean} raise `true` to raise global events, `false` to supress \n   * event firing globally.\n   * @return {DeployR} for chaining.\n   * @api public\n   */  \n  global: function(raise) {\n    this.globalEvts = Lang.isBoolean(raise) ? raise : this.globalEvts;\n\n    return this;\n  },  \n\n  /**\n   * Retrieve details about user.\n   *   \n   * @method about\n   * @return {Object} details about user otherwies `null`.\n   * @api public   \n   */\n  about: function() {\n    var response = this.req.res;\n\n    return this.api['call'] === '/r/user/login' && response ? \n           response.body.get('user') : null;\n  },  \n\n  /**\n   * Shares the cookies from a diffrent `.io()` agent to preserve session state\n   * across `this` request and all requests chained to it.\n   *\n   * @method share\n   * @return {DeployR} for chaining.\n   * @api public   \n   */  \n  share: function (cookies) {\n    if (globalOptions.sticky) {\n      if (globalOptions.cookies) {\n        this.cookies = globalOptions.cookies.slice(0); \n      } else {\n        if (cookies) { \n          this.cookies = cookies.slice(0); \n          globalOptions.set('cookies', this.cookies);\n        }\n      }\n    } else {\n      this.cookies = (cookies ? cookies.slice(0) : this.cookies);\n    }\n\n    return this;\n  },\n\n  /**\n   * Returns the HTTP cookie previously sent by the server with Set-Cookie.\n   * This value can be passed to `.share(ruser.getCookies())` of a diffrent\n   * `.io()` agent to preserve session state across requests.\n   *\n   * @method getCookies\n   * @return {Array} The HTTP cookie previously sent by the server with \n   * Set-Cookie.\n   * @api public   \n   */  \n  getCookies: function () {\n    return this.cookies;\n  }, \n\n  delay: function (ms) {\n    // TODO: support delayed requests based on ms for now this is just a pause.\n    this.delayed = !isNaN(parseFloat(ms)) && isFinite(ms) ? ms : true;\n\n    return this;\n  },   \n\n  /**\n   * Unwind the queue chain clearing requests that might have delays attached.\n   *\n   * @method drain\n   * @return {Promise} A promise wrapping the resolution of either \"resolve\" or\n   * \"reject\" callback.\n   * @api public   \n   */\n  drain: function () {\n    this.delayed = false;\n    this.q.flush(); \n\n    return this.deferred.promise;\n  },   \n\n  /**\n   * The `.promise()` method returns a dynamically generated Promise that is \n   * resolved once all DeployR `.io()` requests have ended.\n   *   \n   * @method promise\n   * @return {Promise} A promise wrapping the resolution of either \"resolve\" or\n   * \"reject\" callback.\n   * @api public\n   */     \n  promise: function () {\n    this.end();\n\n    return this.deferred.promise;\n  },\n\n  /**\n   * Abort the DeployR request.\n   *\n   * @method abort  \n   * @return {DeployR} for chaining.\n   * @api public\n   */  \n  abort: function () {\n    this.req.abort();\n    this.emit('abort');\n    this.deferred.reject(this._handleError({ \n        status: 'abort',\n        text: 'DeployR request aborted.'\n    }));\n\n    return this;\n  },\n\n /**\n  * Set timeout to `ms`.\n  *\n  * @method timeout  \n  * @param {Number} ms\n  * @return {DeployR} for chaining\n  * @api public\n  */  \n  timeout: function (ms) {\n    this.req.timeout(ms);\n\n    return this;\n  },\n\n /**\n  * Turn logging on for the specific transaction.\n  *\n  * @method log\n  * @return {DeployR} for chaining\n  * @api public\n  */ \n  log: function (level) {\n    this.logger.setLevel(level || Logger.DEBUG);\n\n    return this;\n  },\n\n  /**\n   * Filters successful responses to contain only a top-level DeployR API \n   * response entities:\n   * - 'user'\n   * - 'project'\n   * - 'workspace' \n   * - 'execution' \n   * - 'directory' \n   * - 'repository'\n   * - 'packages' \n   *   \n   * @method entity\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  entity: function (entity) {\n    this.entities = utils.inArray(TOPLEVEL_ENTITIES, entity);\n\n    return this;\n  },\n\n  /**\n   * Defines the request data being sent to a DeployR API. \n   *\n   * @method data\n   * @param {Object} data The object literal configuration hash. \n   * @return {DeployR} for chaining\n   * @api public\n   */\n  data: function (data) {\n    data = data || {};    \n\n    // remove any inlined rinput(s) and attach them to the rinput(s) property\n    if (data.rinput || data.rinputs) {\n      this.rinput(data.rinput);\n      this.rinputs(data.rinputs);\n    } \n\n    // remove any `reserved` values that could have been passed by mistake\n    var BLACKLIST = ['rinput', 'rinputs', '__cookies__'];\n    BLACKLIST.forEach(function(param) { delete data[param]; });  \n\n    this.params = merge(this.params, data);\n\n    return this;\n  },\n\n  /**\n   * Attaches a file to be uploaded. \n   *\n   * @method attach\n   * @param {File|Blob|path} file The file to be attached for an upload. For \n   * Browser environments the HTML5 File|Blob is used. For the Node.js \n   * environment, a file path is accepted.\n   * @param {String} filename (optional) the name of the file to be uploaded. \n   * This name does not have to match the actual source filename.\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  attach: function (file, filename) {\n    if (this.api.upload) {\n      this.file = file;\n\n      // optional filename here for convenience\n      if (filename) { this.data( { filename: filename } ); }\n    }\n\n    return this;\n  },\n\n  /**\n   * Supported only in Node.js, this method works in conjunction with the \n   * attach method to indicate that the file should be read in as a readable \n   * stream during a file upload.\n   *\n   * @method stream\n   * @param {Object} options (optional) the Readable Stream options hash.\n   *  ```\n   *    { flags: 'r',\n   *      encoding: null,\n   *      fd: null,\n   *      mode: 0666,\n   *      autoClose: true\n   *    }\n   * ```\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  stream: function () {\n    this.rstream = (!win && this.api.upload); //nodejs only\n\n    return this;\n  },\n\n  /**\n   * The `filter(λ)` method removes this DeployR request from the request chain\n   * if the provided function does *not* pass the test implemented by it.\n   *\n   * Examples:\n   *\n   * ```\n   * // Remove from the request chain\n   * .filter(function(args) {\n   *    return 5 > 10;\n   * })\n   *\n   * // Keep in the request chain\n   * .filter(function(args) {\n   *    return 10 > 5;\n   * })   \n   * ```\n   *\n   * @method filter\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining\n   * @api public   \n   */\n  filter: function(fn) {\n    if (fn) {\n      this.ioFilter = function(prevArgs) {\n        var args = {}, keep;\n\n        // copy over previous arguments and filter out internal __cookies__ \n        for (var key in prevArgs) {\n           if (key !== '__cookies__') { \n              args[key] = prevArgs[key];\n           }\n        }\n\n        keep = fn(args);\n        return (keep || keep === false ? keep : true);\n      };\n    }\n\n    return this;\n  },  \n  \n  /**\n   * Acts as a finally statement allowing you to execute \"cleanup\" type tasks \n   * in a request chain. It arranges for cleanup to be called, with no \n   * arguments, when the DeployR request chain is either completely fulfilled \n   * or rejected.\n   *\n   * @method ensure\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining\n   * @api public\n   */  \n  ensure: function (fn) {\n    this.deferred.promise.ensure(fn);\n\n    return this.deferred.promise;\n  },\n      \n  /**\n   * The general failure callback. If called, all DeployR errors for this \n   * transaction will be returned here when raised.\n   *\n   * @method error\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  error: function (fn) {\n    this.on('error', fn);\n\n    return this;\n  },\n\n  /**\n   * Stream the DeployR response into the pipe. It is important to note that if \n   * the `.pipe()` method is never called the request will not be sent.\n   *\n   * The `.pipe()` method should be be used as an alternative to `.end()` and \n   * never along side of it. `.pipe()` and `.end()` are an either-or.\n   *\n   * @method pipe\n   * @param {Stream} stream A destination Stream.\n   * @return {Stream} The passed in destination stream to be used for additional \n   * piping.\n   * @api public\n   */\n  pipe: function (dest) {\n    var q   = this.q,\n        api = this.api;        \n\n    q.add(function(responseChain, error, prevArgs) {    \n      // brake the call chain on error      \n      if (error) {        \n        this.deferred.reject(error);      \n        q.flush(responseChain, error, prevArgs); // drain the queue\n        this._clear();\n        return;\n      }\n      \n      this._prepRequest(responseChain, prevArgs);\n\n      Logger.info('pipe()', api, this.req);\n      this.logger.info('pipe()', api, this.req);   \n\n      var stream = this.req.pipe(dest);\n      q.yield(true);\n      stream.on('error', function () { });    \n      stream.on('end', function() { });     \n      stream.on('data', function() { });      \n    }, this);\n  \n    if (q.size() <= 1) { q.flush(); }\n\n    return dest;\n  },\n\n  /**\n   * Indicates that the request is ready to be sent to DeployR. It is important \n   * to note that if the `.end()` method is never called the request will not be\n   * sent.\n   *\n   * @method end\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining.\n   * @api public\n   */ \n  end: function (fn) {\n    var self     = this,\n        q        = this.q,\n        api      = this.api,\n        args     = null,\n        entities =  this.entities;\n\n    q.add(function(responseChain, error, prevArgs) {\n      // break the call chain on error      \n      if (error) {        \n        this.deferred.reject(error);        \n        q.flush(responseChain, error, prevArgs); // drain the queue\n        this._clear();\n        return;\n      }\n\n      //\n      if (!this.ioFilter(prevArgs)) {\n        if (q.size() === 0) { \n          this.deferred.resolve(responseChain || prevArgs);\n        }\n\n        q.flush(responseChain, error, prevArgs); // drain the queue\n        this._clear();\n        return;\n      }\n      \n      this._prepRequest(responseChain, prevArgs);\n\n      Logger.info('io()', api, this.req);\n      this.logger.info('io()', api, this.req);    \n\n      // send next request\n      this.req.end(function(res) {\n        self.share(self.cookies || res.headers['set-cookie']);         \n\n        // -- log cookies across requests --\n        if (self.cookies) {\n          Logger.info('cookies', api, self.cookies); \n          self.logger.info('cookies', api, self.cookies); \n        }\n\n        error = self._handleError(res);\n        var dres = (res.body && res.body.deployr ? res.body : res);             \n      \n        self.inputs = [];\n        self.outputs = [];\n\n        if (!error) {\n           // -- Log global + transaction log --\n           Logger.info('end()', api, dres, res);\n           self.logger.info('end()', api, dres, res);\n\n           // -- walk response for top-level entity response assignment --        \n           if (entities) { dres = dres.deployr.response[entities] || dres; }\n\n           dres.get = function(key) { \n              return utils.get(dres.deployr.response, key); \n           };\n\n           dres.workspace = function(name) { \n              return utils.workspace(dres.deployr.response, name); \n           };\n\n           // -- callback --\n           if (fn) { args = fn.apply(self.scope, [dres, responseChain]);}\n\n           // -- notify that the queue has been drained... --\n           if (q.size() === 0) { \n             self._clear();\n             self.deferred.resolve(responseChain || dres);\n           }          \n\n           // -- include cookies in next request in the queue --\n           args = merge(args, { __cookies__: self.cookies });          \n        }        \n\n        q.yield(false);\n        q.flush(dres, error, args); // pass result|error|args to next \n      });\n\n      q.yield(true);\n    }, this, this.delayed);\n  \n    if (!this.delayed && q.size() <= 1) { q.flush(); }\n\n    return this;\n  }, \n\n  /** \n   * Add an additional IO request to the exsisting sequential request chain.\n   *\n   * @method io\n   * @param {String} api One of the supported DeployR APIs.\n   * @return {DeployR} for chaining.\n   * @api public\n   */   \n  io: function (api) {    \n    return DeployR.new(api, { \n      cookies: this.cookies, \n      queue: this.q, \n      deferred: this.deferred\n    });\n  },\n\n  /** \n   * Convenience function for adding an additional script execution to the \n   * exsisting sequential request chain.\n   *\n   * @method script\n   * @param {Arguments} Arguments to define the fully qualified script for \n   * execution.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  script: function() {\n     var args = utils.signature(arguments),\n         opts = args.opts,\n         api  = args.api,\n         link = { \n          cookies: this.cookies, \n          queue: this.q, \n          deferred: this.deferred\n        };  \n\n    // convenience - if the project is a boolen `true` rather than a pid, first\n    // create a new project and then prepare the project api call to execute\n    if (args.create) {\n      return DeployR.new('/r/project/create', link)\n               .end(function(res) {\n                  return { project: res.get('project').project };\n                })\n               .io(api)\n               .data(opts);\n    } else {\n      return DeployR.new(api, link).data(opts);\n    }    \n  },\n\n  /** \n   * Convenience function for adding an additional repository-managed shell \n   * script execution to the exsisting sequential request chain.\n   *\n   * This call executes repository-managed shell scripts .sh, .csh, .bash, .bat \n   * on the DeployR server. Due to the special security concerns associated with \n   * excuting shell scripts on the DeployR server, only shell scripts owned by \n   * _ADMINISTRATOR_ users can be executed on this API call. Any attempt to \n   * execute a shell script stored in the repository that is not owned by an \n   * _ADMINISTRATOR_ user will be rejected.\n   *\n   * To execute a repository-managed shell script the caller must provide \n   * parameter values for _author_, _directory_, _filename_. This can be\n   * achieved by providing a fully qualified shell script \n   * `/<author>/<directory>/<filename>`, for example:\n   *\n   *  ```\n   *  .shell('/admin/external:public:admin/echo.sh', 'echo.sh args to pass.')\n   *  ```\n   *\n   * @method shell\n   * @param {String} filepath to define the fully qualified shell script for\n   * execution. \n   * @param {String} args (optional) arguments to be passed into the shell \n   * script on execution.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  shell: function(path, args) {   \n    var link = { \n          cookies: this.cookies, \n          queue: this.q, \n          deferred: this.deferred\n        },\n        tokens = Lang.isString(path) ? path.split('\\/') : [];\n\n    // handle both: `/author/directory/filename` & `author/directory/filename`\n    if (tokens.length > 3) { tokens = tokens.slice(1); }\n\n    return DeployR.new('/r/repository/shell/execute', link).data({\n      author: tokens[0],\n      directory: tokens[1],\n      filename: tokens[2],\n      args: args\n    });\n  },\n\n  /** \n   * Convenience function for executing a block of R code on the R session.\n\n   * Example:\n   *  ```\n   *  .code('x<-5')\n   *  // -- or --\n   *  .code('x<-5', projectId)\n   *  ```\n   *   \n   * @method code\n   * @param {String} r - The block of R code to execute.\n   * @param {String} project - (optional) if omitted a new project will first be \n   * created and used, otherwise it will execute on the R session identified by \n   * this `project`.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  code: function(r, project) {\n     var link = {\n             cookies: this.cookies,\n             queue: this.q,\n             deferred: this.deferred\n         },\n         api = '/r/project/execute/code';\n\n     if (!project) {\n         return DeployR.new('/r/project/create', link)\n             .end(function(res) {\n                 return { project: res.get('project').project };\n             })\n             .io(api)\n             .data({ code: r });\n     } else {\n         return DeployR.new(api, link).data({ code: r, project: project });\n     }\n  },\n  \n  /** \n   * Release any residual project resources associated with the application \n   * instance whenever a client application terminates. This includes closing \n   * any supplied projects down and logging out.\n   *\n   * @method release\n   * @param {String|Array} projects The project or list of projects to close.\n   * @param {Boolean} auth (optional) to remain authenticated.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  release: function(projects, auth) {\n     projects = Lang.isArray(projects) ? projects : [projects];\n\n     var self     = this,\n         deferred = D(),\n         empty    = !projects || !projects[0],\n         count    = 0,\n         last     = !empty ? projects.length - 1 : count,\n         cookies  = this.getCookies();           \n\n    function logout(index) {\n      if (index === last) {\n        if (!auth) {\n          DeployR.new('/r/user/logout')\n          .share(cookies)\n          .error(function() {          \n            deferred.reject(false);\n          })      \n          .end(function() { \n            deferred.resolve(true);\n          })\n          .ensure(function() {\n            self.destroy();\n          });\n        } else {\n          deferred.resolve(true);\n          self.destroy();\n        }\n      } \n    }\n\n    if (!empty) {\n      projects.forEach(function(project) {\n        DeployR.new('/r/project/close')\n        .data({ project: project })\n        .share(cookies)\n        .end()\n        .ensure(function() {\n          logout(count);\n          count++;\n        });\n      });   \n    } else {\n      logout(count);\n    }\n\n    return deferred.promise;  \n  },  \n\n  /** \n   * A convenience alternative to multiple `.rinput()` calls. Defines a name \n   * list of R objects that will be returned as DeployR-encoded R objects on the \n   * response markup.\n   *\n   * Calling this method ~.routputs([ ... ])` is equivalent to invoking multiple \n   * `.routput(...)` calls.\n   *\n   * @method routputs\n   * @param {Array} robjects A name list of R objects that will be returned.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  routputs: function (routputs) {\n    if (routputs) { this.outputs = this.outputs.concat(routputs); }\n\n    return this;\n  },\n  \n  /** \n   * Defines the name of the R object that will be returned as a DeployR-encoded \n   * R object on the response markup.\n   *\n   * @method routput\n   * @param {String} robject The name of the R object that will be returned.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  routput: function (routput) {\n    if (routput) { this.routputs([routput]); }\n\n    return this;\n  },\n\n  /** \n   * Used to pass multiple inputs at once from JavaScript to an R script using \n   * one of the defined `RInput` factories.\n   *\n   * @method rinputs\n   * @param {Array} rinputs The `RInput` list of DeployR-specific encoded R \n   * object data for use on an API call.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  rinputs: function (rinputs) {\n    if (rinputs) { this.inputs = this.inputs.concat(rinputs); }\n\n    return this;\n  },\n\n  /** \n   * Used to pass multiple inputs at once from JavaScript to an R script using \n   * one of the defined `RInput` factories.\n   *\n   * @method rinput\n   * @param {RInput} rinput The DeployR-specific encoded R object data for use \n   * on an API call.   \n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  rinput: function (rinput) {\n    if (rinput) { this.inputs.push(rinput); }\n\n    return this;\n  },\n\n  /**\n   * Destroy lifecycle method. Fires the `destroy` event, prior to invoking \n   * destructors for the class hierarchy. Called internally when `.release()`\n   * is called.\n   *\n   * @method destroy\n   * @api public   \n   */\n  destroy: function () {\n    try {\n      this.emit('destroy');\n      this.offAll();\n    \n      for (var key in this) {\n        if (this.hasOwnProperty(key)) { \n          this[key] = null; \n          delete this[key];\n        }\n      }\n    } catch(err) {}\n  },  \n\n  // --------------------------------------------------------------------------\n  // Private methods\n  // --------------------------------------------------------------------------\n\n  /**\n   * @api private\n   */\n  _clear: function() {    \n    this.params   = {};\n    this.inputs   = [];\n    this.outputs  = [];\n    this.rstream  = false;\n    this.delayed  = false;\n    this.api      = null;    \n    this.file     = null;  \n    this.entities = null;\n    this.ioFilter = null;\n  }, \n\n  /**\n   * @api private\n   */\n  _prepRequest: function (responseChain, args) {\n    var req  = this.req,\n        file = this.file;\n\n    // set the request type    \n    if (this.api.upload) {\n       // If the env is the Browser there is no need to manually set the\n       // Content-Type. The browser will automatically set the \n       // \"multipart/form-data; boundary=...\" value. If the env is Node we need\n       // to set it manually.\n       if (!win) { this.req.type('multipart/form-data'); }    \n    } else {\n      req.type('form');\n    }    \n\n    req.on('error', function(err) { \n      err = err || {  code: 'UNKNOWN CODE', text: 'UNKNOWN ERROR' };\n\n      this._handleError({ \n        status: err.code || 'UNKNOWN CODE',\n        text: err\n      });\n    }.bind(this));    \n\n    this.share(args ? args.__cookies__ : null);\n\n    // arguments returned from prev request's io().end(function() { return x; })\n    if (args) { \n       this.data(args);\n    } \n\n    if (this.inputs.length > 0) { \n      this.data({ inputs: encoder.encode(this.inputs) }); \n    }\n  \n    if (this.outputs.length > 0) { \n      this.data({ robjects: this.outputs.join() }); \n    }    \n\n    if (this.cookies) {     \n      this.cookies.forEach( function(c) { req.set('Cookie', c); });\n    }\n\n    if (this.api.upload) {    \n      for(var p in this.params) {\n        req.field(p, (this.params[p] || this.params[p] === false) ? \n           this.params[p] + '' : '');\n      } \n      req.attach('file', this.rstream ? fs.createReadStream(file) : file);\n    } else {\n      req[this.api.method === 'GET' ? 'query' : 'send'](this.params);\n    } \n  },\n\n  /**\n   * @api private\n   */\n  _handleError: function (raw) {\n    var stat  = raw.status,\n        res   = (raw.body && raw.body.deployr ? raw.body : raw),\n        error = ((stat !== 200) || res.deployr && !res.deployr.response.success);\n\n    // -- Handle errors --\n    if (error) {\n      res = {\n        get: function(key) { \n          return utils.get(this.deployr.response, key); \n        },\n        deployr: {          \n          response: {\n            success: false,\n            call: this.api['call'],\n            errorCode: res.deployr ? res.deployr.response.errorCode : stat,\n            error: res.deployr ? res.deployr.response.error : res.text\n          }\n        }\n      };\n\n      Logger.error('error()', this.api, res, raw);\n      this.logger.error('error()', this.api, res, raw);\n\n      // -- notify global errors first (if any) for this call --      \n      if (this.globalEvts) {\n        raiseGlobalErrors(this.api['call'], res);        \n      }\n\n      // -- tranaction level HTTP or DeployR errors come next --    \n      this.emit('error', res);\n      this.emit('deployr-io:' + res.deployr.response.errorCode, res);\n      this.deferred.reject(res);\n    }\n\n    return error;\n  }\n});\n\n/*****************************************************************************/\n/*****************************************************************************/\n/*****************************************************************************/\n\n// Include the `deprecated` jsDeployR for now.\nif (win) {\n  window.Revolution = window.Revolution || require('./lib/deprecated');\n}\n\n/*****************************************************************************/\n/*****************************************************************************/\n/*****************************************************************************/\n\n/**\n * Expose for a cleaner client api into DeployR\n */\nmodule.exports = {\n\n  /**\n   * Exposes the `DeployR` object for extending.\n   *\n   * ```var DeployR = require('deployr').DeployR;```\n   *\n   * @static\n   * @api public\n   * @return {DeployR} The `DeployR` object.\n   */   \n  DeployR: DeployR,\n\n  /**\n   * Exposes the supported DeployR APIs.\n   *\n   * @method apis\n   * @param {Boolean} flat (optional) if `true` will return an array of just the \n   * API's endpoint properties, for example: \n   * ```\n   * ['/r/user/login', '/r/user/logout', '/r/user/about', ...]\n   * ```\n   * @static\n   * @api public\n   * @return {Object|Array} The HTTP request to the DeployR server.      \n   */  \n  apis: function(flat) {\n    return flat ? Object.keys(apis) : apis;\n  },\n\n  /**\n   * Represents a static method for configuring all DeployR requests. Settings \n   * made here are applied globally across every request.\n   *\n   * @method configure\n   * @param {Object} options The object literal configuration hash. \n   * @static\n   * @chainable\n   * @api public\n   */\n  configure: function(options) {\n    options = options || {};\n\n    for (var i in options) { globalOptions.set(i, options[i]); }\n\n    // assert global cookies are empty if global `sticky` jsessionid is off\n    if (!globalOptions.sticky)  { globalOptions.set('cookies', null); }\n\n    // turn global logging on|off (off by default)\n    Logger.setLevel(globalOptions.logging ? Logger.DEBUG : Logger.OFF);\n\n    return this;\n  },\n\n  /**\n   * Factory for creating new IO requests to `DeployR`.\n   *\n   * Example:\n   * ```   \n   *    deployr.io('/r/user/about').end(callback);\n   * ```\n   *\n   * @method io\n   * @param {String} api One of the supported DeployR APIs.\n   * @static\n   * @return {DeployR} The HTTP request to the DeployR server.\n   * @api public   \n   */\n  io: function(api) {  \n    return DeployR.new(api);\n  },\n\n  /**\n   * Convenience function to sign the user in by authenticating the credentials \n   * with the DeployR server.   \n   *\n   * @method auth\n   * @param {String} username Specifies the username.\n   * @param {String} password Specifies the password.\n   * @static\n   * @return {DeployR} The HTTP request to the DeployR server.   \n   * @api public   \n   */   \n  auth: function(un, pw) {\n    var data = { username: un, password: pw };\n    return DeployR.new('/r/user/login').data(data).end();    \n  },\n\n  /**\n   * Convenience function to sign the user in by authenticating the credentials \n   * with the DeployR server.   \n   *\n   * Example:\n   * ```\n   *    deployr.script('/testuser/root/reduce.R')\n   *    deployr.script({ filename: 'reduce.R', author: 'testuser',\n   *                     directory: 'root'})\n   *    deployr.script('reduce.R', 'testuser', 'root')\n   *    deployr.script('/testuser/root/reduce.R', project)     \n   * ```   \n   *\n   * @method script\n   * @param {Arguments} arguments Arguments to define the fully qualified script \n   * for execution.\n   * @static\n   * @return {DeployR} The HTTP request to the DeployR server.   \n   * @api public   \n   */     \n  script: function() {\n    var args = utils.signature(arguments),\n        opts = args.opts,\n        api  = args.api;  \n\n    // convenience - if the project is a boolen `true` rather than a pid, first\n    // create a new project and then prepare the project api call to execute\n    if (args.create) {\n      return DeployR.new('/r/project/create')\n               .end(function(res) {\n                  return { project: res.get('project').project };\n                })\n               .io(api)\n               .data(opts);\n    } else {\n      return DeployR.new(api).data(opts);\n    }\n  },  \n\n  /**\n   * Run an series of chained DeployR requests in sequence and without overlap.       \n   *\n   * @method pipline\n   * @param {Array} tasks Specifies the list of `Function` tasks.\n   * @static\n   * @return {Promise} A promise wrapping the resolution of either \"resolve\" or\n   * \"reject\" callback.\n   * @api public   \n   */\n  pipeline: function(chains) {      \n    var deployr  = this,\n        deferred = D(),\n        q        = new Queue(),\n        results  = [],\n        errors   = [],\n        NOOP     = null, // NOOP errors|results for [a] batch request chain\n        orig     = {\n          sticky: globalOptions.sticky,\n          cookies: globalOptions.cookies\n        };\n\n    // make a copy\n    chains = chains.slice(0);\n\n    // turn sticky session for these request (hacky)\n    deployr.configure( { sticky: true });\n\n    function add() {\n      q.add(function() { \n        chains.shift().drain()\n        .then(function(chain) {\n          results.push(chain);  \n          errors.push(NOOP);           \n          if (q.isEmpty()) { \n            deployr.configure(orig); // reset\n            deferred.resolve({ results: results, errors: errors }); \n          }  \n\n          q.take();\n        }, function(err) {          \n          results.push(NOOP); \n          errors.push(err);\n          // rejections are only met when they [all] fail\n          if (q.isEmpty() && results.length === 0) { \n            deployr.configure(orig); // reset\n            deferred.reject(errors); \n          }  \n          q.take();\n        });       \n      }, null, true);\n    }\n\n    // convert to a seq queue for better handling\n    for(var i = 0; i < chains.length; i++) { add(); }\n\n    // start: dequeue first item and run it\n    q.take();\n\n    return deferred.promise;\n  },\n\n  /**\n   * The event stream API is unique within the DeployR API as it supports push \n   * notifications from the DeployR server to client applications. Notifications \n   * correspond to discrete events that occur within the DeployR server. There \n   * are four distinct event categories:\n   * \n   * - Stream Lifecycle events\n   * - Execution events\n   * - Job Lifecycle events\n   * - Management events\n   *\n   * Example:\n   * ```\n   * deployr.es({ username: 'testuser', password: 'secret' })\n   *    // -- connection choices for event types --\n   *    .management()  //.session() | .all() | .project(id) | .job(id)\n   *    .on('es:gridHeartbeat', function(data) {\n   *        console.log('===================');\n   *        console.log('es:gridHeartbeat');\n   *        console.log('===================');          \n   *     })\n   *     .open();\n   * ```\n   * \n   * @method es\n   * @param {Object} options The object literal configuration hash. \n   * @static\n   * @return {EventStream} a new `EventStream` for binding.\n   * @api public   \n   */  \n  es: function(options) {    \n    var stream = EventStream.new(globalOptions.host, options);\n\n    if (options && options.username && options.password) {\n      var ruser = this.auth(options.username, options.password);\n      ruser.ensure(function() { \n        stream.share(ruser.getCookies());\n        stream.flush(); \n      });\n    }\n\n    return stream;\n  },\n\n  /**\n   * Defines the factory for creating a DeployR-specific encoded R object to be \n   * sent as input parameters to an R script.\n   *\n   * Example:\n   * ```\n   *    var rinput = deployr.RInput.logical('logical_name', true);\n   *    var rinput = deployr.RInput.numeric('numeric_name', 10.5);\n   *    var rinput = deployr.RInput.integer('integer_name', 5);\n   *    var rinput = deployr.RInput.character('character_name', 'Hello');\n   *    // ect...\n   * ```\n   * @property RInput\n   * @static\n   * @api public\n   */\n  RInput: {\n    numeric: function (name, value) {\n      return RInput.new(name, value).numeric();\n    },\n\n    integer: function (name, value) {\n      return RInput.new(name, value).integer();\n    },\n\n    logical: function (name, value) {\n      return RInput.new(name, value).logical();\n    },\n\n    character: function (name, value) {\n      return RInput.new(name, value).character();\n    },\n\n    date: function (name, value) {\n      return RInput.new(name, value).date();\n    },\n\n    posixct: function (name, value) {\n      return RInput.new(name, value).posixct();\n    },  \n\n    numericVector: function(name, value) {\n      return RInput.new(name, value).numericVector();\n    }, \n\n    integerVector: function (name, value) {\n      return RInput.new(name, value).integerVector();\n    },\n\n    logicalVector: function (name, value) { \n      return RInput.new(name, value).logicalVector();\n    },\n\n    characterVector: function (name, value) { \n      return RInput.new(name, value).characterVector();\n    },  \n\n    dateVector: function (name, value) { \n      return RInput.new(name, value).dateVector();\n    },  \n\n    posixctVector: function (name, value) { \n      return RInput.new(name, value).posixctVector();\n    },\n\n    list: function (name, value) {\n      return RInput.new(name, value).list(); \n    },\n\n    dataframe: function (name, value) { \n      return RInput.new(name, value).dataframe();\n    },\n  \n    factor: function (name, value, levels, labels) {\n      var opts = { levels: levels, labels: labels };\n      return RInput.new(name, value, opts).factor();\n    },\n\n    ordered: function (name, value, levels, labels) {\n      var opts = { levels: levels, labels: labels };\n      return RInput.new(name, value, opts).ordered();\n    },\n\n    numericMatrix: function (name, value) { \n      return RInput.new(name, value).numericMatrix();\n    },\n\n    integerMatrix: function (name, value) { \n      return RInput.new(name, value).integerMatrix();\n    },\n\n    logicalMatrix: function (name, value) { \n      return RInput.new(name, value).logicalMatrix();\n    },\n\n    characterMatrix: function (name, value) {\n      return RInput.new(name, value).characterMatrix();\n    }\n  }\n};\n}).call(this,require('_process'))\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["deployr.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["/*!\n * Copyright (C) 2010-2015 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nvar win         = (typeof window !== 'undefined'),   \n    request     = require('superagent'),\n    D           = require('d.js'),\n    fs          = require('fs'),\n    apis        = require('./apis.json'), \n    EventStream = require('./lib/es'),\n    utils       = require('./lib/utils'),\n    Lang        = require('./lib/lang'),   \n    Logger      = require('./lib/logger'),   \n    Queue       = require('./lib/queue'),\n    Emitter     = require('./lib/emitter'),\n    encoder     = require('./lib/encoder'),\n    Base        = require('./lib/selfish').Base,\n    RInput      = require('./lib/rinput'),    \n    RInputs     = require('./lib/rinputs'),\n    merge       = utils.merge;\n\n/*\n * Turn global logging off by default\n */\nLogger.setLevel(Logger.OFF);\n\n/*\n * Global options that persist through all DeployR requests.\n */\nvar globalOptions = { \n  cors: false,\n  logging: false,\n  sticky: false,\n  cookies: null,\n  host: '',\n  allowSelfSignedSSLCert: false,\n  maxRequests: null, // no socket pooling in http.Agent\n  events:{},\n  set: function(prop, value) { \n    if (prop !== 'set') { \n      if (prop === 'host' && value) {         \n         // Be more forgiving on the entered DeployR 'endpoint':\n         //   - http(s)://dhost:port\n         //   - http(s)://dhost:port/deployr\n         //   - dhost:port\n         //   - dhost:port/deployr         \n         value = value.replace(/\\/*$|\\/*deployr\\/*$/, '');\n         value = (new RegExp('^(http|https)://', 'i')).test(value) ? value : \n            'http://' + value;\n      }\n\n      this[prop] = value; \n    } \n  }\n};\n\n/*\n * The top-level DeployR API response entities.\n */\nvar TOPLEVEL_ENTITIES = [\n  'user', \n  'project', \n  'workspace', \n  'execution', \n  'directory', \n  'repository', \n  'packages' \n];\n\n/*\n * Notify global IO error events accessible by all subscribers across requests.\n */\nfunction raiseGlobalErrors(api, res) {\n  var code    = res.deployr ? res.deployr.response.errorCode : res.status,\n      context = this;\n\n  // -- global events if provided --\n  if (globalOptions.events) {\n    if (!res.deployr) {\n      res = res.text;\n    }\n\n    context = globalOptions.events.ctx || context;\n\n    // -- general global failure --\n    if (globalOptions.events.error) {\n      globalOptions.events.error.apply(context, [api, res]);\n    }\n\n    // -- HTTP or DeployR global errors --    \n    if (globalOptions.events[code]) {\n      globalOptions.events[code].apply(context, [api, res]);\n    }\n  }\n}\n\n/**\n * The `DeployR` request class is a utility that brokers HTTP requests through a \n * simplified fluid interface to DeployR.\n *\n * @module deployr\n * @for deployr\n */\nvar DeployR = Base.extend(Emitter, RInputs, {\n\n  /**\n   * The `DeployR` Request class is a utility that brokers HTTP requests through \n   * a simplified fluid interface to DeployR.\n   * \n   * @class \n   * @constructor\n   * @param {String} api The DeployR API\n   * @param {Object} link The object literal containing the previous request.\n   * @api private\n   */\n  initialize: function initialize(api, link) {\n     Emitter.initialize.call(this, {});\n  \n     var opts = globalOptions;\n\n     if (!apis[api]) { throw new Error('Invalid API \"' + api + '\"'); }\n    \n     this.api        = merge({ 'call': api }, apis[api]);    \n     this.link       = link || {};\n     this.q          = this.link.queue || new Queue();\n     this.deferred   = this.link.deferred || D();\n     this.cookies    = this.link.cookies;\n     this.logger     = Logger.get(api, Logger.OFF); // transaction-level logging\n     this.params     = {};\n     this.inputs     = []; // rinputs list \n     this.outputs    = []; // routput object list\n     this.rstream    = false;\n     this.delayed    = false;\n     this.globalEvts = true; // suppress|raise global events fot this `io`     \n     this.file       = null; \n     this.entities   = null; \n     this.ioFilter   = function() { return true; };\n\n     // preset deployr's assigned response format for `this` api\n     this.data({ format: this.api.format });\n\n     // wrap superagent for the heavy lifting     \n     this.req = \n        request[this.api.method.toLowerCase()](opts.host + '/deployr' + api);\n     this.req.timeout(20 * 60 * 1000); // default timeout --> 20 minutes\n\n     // All CORS deployr calls require sticky sessions\n     if (win && globalOptions.cors) { this.req.withCredentials(); }\n\n     // Node.js - access an SSL endpoint with self signed certs for testing|dev\n     if (!win && globalOptions.allowSelfSignedSSLCert) {\n        process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';        \n     }\n  },\n\n  /**\n   * Binds the scope context for the configured `.end()` and `.error()` event    \n   * handler callbacks on this request.\n   *\n   * @method ctx\n   * @param {Object} context The `this` object for the configured `.end()` and\n   * `.error()` event handlers on this request.\n   * @api public   \n   */ \n  ctx: function (context) {\n    this.scope = context || this;\n\n    return this;\n  },\n\n  /**\n   * Suppress or raise global events for this `io` request.\n   *\n   * @method global\n   * @param {Boolean} raise `true` to raise global events, `false` to supress \n   * event firing globally.\n   * @return {DeployR} for chaining.\n   * @api public\n   */  \n  global: function(raise) {\n    this.globalEvts = Lang.isBoolean(raise) ? raise : this.globalEvts;\n\n    return this;\n  },  \n\n  /**\n   * Retrieve details about user.\n   *   \n   * @method about\n   * @return {Object} details about user otherwies `null`.\n   * @api public   \n   */\n  about: function() {\n    var response = this.req.res;\n\n    return this.api['call'] === '/r/user/login' && response ? \n           response.body.get('user') : null;\n  },  \n\n  /**\n   * Shares the cookies from a diffrent `.io()` agent to preserve session state\n   * across `this` request and all requests chained to it.\n   *\n   * @method share\n   * @return {DeployR} for chaining.\n   * @api public   \n   */  \n  share: function (cookies) {\n    if (globalOptions.sticky) {\n      if (globalOptions.cookies) {\n        this.cookies = globalOptions.cookies.slice(0); \n      } else {\n        if (cookies) { \n          this.cookies = cookies.slice(0); \n          globalOptions.set('cookies', this.cookies);\n        }\n      }\n    } else {\n      this.cookies = (cookies ? cookies.slice(0) : this.cookies);\n    }\n\n    return this;\n  },\n\n  /**\n   * Returns the HTTP cookie previously sent by the server with Set-Cookie.\n   * This value can be passed to `.share(ruser.getCookies())` of a diffrent\n   * `.io()` agent to preserve session state across requests.\n   *\n   * @method getCookies\n   * @return {Array} The HTTP cookie previously sent by the server with \n   * Set-Cookie.\n   * @api public   \n   */  \n  getCookies: function () {\n    return this.cookies;\n  }, \n\n  delay: function (ms) {\n    // TODO: support delayed requests based on ms for now this is just a pause.\n    this.delayed = !isNaN(parseFloat(ms)) && isFinite(ms) ? ms : true;\n\n    return this;\n  },   \n\n  /**\n   * Unwind the queue chain clearing requests that might have delays attached.\n   *\n   * @method drain\n   * @return {Promise} A promise wrapping the resolution of either \"resolve\" or\n   * \"reject\" callback.\n   * @api public   \n   */\n  drain: function () {\n    this.delayed = false;\n    this.q.flush(); \n\n    return this.deferred.promise;\n  },   \n\n  /**\n   * The `.promise()` method returns a dynamically generated Promise that is \n   * resolved once all DeployR `.io()` requests have ended.\n   *   \n   * @method promise\n   * @return {Promise} A promise wrapping the resolution of either \"resolve\" or\n   * \"reject\" callback.\n   * @api public\n   */     \n  promise: function () {\n    this.end();\n\n    return this.deferred.promise;\n  },\n\n  /**\n   * Abort the DeployR request.\n   *\n   * @method abort  \n   * @return {DeployR} for chaining.\n   * @api public\n   */  \n  abort: function () {\n    this.req.abort();\n    this.emit('abort');\n    this.deferred.reject(this._handleError({ \n        status: 'abort',\n        text: 'DeployR request aborted.'\n    }));\n\n    return this;\n  },\n\n /**\n  * Set timeout to `ms`.\n  *\n  * @method timeout  \n  * @param {Number} ms\n  * @return {DeployR} for chaining\n  * @api public\n  */  \n  timeout: function (ms) {\n    this.req.timeout(ms);\n\n    return this;\n  },\n\n /**\n  * Turn logging on for the specific transaction.\n  *\n  * @method log\n  * @return {DeployR} for chaining\n  * @api public\n  */ \n  log: function (level) {\n    this.logger.setLevel(level || Logger.DEBUG);\n\n    return this;\n  },\n\n  /**\n   * Filters successful responses to contain only a top-level DeployR API \n   * response entities:\n   * - 'user'\n   * - 'project'\n   * - 'workspace' \n   * - 'execution' \n   * - 'directory' \n   * - 'repository'\n   * - 'packages' \n   *   \n   * @method entity\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  entity: function (entity) {\n    this.entities = utils.inArray(TOPLEVEL_ENTITIES, entity);\n\n    return this;\n  },\n\n  /**\n   * Defines the request data being sent to a DeployR API. \n   *\n   * @method data\n   * @param {Object} data The object literal configuration hash. \n   * @return {DeployR} for chaining\n   * @api public\n   */\n  data: function (data) {\n    data = data || {};    \n\n    // remove any inlined rinput(s) and attach them to the rinput(s) property\n    if (data.rinput || data.rinputs) {\n      this.rinput(data.rinput);\n      this.rinputs(data.rinputs);\n    } \n\n    // remove any `reserved` values that could have been passed by mistake\n    var BLACKLIST = ['rinput', 'rinputs', '__cookies__'];\n    BLACKLIST.forEach(function(param) { delete data[param]; });  \n\n    this.params = merge(this.params, data);\n\n    return this;\n  },\n\n  /**\n   * Attaches a file to be uploaded. \n   *\n   * @method attach\n   * @param {File|Blob|path} file The file to be attached for an upload. For \n   * Browser environments the HTML5 File|Blob is used. For the Node.js \n   * environment, a file path is accepted.\n   * @param {String} filename (optional) the name of the file to be uploaded. \n   * This name does not have to match the actual source filename.\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  attach: function (file, filename) {\n    if (this.api.upload) {\n      this.file = file;\n\n      // optional filename here for convenience\n      if (filename) { this.data( { filename: filename } ); }\n    }\n\n    return this;\n  },\n\n  /**\n   * Supported only in Node.js, this method works in conjunction with the \n   * attach method to indicate that the file should be read in as a readable \n   * stream during a file upload.\n   *\n   * @method stream\n   * @param {Object} options (optional) the Readable Stream options hash.\n   *  ```\n   *    { flags: 'r',\n   *      encoding: null,\n   *      fd: null,\n   *      mode: 0666,\n   *      autoClose: true\n   *    }\n   * ```\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  stream: function () {\n    this.rstream = (!win && this.api.upload); //nodejs only\n\n    return this;\n  },\n\n  /**\n   * The `filter(λ)` method removes this DeployR request from the request chain\n   * if the provided function does *not* pass the test implemented by it.\n   *\n   * Examples:\n   *\n   * ```\n   * // Remove from the request chain\n   * .filter(function(args) {\n   *    return 5 > 10;\n   * })\n   *\n   * // Keep in the request chain\n   * .filter(function(args) {\n   *    return 10 > 5;\n   * })   \n   * ```\n   *\n   * @method filter\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining\n   * @api public   \n   */\n  filter: function(fn) {\n    if (fn) {\n      this.ioFilter = function(prevArgs) {\n        var args = {}, keep;\n\n        // copy over previous arguments and filter out internal __cookies__ \n        for (var key in prevArgs) {\n           if (key !== '__cookies__') { \n              args[key] = prevArgs[key];\n           }\n        }\n\n        keep = fn(args);\n        return (keep || keep === false ? keep : true);\n      };\n    }\n\n    return this;\n  },  \n  \n  /**\n   * Acts as a finally statement allowing you to execute \"cleanup\" type tasks \n   * in a request chain. It arranges for cleanup to be called, with no \n   * arguments, when the DeployR request chain is either completely fulfilled \n   * or rejected.\n   *\n   * @method ensure\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining\n   * @api public\n   */  \n  ensure: function (fn) {\n    this.deferred.promise.ensure(fn);\n\n    return this.deferred.promise;\n  },\n      \n  /**\n   * The general failure callback. If called, all DeployR errors for this \n   * transaction will be returned here when raised.\n   *\n   * @method error\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  error: function (fn) {\n    this.on('error', fn);\n\n    return this;\n  },\n\n  /**\n   * Stream the DeployR response into the pipe. It is important to note that if \n   * the `.pipe()` method is never called the request will not be sent.\n   *\n   * The `.pipe()` method should be be used as an alternative to `.end()` and \n   * never along side of it. `.pipe()` and `.end()` are an either-or.\n   *\n   * @method pipe\n   * @param {Stream} stream A destination Stream.\n   * @return {Stream} The passed in destination stream to be used for additional \n   * piping.\n   * @api public\n   */\n  pipe: function (dest) {\n    var q   = this.q,\n        api = this.api;        \n\n    q.add(function(responseChain, error, prevArgs) {    \n      // brake the call chain on error      \n      if (error) {        \n        this.deferred.reject(error);      \n        q.flush(responseChain, error, prevArgs); // drain the queue\n        this._clear();\n        return;\n      }\n      \n      this._prepRequest(responseChain, prevArgs);\n\n      Logger.info('pipe()', api, this.req);\n      this.logger.info('pipe()', api, this.req);   \n\n      var stream = this.req.pipe(dest);\n      q.yield(true);\n      stream.on('error', function () { });    \n      stream.on('end', function() { });     \n      stream.on('data', function() { });      \n    }, this);\n  \n    if (q.size() <= 1) { q.flush(); }\n\n    return dest;\n  },\n\n  /**\n   * Indicates that the request is ready to be sent to DeployR. It is important \n   * to note that if the `.end()` method is never called the request will not be\n   * sent.\n   *\n   * @method end\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining.\n   * @api public\n   */ \n  end: function (fn) {\n    var self     = this,\n        q        = this.q,\n        api      = this.api,\n        args     = null,\n        entities =  this.entities;\n\n    q.add(function(responseChain, error, prevArgs) {\n      // break the call chain on error      \n      if (error) {        \n        this.deferred.reject(error);        \n        q.flush(responseChain, error, prevArgs); // drain the queue\n        this._clear();\n        return;\n      }\n\n      //\n      if (!this.ioFilter(prevArgs)) {\n        if (q.size() === 0) { \n          this.deferred.resolve(responseChain || prevArgs);\n        }\n\n        q.flush(responseChain, error, prevArgs); // drain the queue\n        this._clear();\n        return;\n      }\n      \n      this._prepRequest(responseChain, prevArgs);\n\n      Logger.info('io()', api, this.req);\n      this.logger.info('io()', api, this.req);    \n\n      // send next request\n      this.req.end(function(res) {\n        self.share(self.cookies || res.headers['set-cookie']);         \n\n        // -- log cookies across requests --\n        if (self.cookies) {\n          Logger.info('cookies', api, self.cookies); \n          self.logger.info('cookies', api, self.cookies); \n        }\n\n        error = self._handleError(res);\n        var dres = (res.body && res.body.deployr ? res.body : res);             \n      \n        self.inputs = [];\n        self.outputs = [];\n\n        if (!error) {\n           // -- Log global + transaction log --\n           Logger.info('end()', api, dres, res);\n           self.logger.info('end()', api, dres, res);\n\n           // -- walk response for top-level entity response assignment --        \n           if (entities) { dres = dres.deployr.response[entities] || dres; }\n\n           dres.get = function(key) { \n              return utils.get(dres.deployr.response, key); \n           };\n\n           dres.workspace = function(name) { \n              return utils.workspace(dres.deployr.response, name); \n           };\n\n           // -- callback --\n           if (fn) { args = fn.apply(self.scope, [dres, responseChain]);}\n\n           // -- notify that the queue has been drained... --\n           if (q.size() === 0) { \n             self._clear();\n             self.deferred.resolve(responseChain || dres);\n           }          \n\n           // -- include cookies in next request in the queue --\n           args = merge(args, { __cookies__: self.cookies });          \n        }        \n\n        q.yield(false);\n        q.flush(dres, error, args); // pass result|error|args to next \n      });\n\n      q.yield(true);\n    }, this, this.delayed);\n  \n    if (!this.delayed && q.size() <= 1) { q.flush(); }\n\n    return this;\n  }, \n\n  /** \n   * Add an additional IO request to the exsisting sequential request chain.\n   *\n   * @method io\n   * @param {String} api One of the supported DeployR APIs.\n   * @return {DeployR} for chaining.\n   * @api public\n   */   \n  io: function (api) {    \n    return DeployR.new(api, { \n      cookies: this.cookies, \n      queue: this.q, \n      deferred: this.deferred\n    });\n  },\n\n  /** \n   * Convenience function for adding an additional script execution to the \n   * exsisting sequential request chain.\n   *\n   * @method script\n   * @param {Arguments} Arguments to define the fully qualified script for \n   * execution.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  script: function() {\n     var args = utils.signature(arguments),\n         opts = args.opts,\n         api  = args.api,\n         link = { \n          cookies: this.cookies, \n          queue: this.q, \n          deferred: this.deferred\n        };  \n\n    // convenience - if the project is a boolen `true` rather than a pid, first\n    // create a new project and then prepare the project api call to execute\n    if (args.create) {\n      return DeployR.new('/r/project/create', link)\n               .end(function(res) {\n                  return { project: res.get('project').project };\n                })\n               .io(api)\n               .data(opts);\n    } else {\n      return DeployR.new(api, link).data(opts);\n    }    \n  },\n\n  /** \n   * Convenience function for adding an additional repository-managed shell \n   * script execution to the exsisting sequential request chain.\n   *\n   * This call executes repository-managed shell scripts .sh, .csh, .bash, .bat \n   * on the DeployR server. Due to the special security concerns associated with \n   * excuting shell scripts on the DeployR server, only shell scripts owned by \n   * _ADMINISTRATOR_ users can be executed on this API call. Any attempt to \n   * execute a shell script stored in the repository that is not owned by an \n   * _ADMINISTRATOR_ user will be rejected.\n   *\n   * To execute a repository-managed shell script the caller must provide \n   * parameter values for _author_, _directory_, _filename_. This can be\n   * achieved by providing a fully qualified shell script \n   * `/<author>/<directory>/<filename>`, for example:\n   *\n   *  ```\n   *  .shell('/admin/external:public:admin/echo.sh', 'echo.sh args to pass.')\n   *  ```\n   *\n   * @method shell\n   * @param {String} filepath to define the fully qualified shell script for\n   * execution. \n   * @param {String} args (optional) arguments to be passed into the shell \n   * script on execution.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  shell: function(path, args) {   \n    var link = { \n          cookies: this.cookies, \n          queue: this.q, \n          deferred: this.deferred\n        },\n        tokens = Lang.isString(path) ? path.split('\\/') : [];\n\n    // handle both: `/author/directory/filename` & `author/directory/filename`\n    if (tokens.length > 3) { tokens = tokens.slice(1); }\n\n    return DeployR.new('/r/repository/shell/execute', link).data({\n      author: tokens[0],\n      directory: tokens[1],\n      filename: tokens[2],\n      args: args\n    });\n  },\n\n  /** \n   * Convenience function for executing a block of R code on the R session.\n\n   * Example:\n   *  ```\n   *  .code('x<-5')\n   *  // -- or --\n   *  .code('x<-5', projectId)\n   *  ```\n   *   \n   * @method code\n   * @param {String} r - The block of R code to execute.\n   * @param {String} project - (optional) if omitted a new project will first be \n   * created and used, otherwise it will execute on the R session identified by \n   * this `project`.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  code: function(r, project) {\n     var link = {\n             cookies: this.cookies,\n             queue: this.q,\n             deferred: this.deferred\n         },\n         api = '/r/project/execute/code';\n\n     if (!project) {\n         return DeployR.new('/r/project/create', link)\n             .end(function(res) {\n                 return { project: res.get('project').project };\n             })\n             .io(api)\n             .data({ code: r });\n     } else {\n         return DeployR.new(api, link).data({ code: r, project: project });\n     }\n  },\n  \n  /** \n   * Release any residual project resources associated with the application \n   * instance whenever a client application terminates. This includes closing \n   * any supplied projects down and logging out.\n   *\n   * @method release\n   * @param {String|Array} projects The project or list of projects to close.\n   * @param {Boolean} auth (optional) to remain authenticated.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  release: function(projects, auth) {\n     projects = Lang.isArray(projects) ? projects : [projects];\n\n     var self     = this,\n         deferred = D(),\n         empty    = !projects || !projects[0],\n         count    = 0,\n         last     = !empty ? projects.length - 1 : count,\n         cookies  = this.getCookies();           \n\n    function logout(index) {\n      if (index === last) {\n        if (!auth) {\n          DeployR.new('/r/user/logout')\n          .share(cookies)\n          .error(function() {          \n            deferred.reject(false);\n          })      \n          .end(function() { \n            deferred.resolve(true);\n          })\n          .ensure(function() {\n            self.destroy();\n          });\n        } else {\n          deferred.resolve(true);\n          self.destroy();\n        }\n      } \n    }\n\n    if (!empty) {\n      projects.forEach(function(project) {\n        DeployR.new('/r/project/close')\n        .data({ project: project })\n        .share(cookies)\n        .end()\n        .ensure(function() {\n          logout(count);\n          count++;\n        });\n      });   \n    } else {\n      logout(count);\n    }\n\n    return deferred.promise;  \n  },  \n\n  /** \n   * A convenience alternative to multiple `.rinput()` calls. Defines a name \n   * list of R objects that will be returned as DeployR-encoded R objects on the \n   * response markup.\n   *\n   * Calling this method ~.routputs([ ... ])` is equivalent to invoking multiple \n   * `.routput(...)` calls.\n   *\n   * @method routputs\n   * @param {Array} robjects A name list of R objects that will be returned.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  routputs: function (routputs) {\n    if (routputs) { this.outputs = this.outputs.concat(routputs); }\n\n    return this;\n  },\n  \n  /** \n   * Defines the name of the R object that will be returned as a DeployR-encoded \n   * R object on the response markup.\n   *\n   * @method routput\n   * @param {String} robject The name of the R object that will be returned.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  routput: function (routput) {\n    if (routput) { this.routputs([routput]); }\n\n    return this;\n  },\n\n  /** \n   * Used to pass multiple inputs at once from JavaScript to an R script using \n   * one of the defined `RInput` factories.\n   *\n   * @method rinputs\n   * @param {Array} rinputs The `RInput` list of DeployR-specific encoded R \n   * object data for use on an API call.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  rinputs: function (rinputs) {\n    if (rinputs) { this.inputs = this.inputs.concat(rinputs); }\n\n    return this;\n  },\n\n  /** \n   * Used to pass multiple inputs at once from JavaScript to an R script using \n   * one of the defined `RInput` factories.\n   *\n   * @method rinput\n   * @param {RInput} rinput The DeployR-specific encoded R object data for use \n   * on an API call.   \n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  rinput: function (rinput) {\n    if (rinput) { this.inputs.push(rinput); }\n\n    return this;\n  },\n\n  /**\n   * Destroy lifecycle method. Fires the `destroy` event, prior to invoking \n   * destructors for the class hierarchy. Called internally when `.release()`\n   * is called.\n   *\n   * @method destroy\n   * @api public   \n   */\n  destroy: function () {\n    try {\n      this.emit('destroy');\n      this.offAll();\n    \n      for (var key in this) {\n        if (this.hasOwnProperty(key)) { \n          this[key] = null; \n          delete this[key];\n        }\n      }\n    } catch(err) {}\n  },  \n\n  // --------------------------------------------------------------------------\n  // Private methods\n  // --------------------------------------------------------------------------\n\n  /**\n   * @api private\n   */\n  _clear: function() {    \n    this.params   = {};\n    this.inputs   = [];\n    this.outputs  = [];\n    this.rstream  = false;\n    this.delayed  = false;\n    this.api      = null;    \n    this.file     = null;  \n    this.entities = null;\n    this.ioFilter = null;\n  }, \n\n  /**\n   * @api private\n   */\n  _prepRequest: function (responseChain, args) {\n    var req  = this.req,\n        file = this.file;\n\n    // set the request type    \n    if (this.api.upload) {\n       // If the env is the Browser there is no need to manually set the\n       // Content-Type. The browser will automatically set the \n       // \"multipart/form-data; boundary=...\" value. If the env is Node we need\n       // to set it manually.\n       if (!win) { this.req.type('multipart/form-data'); }    \n    } else {\n      req.type('form');\n    }    \n\n    req.on('error', function(err) { \n      err = err || {  code: 'UNKNOWN CODE', text: 'UNKNOWN ERROR' };\n\n      this._handleError({ \n        status: err.code || 'UNKNOWN CODE',\n        text: err\n      });\n    }.bind(this));    \n\n    this.share(args ? args.__cookies__ : null);\n\n    // arguments returned from prev request's io().end(function() { return x; })\n    if (args) { \n       this.data(args);\n    } \n\n    if (this.inputs.length > 0) { \n      this.data({ inputs: encoder.encode(this.inputs) }); \n    }\n  \n    if (this.outputs.length > 0) { \n      this.data({ robjects: this.outputs.join() }); \n    }    \n\n    if (this.cookies) {     \n      this.cookies.forEach( function(c) { req.set('Cookie', c); });\n    }\n\n    if (this.api.upload) {    \n      for(var p in this.params) {\n        req.field(p, (this.params[p] || this.params[p] === false) ? \n           this.params[p] + '' : '');\n      } \n      req.attach('file', this.rstream ? fs.createReadStream(file) : file);\n    } else {\n      req[this.api.method === 'GET' ? 'query' : 'send'](this.params);\n    } \n  },\n\n  /**\n   * @api private\n   */\n  _handleError: function (raw) {\n    var stat  = raw.status,\n        res   = (raw.body && raw.body.deployr ? raw.body : raw),\n        error = ((stat !== 200) || res.deployr && !res.deployr.response.success);\n\n    // -- Handle errors --\n    if (error) {\n      res = {\n        get: function(key) { \n          return utils.get(this.deployr.response, key); \n        },\n        deployr: {          \n          response: {\n            success: false,\n            call: this.api['call'],\n            errorCode: res.deployr ? res.deployr.response.errorCode : stat,\n            error: res.deployr ? res.deployr.response.error : res.text\n          }\n        }\n      };\n\n      Logger.error('error()', this.api, res, raw);\n      this.logger.error('error()', this.api, res, raw);\n\n      // -- notify global errors first (if any) for this call --      \n      if (this.globalEvts) {\n        raiseGlobalErrors(this.api['call'], res);        \n      }\n\n      // -- tranaction level HTTP or DeployR errors come next --    \n      this.emit('error', res);\n      this.emit('deployr-io:' + res.deployr.response.errorCode, res);\n      this.deferred.reject(res);\n    }\n\n    return error;\n  }\n});\n\n/*****************************************************************************/\n/*****************************************************************************/\n/*****************************************************************************/\n\n// Include the `deprecated` jsDeployR for now.\nif (win) {\n  window.Revolution = window.Revolution || require('./lib/deprecated');\n}\n\n/*****************************************************************************/\n/*****************************************************************************/\n/*****************************************************************************/\n\n/**\n * Expose for a cleaner client api into DeployR\n */\nmodule.exports = {\n\n  /**\n   * Exposes the `DeployR` object for extending.\n   *\n   * ```var DeployR = require('deployr').DeployR;```\n   *\n   * @static\n   * @api public\n   * @return {DeployR} The `DeployR` object.\n   */   \n  DeployR: DeployR,\n\n  /**\n   * Exposes the supported DeployR APIs.\n   *\n   * @method apis\n   * @param {Boolean} flat (optional) if `true` will return an array of just the \n   * API's endpoint properties, for example: \n   * ```\n   * ['/r/user/login', '/r/user/logout', '/r/user/about', ...]\n   * ```\n   * @static\n   * @api public\n   * @return {Object|Array} The HTTP request to the DeployR server.      \n   */  \n  apis: function(flat) {\n    return flat ? Object.keys(apis) : apis;\n  },\n\n  /**\n   * Represents a static method for configuring all DeployR requests. Settings \n   * made here are applied globally across every request.\n   *\n   * @method configure\n   * @param {Object} options The object literal configuration hash. \n   * @static\n   * @chainable\n   * @api public\n   */\n  configure: function(options) {\n    options = options || {};\n\n    for (var i in options) { globalOptions.set(i, options[i]); }\n\n    // assert global cookies are empty if global `sticky` jsessionid is off\n    if (!globalOptions.sticky)  { globalOptions.set('cookies', null); }\n\n    // turn global logging on|off (off by default)\n    Logger.setLevel(globalOptions.logging ? Logger.DEBUG : Logger.OFF);\n\n    return this;\n  },\n\n  /**\n   * Factory for creating new IO requests to `DeployR`.\n   *\n   * Example:\n   * ```   \n   *    deployr.io('/r/user/about').end(callback);\n   * ```\n   *\n   * @method io\n   * @param {String} api One of the supported DeployR APIs.\n   * @static\n   * @return {DeployR} The HTTP request to the DeployR server.\n   * @api public   \n   */\n  io: function(api) {  \n    return DeployR.new(api);\n  },\n\n  /**\n   * Convenience function to sign the user in by authenticating the credentials \n   * with the DeployR server.   \n   *\n   * @method auth\n   * @param {String} username Specifies the username.\n   * @param {String} password Specifies the password.\n   * @static\n   * @return {DeployR} The HTTP request to the DeployR server.   \n   * @api public   \n   */   \n  auth: function(un, pw) {\n    var data = { username: un, password: pw };\n    return DeployR.new('/r/user/login').data(data).end();    \n  },\n\n  /**\n   * Convenience function to sign the user in by authenticating the credentials \n   * with the DeployR server.   \n   *\n   * Example:\n   * ```\n   *    deployr.script('/testuser/root/reduce.R')\n   *    deployr.script({ filename: 'reduce.R', author: 'testuser',\n   *                     directory: 'root'})\n   *    deployr.script('reduce.R', 'testuser', 'root')\n   *    deployr.script('/testuser/root/reduce.R', project)     \n   * ```   \n   *\n   * @method script\n   * @param {Arguments} arguments Arguments to define the fully qualified script \n   * for execution.\n   * @static\n   * @return {DeployR} The HTTP request to the DeployR server.   \n   * @api public   \n   */     \n  script: function() {\n    var args = utils.signature(arguments),\n        opts = args.opts,\n        api  = args.api;  \n\n    // convenience - if the project is a boolen `true` rather than a pid, first\n    // create a new project and then prepare the project api call to execute\n    if (args.create) {\n      return DeployR.new('/r/project/create')\n               .end(function(res) {\n                  return { project: res.get('project').project };\n                })\n               .io(api)\n               .data(opts);\n    } else {\n      return DeployR.new(api).data(opts);\n    }\n  },  \n\n  /**\n   * Run an series of chained DeployR requests in sequence and without overlap.       \n   *\n   * @method pipline\n   * @param {Array} tasks Specifies the list of `Function` tasks.\n   * @static\n   * @return {Promise} A promise wrapping the resolution of either \"resolve\" or\n   * \"reject\" callback.\n   * @api public   \n   */\n  pipeline: function(chains) {      \n    var deployr  = this,\n        deferred = D(),\n        q        = new Queue(),\n        results  = [],\n        errors   = [],\n        NOOP     = null, // NOOP errors|results for [a] batch request chain\n        orig     = {\n          sticky: globalOptions.sticky,\n          cookies: globalOptions.cookies\n        };\n\n    // make a copy\n    chains = chains.slice(0);\n\n    // turn sticky session for these request (hacky)\n    deployr.configure( { sticky: true });\n\n    function add() {\n      q.add(function() { \n        chains.shift().drain()\n        .then(function(chain) {\n          results.push(chain);  \n          errors.push(NOOP);           \n          if (q.isEmpty()) { \n            deployr.configure(orig); // reset\n            deferred.resolve({ results: results, errors: errors }); \n          }  \n\n          q.take();\n        }, function(err) {          \n          results.push(NOOP); \n          errors.push(err);\n          // rejections are only met when they [all] fail\n          if (q.isEmpty() && results.length === 0) { \n            deployr.configure(orig); // reset\n            deferred.reject(errors); \n          }  \n          q.take();\n        });       \n      }, null, true);\n    }\n\n    // convert to a seq queue for better handling\n    for(var i = 0; i < chains.length; i++) { add(); }\n\n    // start: dequeue first item and run it\n    q.take();\n\n    return deferred.promise;\n  },\n\n  /**\n   * The event stream API is unique within the DeployR API as it supports push \n   * notifications from the DeployR server to client applications. Notifications \n   * correspond to discrete events that occur within the DeployR server. There \n   * are four distinct event categories:\n   * \n   * - Stream Lifecycle events\n   * - Execution events\n   * - Job Lifecycle events\n   * - Management events\n   *\n   * Example:\n   * ```\n   * deployr.es({ username: 'testuser', password: 'secret' })\n   *    // -- connection choices for event types --\n   *    .management()  //.session() | .all() | .project(id) | .job(id)\n   *    .on('es:gridHeartbeat', function(data) {\n   *        console.log('===================');\n   *        console.log('es:gridHeartbeat');\n   *        console.log('===================');          \n   *     })\n   *     .open();\n   * ```\n   * \n   * @method es\n   * @param {Object} options The object literal configuration hash. \n   * @static\n   * @return {EventStream} a new `EventStream` for binding.\n   * @api public   \n   */  \n  es: function(options) {    \n    var stream = EventStream.new(globalOptions.host, options);\n\n    if (options && options.username && options.password) {\n      var ruser = this.auth(options.username, options.password);\n      ruser.ensure(function() { \n        stream.share(ruser.getCookies());\n        stream.flush(); \n      });\n    }\n\n    return stream;\n  },\n\n  /**\n   * Defines the factory for creating a DeployR-specific encoded R object to be \n   * sent as input parameters to an R script.\n   *\n   * Example:\n   * ```\n   *    var rinput = deployr.RInput.logical('logical_name', true);\n   *    var rinput = deployr.RInput.numeric('numeric_name', 10.5);\n   *    var rinput = deployr.RInput.integer('integer_name', 5);\n   *    var rinput = deployr.RInput.character('character_name', 'Hello');\n   *    // ect...\n   * ```\n   * @property RInput\n   * @static\n   * @api public\n   */\n  RInput: {\n    numeric: function (name, value) {\n      return RInput.new(name, value).numeric();\n    },\n\n    integer: function (name, value) {\n      return RInput.new(name, value).integer();\n    },\n\n    logical: function (name, value) {\n      return RInput.new(name, value).logical();\n    },\n\n    character: function (name, value) {\n      return RInput.new(name, value).character();\n    },\n\n    date: function (name, value) {\n      return RInput.new(name, value).date();\n    },\n\n    posixct: function (name, value) {\n      return RInput.new(name, value).posixct();\n    },  \n\n    numericVector: function(name, value) {\n      return RInput.new(name, value).numericVector();\n    }, \n\n    integerVector: function (name, value) {\n      return RInput.new(name, value).integerVector();\n    },\n\n    logicalVector: function (name, value) { \n      return RInput.new(name, value).logicalVector();\n    },\n\n    characterVector: function (name, value) { \n      return RInput.new(name, value).characterVector();\n    },  \n\n    dateVector: function (name, value) { \n      return RInput.new(name, value).dateVector();\n    },  \n\n    posixctVector: function (name, value) { \n      return RInput.new(name, value).posixctVector();\n    },\n\n    list: function (name, value) {\n      return RInput.new(name, value).list(); \n    },\n\n    dataframe: function (name, value) { \n      return RInput.new(name, value).dataframe();\n    },\n  \n    factor: function (name, value, levels, labels) {\n      var opts = { levels: levels, labels: labels };\n      return RInput.new(name, value, opts).factor();\n    },\n\n    ordered: function (name, value, levels, labels) {\n      var opts = { levels: levels, labels: labels };\n      return RInput.new(name, value, opts).ordered();\n    },\n\n    numericMatrix: function (name, value) { \n      return RInput.new(name, value).numericMatrix();\n    },\n\n    integerMatrix: function (name, value) { \n      return RInput.new(name, value).integerMatrix();\n    },\n\n    logicalMatrix: function (name, value) { \n      return RInput.new(name, value).logicalMatrix();\n    },\n\n    characterMatrix: function (name, value) {\n      return RInput.new(name, value).characterMatrix();\n    }\n  }\n};"]}","module.exports={\n    \"/r/user/login\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/user/logout\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/user/about\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/user/autosave\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/user/release\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/create\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/pool\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/recycle\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/ping\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/about\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/about/update\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/save\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/saveas\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/close\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/grant\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/import\": {\n        \"method\": \"POST\",\n        \"format\": \"json\",\n        \"upload\": true\n    },\n\n    \"/r/project/export\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/code\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/script\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/interrupt\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/console\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/history\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/flush\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/result/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/result/download\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/result/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/get\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/upload\": {\n        \"method\": \"POST\",\n        \"format\": \"json\",\n        \"upload\": true\n    },\n\n    \"/r/project/workspace/transfer\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/push\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/save\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/store\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/load\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/upload\": {\n        \"method\": \"POST\",\n        \"format\": \"json\",\n        \"upload\": true\n    },\n\n    \"/r/project/directory/transfer\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/write\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/update\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/store\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/load\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/download\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/package/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/package/attach\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/package/detach\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/job/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/job/submit\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/job/schedule\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/job/query\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/job/cancel\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/job/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/create\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/rename\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/copy\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/move\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/update\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/script/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/script/execute\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/script/render\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/script/interrupt\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/shell/execute\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/archive\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/upload\": {\n        \"method\": \"POST\",\n        \"format\": \"json\",\n        \"upload\": true\n    },\n\n    \"/r/repository/directory/download\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/fetch\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/fetch\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/upload\": {\n        \"method\": \"POST\",\n        \"format\": \"json\",\n        \"upload\": true\n    },\n\n    \"/r/repository/file/transfer\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/write\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/update\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/diff\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/revert\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/grant\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/download\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/copy\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/move\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/server/info\": {\n        \"method\": \"GET\",\n        \"format\": \"json\"\n    }\n}\n","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more\n * details.\n */\nvar Lang = require('./lang'),\n    Base = require('./selfish').Base,\n    RInput = require('./rinput');\n\nvar Deprecated,\n    emitter,\n    _config = {},\n    TOPLEVEL_ENTITIES = [\n        'user',\n        'project',\n        'workspace',\n        'execution',\n        'directory',\n        'repository',\n        'packages'\n    ];\n\n/**********************************************************************/\n/**********************************************************************/\n/**********************************************************************/\n\nvar SessionManager = {\n    ENDPOINT_WHITELIST: {\n        login: '/r/user/login',\n        logout: '/r/user/logout',\n        projectCreate: '/r/project/create',\n        projectClose: '/r/project/close',\n        projectAboutUpdate: '/r/project/about/update',\n        projectSave: '/r/project/save',\n        projectSaveAs: '/r/project/saveas',\n        // --- private APIS ---\n        clientProjectSave: '/r/client/project/save',\n        clientProjectClose: '/r/client/project/close'\n    },\n\n    session: {},\n\n    config: {},\n\n    setUnloadConfig: function(config) {\n        config = config || {};\n        this.config = {\n            disableautosave: config.disableautosave || true,\n            dropworkspace: config.dropworkspace || true,\n            dropdirectory: config.dropdirectory || true,\n            drophistory: config.drophistory || true,\n            flushhistory: config.flushhistory || true\n        };\n    },\n    setSession: function(session) {\n        this.session = session;\n    },\n    setProject: function(project) {\n        this.session.project = project;\n    },\n    clearSession: function() {\n        this.session = {};\n    },\n    clearProject: function() {\n        this.session.project = null;\n    },\n    unloadHandler: function() {\n        try {\n            var project = this.session.project;\n            if (project) {\n\n                var data = this._config;\n                data.project = project.id;\n                data.projectcookie = project.cookie;\n\n                deployr.io('/r/project/close')\n                    .data(data)\n                    .sync()\n                    .end();\n            }\n        } catch (e) {\n            throw new Error(e);\n        }\n    }\n};\n\n/**********************************************************************/\n/**********************************************************************/\n/**********************************************************************/\n\nfunction format(response, transEntity) {\n    // -- transaction entity formats override global entity formats --  \n    //var format = transEntity || _config.entity;\n    var format = transEntity || globalConfig.entity;\n\n    if (format) {\n        var resObj = response.deployr.response,\n            // -- top-level entities --\n            entities = TOPLEVEL_ENTITIES;\n\n        for (var index = 0; index < entities.length; index++) {\n            var entity = entities[index];\n\n            if (resObj[entity] && format[entity]) { // response entity hit\n                // -- user-defined parse for top-level entity --                \n                if (format[entity].parser) {\n                    var formatScope = format[entity].scope || this;\n                    resObj[entity] = format[entity].parser.call(formatScope, resObj[entity]);\n                }\n            }\n        }\n    }\n\n    return response;\n}\n\nfunction changeEndpoint(response, endpoint, args) {\n\n    var resObj = response.deployr.response,\n        ENDPOINT = SessionManager.ENDPOINT_WHITELIST;\n\n    switch (endpoint) {\n\n        case ENDPOINT.login:\n\n            SessionManager.setSession({\n                httpcookie: resObj.httpcookie,\n                user: resObj.user,\n                limits: resObj.limits,\n                project: null\n            });\n            break;\n\n        case ENDPOINT.logout:\n            SessionManager.clearSession();\n            break;\n\n        case ENDPOINT.projectClose:\n        case ENDPOINT.clientProjectClose:\n            SessionManager.clearProject();\n            break;\n\n        case ENDPOINT.projectCreate:\n        case ENDPOINT.projectAboutUpdate:\n        case ENDPOINT.projectSave:\n        case ENDPOINT.projectSaveAs:\n        case ENDPOINT.clientProjectSave:\n            var project = resObj.project;\n            SessionManager.setProject({\n                id: project.project,\n                cookie: project.cookie\n            });\n            break;\n\n    } // end switch\n\n    Deprecated.Event.fire('DeployR:endpointChange', {\n        response: response,\n        endpoint: endpoint,\n        args: args\n    });\n}\n\n\nfunction camelCase(input) {\n    // convert format: '/r/user/login' --> 'userLogin'\n    input = input.replace('\\/r\\/', '');\n    return input.toLowerCase().replace(/\\/(.)/g, function(match, segment) {\n        return segment.toUpperCase();\n    });\n}\n\n// turn the old deprecated inputs into new inputs\nfunction normalizeInputs(inputs) {\n    var rinputs = [];\n\n    for (var i = 0; i < inputs.length; i++) {\n        rinputs.push(inputs[i].normalize());\n    }\n\n    return rinputs;\n}\n\n/**********************************************************************/\n/**********************************************************************/\n/**********************************************************************/\n\n/**\n * The Deprecated interface.\n */\nvar RData = Base.extend({\n    initialize: function(type, rclass, rinput) {\n        this.type = type;\n        this.rclass = rclass;\n        this.rinput = rinput;\n    },\n\n    getType: function() {\n        return this.type;\n    },\n\n    getRClass: function() {\n        return this.rclass;\n    },\n\n    getName: function() {\n        return this.rinput.name;\n    },\n\n    getValue: function() {\n        return this.rinput.value;\n    },\n\n    getLevels: function() {\n        return this.rinput.levels;\n    },\n\n    getLabels: function() {\n        return this.rinput.labels;\n    },\n\n    getOrdered: function() {\n        return this.rinput.ordered;\n    },\n\n    normalize: function() {\n        return this.rinput;\n    }\n});\n\n/**********************************************************************/\n/**********************************************************************/\n/**********************************************************************/\n\nfunction Emitter(obj) {  \n  \n}\n\nfunction debug(msg) {  \n}\n\nEmitter.prototype = {\n\n  events: {},\n\n  scope: null,\n\n  /**\n   * Adds a listener.  Multiple can be added per name.  Aliased as `on`.\n   *\n   * @param {String} name The name of the event\n   * @param {Function} handler A callback\n   */\n  on: function(name, handler) {\n    if (name in this.events === false) { this.events[name] = []; }        \n\n    this.events[name].push(handler);\n    debug('Emitter.on(\"' + name + '\")');\n\n    return this;\n  },\n\n  /**\n   * Triggers all matching listeners.\n   *\n   * @param {String} name The name of the event\n   * @returns {Boolean} `true` if an event fired\n   */\n  emit: function(name) {\n    if (name in this.events === false) { return this; }\n\n    for (var i = 0; i < this.events[name].length; i++) {\n      debug('Fired event: \"' + name + '\"');\n      this.events[name][i].apply(this.scope || this, Array.prototype.slice.call(arguments, 1));       \n    }\n\n    return this;\n  },\n\n  /**\n   * Removes all matching listeners.\n   *\n   * @param {String} name The name of the event\n   * @returns {Boolean} `true` if an event was removed\n   */\n  removeAllListeners: function(name) {\n    if (!name) {\n      for (var e in this.events) {\n        delete this.events[e];\n      }\n    } else {\n      if (name in this.events === false) { return this; }\n      delete this.events[name];        \n    }\n\n    return this;\n  },\n\n  removeListenerAt: function(name, index) {\n    var array = this.events[name],\n        rest = array.slice(index + 1);\n\n    array.length = index;\n    array.push.apply(array, rest);\n    this.events[name] = array;\n  },\n\n  /**\n   * Removes a listener based on the handler function.\n   *\n   * @param {String} name The name of the event\n   * @param {Function} handler The handler function to remove\n   * @returns {Boolean} `true` if an event was removed\n   */\n  off: function(name, handler) {\n    if (name in this.events === false) { return this; }\n\n    // remove all events handlers by this name\n    if (!handler) {\n      return this.removeAllListeners(name);\n    } else { // remove all events handlers == 'handler' by this name\n      for (var i = 0; i < this.events[name].length; i++) {\n        if (this.events[name][i] == handler) {\n          this.removeListenerAt(name, i);\n          return this;\n        }\n      }\n    } \n\n    return this;\n  }\n};\n\n\nemitter = new Emitter();\n\n/**\n * Provides simple adapter methods which wrap the raw <code>Revolution.DeployR.io(...)</code>\n * remote DeployR API AJAX transactions. These methods are an opt-in feature to\n * complement the low level DeployR IO communication.\n *\n * @class Revolution.DeployR.PublicAdapter\n * @extensionfor Revolution.DeployR\n */\n\nDeprecated = {\n    version: require('../package').version,\n\n    Event: {\n        on: function(type, fn, scope) {\n            emitter.on(type, fn, scope);\n        },\n\n        detach: function(type, fn, obj) {\n            emitter.off(type, fn);            \n        }\n    },\n\n    RDataFactory: {\n        createNumeric: function(name, value) {\n            return RData.new('primitive', 'numeric', RInput.new(name, value).numeric());\n        },\n\n        createInteger: function(name, value) {\n            return RData.new('primitive', 'integer', RInput.new(name, value).integer());\n        },\n\n        createBoolean: function(name, value) {\n            return RData.new('primitive', 'numeric', RInput.new(name, value).logical());\n        },\n\n        createString: function(name, value) {\n            return RData.new('primitive', 'character', RInput.new(name, value).character());\n        },\n\n        createDate: function(name, value) {\n            return RData.new('date', 'Date', RInput.new(name, value).date());\n        },\n\n        createPOSIXDate: function(name, value) {\n            return RData.new('date', 'POSIXct', RInput.new(name, value).posixct());\n        },\n\n        createNumericVector: function(name, value) {\n            return RData.new('vector', 'numeric', RInput.new(name, value).numericVector());\n        },\n\n        createIntegerVector: function(name, value) {\n            return RData.new('vector', 'integer', RInput.new(name, value).integerVector());\n        },\n\n        createBooleanVector: function(name, value) {\n            return RData.new('vector', 'logical', RInput.new(name, value).logicalVector());\n        },\n\n        createStringVector: function(name, value) {\n            return RData.new('vector', 'character', RInput.new(name, value).characterVector());\n        },\n\n        createDateVector: function(name, value) {\n            return RData.new('type', 'Date', RInput.new(name, value).dateVector());\n        },\n\n        createPOSIXDateVector: function(name, value) {\n            return RData.new('vector', 'POSIXct', RInput.new(name, value).posixctVector());\n        },\n\n        createList: function(name, value) {\n            return RData.new('list', 'list', RInput.new(name, value).list());\n        },\n\n        createDataframe: function(name, value) {\n            return RData.new('dataframe', 'data.frame', RInput.new(name, value).dataframe());\n        },\n\n        createFactor: function(name, value, ordered, levels, labels) {\n            var opts = {\n                levels: levels,\n                labels: labels\n            };\n\n            if (ordered) {\n                return RData.new('factor', 'factor', RInput.new(name, value, opts).ordered());\n            } else {\n                return RData.new('factor', 'factor', RInput.new(name, value, opts).factor());\n            }\n        },\n\n        createNumericMatrix: function(name, value) {\n            return RData.new('matrix', 'matrix', RInput.new(name, value).numericMatrix());\n        },\n\n        createIntegerMatrix: function(name, value) {\n            return RData.new('matrix', 'matrix', RInput.new(name, value).integerMatrix());\n        },\n\n        createBooleanMatrix: function(name, value) {\n            return RData.new('matrix', 'matrix', RInput.new(name, value).logicalMatrix());\n        },\n\n        createStringMatrix: function(name, value) {\n            return RData.new('matrix', 'matrix', RInput.new(name, value).characterMatrix());\n        }\n    }, // RDataFactory\n\n    DeployR: {\n\n        init: function(config) {\n            config = config || {};\n\n            // --- Assert JSDeploy compatability against the connected DeployR version ---\n            if (config.compatibility) {\n                //compatibilityCheck();\n            }\n\n            // --- Event registration ---\n            if (config.events) {\n                var events = config.events;\n\n                // -- Manage cleanup on browser close (close project, logout, ect...)--\n                if (events.unload) {\n                    SessionManager.setUnloadConfig(events.unload);\n                    Deprecated.Event.on('deployR:unload', SessionManager.unloadHandler, SessionManager);\n                }\n\n                // -- IO Global Events --\n                if (events.globalIO) {\n                    var scope = events.globalIO.scope || window,\n                        lifecycle = events.globalIO.lifecycle,\n                        statusCode = events.globalIO.statusCode;\n\n                    if (lifecycle) {\n                        for (var eventName in lifecycle) {\n                            Deprecated.Event.on('deployR-io:' + eventName, lifecycle[eventName], scope);\n                        }\n                    }\n\n                    if (statusCode) {\n                        for (var eventName in statusCode) {\n                            Deprecated.Event.on('deployR-io:' + eventName, statusCode[eventName], scope);\n                        }\n                    }\n                }\n            }\n\n            // New API\n            deployr.configure({\n                host: config.deployrURI,\n                cors: config.deployrURI ? true : false,\n                logging: config.logging,\n                sticky: true\n            });\n        },\n\n        io: function(api, config, cb) {\n            if (console) {\n                console.warn('\"' + camelCase(api) + '()\" API is now deprecated.');\n            }\n\n            cb = cb || {};\n            config = config || {};\n\n            var transaction = config.transaction || {},\n                transArgs = transaction['arguments'],\n                statusCode = transaction.statusCode || {},\n                scope = cb.scope || window,\n                routputs = config.robjects,\n                rinputs = config.inputs; // config.inputs = R.DeployR.parseInputs(config.inputs);\n\n            // --- omit deprecated props ---\n            if (config.transaction) {\n                delete config.transaction;\n            }\n            if (config.method) {\n                delete config.method;\n            }\n            if (config.on) {\n                delete config.on;\n            }\n            if (config.format) {\n                delete config.format;\n            }\n            if (config.inputs) {\n                delete config.inputs;\n            }\n            if (config.robjects) {\n                delete config.robjects;\n            }\n\n            // --- make the new request ---\n            var io = deployr.io(api)\n                .data(config || {})\n                .error(function(response) {\n                    // global-failure\n                    emitter.emit('deployR-io:failure', [response, api, transArgs]);\n\n                    // transaction-failure\n                    if (cb.failure) {\n                        cb.failure.apply(scope, [response, api, transArgs]);                        \n                    }\n\n                    // global-statusError\n                    emitter.emit(('deployR-io:' + code), [response, api, transArgs]);\n                });\n\n            if (rinputs) {\n                io.rinputs(normalizeInputs(rinputs));\n            }\n            if (routputs) {\n                io.routputs(routputs);\n            }\n            if (transaction.sync) {\n                io.sync();\n            }\n            if (transaction.timeout) {\n                io.timeout(transaction.timeout);\n            }\n\n            // --- Error status code --- //\n            if (statusCode) {\n\n                for (var eventName in statusCode) {                    \n                    io.on('deployr-io:' + eventName, function(response) {\n                        var cb = statusCode;\n                        var statusText = response.deployr.response.error;\n                        var status = response.deployr.response.errorCode;\n                        cb[status].apply(scope, [response, status, statusText, api, transArgs]);\n                    });\n                }                \n\n                // @@@@TODO @@@@@@\n            }\n\n            // global-start\n            emitter.emit('deployR-io:start');\n\n            /// transaction-start\n            if (cb.start) {\n                cb.start.apply(scope, [api, transArgs]); \n            }\n\n            io.end(function(response) {\n                // global-complete\n                emitter.emit('deployR-io:complete');\n\n                // transaction-complete\n                if (cb.complete) {\n                    cb.complete.apply(scope, [response, api, transArgs]); \n                }\n\n                // entity manipulation of the response\n                if (transaction.entity) {\n                    response = format(response, transaction.entity);\n                }\n\n                // global-success\n                emitter.emit('deployR-io:success', [response, api]);\n\n                // transaction-success\n                if (cb.success) {\n                    cb.success.apply(scope, [response, api, transArgs]);                    \n                }\n\n                // global-end\n                emitter.emit('deployR-io:end', [response, api]);\n\n                // transaction-end\n                if (cb.end) {\n                    cb.end.apply(scope, [response, api, transArgs]); \n                }                \n            });\n\n            return io;\n        },\n\n        /**\n         * Flattens a given <code>Revolution.RData</code> type into a JSON\n         * string representing the expected DeployR input format.\n         *\n         * @method parseInputs\n         * @public\n         * @param {Array} rdata An Array of RData Objects to be flattened.\n         * @return {String} The flattend RData JSON string representing the\n         * DeployR input format.\n         */\n        parseInputs: function(rdata) {\n            return rdata;\n        },\n\n        /////////////////////////////////////\n        // Project Workspace APIs\n        //////////////////////////////////////\n\n        /**\n         * This call lists the objects in the workspace for the project indicated.\n         *\n         * @method projectWorkspaceList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>root</dt>\n         *    <dd>(optional) specifies object graph root</dd>\n         *\n         *    <dt>clazz</dt>\n         *    <dd>(optional) specifies R class based filter</dd>\n         *\n         *    <dt>filter</dt>\n         *    <dd>(optional) specifies R object name based filter</dd>\n         *\n         *    <dt>restrict</dt>\n         *    <dd>\n         *       (optional) if <code>true</code, limits returned objects to object\n         *       types with supported RevoDeployR-encoding\n         *    </dd>\n         *\n         *    <dt>pagesize</dt>\n         *    <dd>\n         *       (optional) specifies the page size for paging results in response\n         *       markup\n         *    </dd>\n         *\n         *    <dt>pageoffset</dt>\n         *    <dd>\n         *       (optional) specifies the page offset for paging results in response\n         *       markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceList: function(config, callback) {\n            return this.io('/r/project/workspace/list', config, callback);\n        },\n\n        /**\n         * This call retrieves RevoDeployR-encoded objects from the workspace for the\n         * specified project.\n         *\n         * @method projectWorkspaceGet\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies a comma-separated list of object names</dd>\n         *\n         *    <dt>root</dt>\n         *    <dd>optional) specifies object graph root</dd>\n         *\n         *    <dt>start</dt>\n         *    <dd>optional) specifies the offset into object data</dd>\n         *\n         *    <dt>length</dt>\n         *    <dd>optional) specifies the segment of object data to retrieve</dd>\n         *\n         *      <dt>infinity</dt>\n         *    <dd>\n         *       (optional) specifies a custom value for Infinity appearing in R\n         *       object data returned on the call, otherwise Infinity is represented\n         *       by 0x7ff0000000000000L\n         *    </dd>\n         *\n         *      <dt>nan</dt>\n         *    <dd>\n         *       (optional) specifies custom value for NaN appearing in R object data\n         *       returned on the call, otherwise NaN is represented by null\n         *    </dd>\n         *\n         *    <dt>encodeDataFramePrimitiveAsVector</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, data.frame primitives are encoded\n         *       vectors in R object data returned on call\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceGet: function(config, callback) {\n            return this.io('/r/project/workspace/get', config, callback);\n        },\n\n        /**\n         * This call uploads a binary object from file into the workspace for the\n         * specified project.\n         *\n         * @method projectWorkspaceUpload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies the name of the object file</dd>\n         *\n         *    <dt>file</dt>\n         *    <dd>file content</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceUpload: function(config, callback) {\n            config.format = \"text\";\n            var ioConfig = {\n                data: config,\n                method: \"POST\",\n                form: {\n                    id: config.formId\n                },\n                on: callback\n            };\n            return this.io('/r/project/workspace/upload', config, callback);\n        },\n\n        /**\n         * This call transfers a binary object from a URL into the workspace for the\n         * specified project.\n         *\n         * @method projectWorkspaceTransfer\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies the name of the object file found on the URL</dd>\n         *\n         *    <dt>url</dt>\n         *    <dd>specifies the URL</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceTransfer: function(config, callback) {\n            return this.io('/r/project/workspace/transfer', config, callback);\n        },\n\n        /**\n         * This call pushes a RevoDeployR-encoded object into the workspace for the\n         * specified project.\n         *\n         * @method projectWorkspacePush\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded object inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspacePush: function(config, callback) {            \n            return this.io('/r/project/workspace/push', config, callback);\n        },\n\n        /**\n         * This call saves the workspace to a file in the working directory for the\n         * specified project.\n         *\n         * If the name parameter is specified on the call then only the named object\n         * is saved as a binary object file to the working directory. Otherwise the\n         * entire contents of the workspace are saved.\n         *\n         * @method projectWorkspaceSave\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>(optional) specifies a named object for saving</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies a description to accompany the saved file</dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>\n         *       (optional) if true, the new file will be renamed to avoid\n         *       overwriting\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceSave: function(config, callback) {            \n            return this.io('/r/project/workspace/save', config, callback);\n        },\n\n        /**\n         * This call stores the workspace as a binary object to the repository.\n         *\n         * If the name parameter is specified on the call, then only the named object\n         * is stored as a binary object in the repository. Otherwise the entire\n         * contents of the workspace are stored.\n         *\n         * @method projectWorkspaceStore\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *      <dt>name</dt>\n         *      <dd>(optional) specifies a named object for storing</dd>\n         *\n         *      <dt>descr</dt>\n         *      <dd>(optional) specifies a description to accompany the saved file</dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>\n         *       (optional) specifies tag words to associate with the repository file\n         *    </dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *       (optional) comma-separated list of role names, which makes the file\n         *       visible to authenticated users with these roles\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, the file will be shared, which\n         *       makes the file visible to authenticated users\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, the file will be published, which\n         *       makes the file visible to authenticated and anonymous users\n         *    </dd>\n         *\n         *      <dt>newversion</dt>\n         *      <dd>\n         *       (optional) if <code>true</code>, the new file will be renamed to\n         *       avoid overwriting\n         *    </dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceStore: function(config, callback) {\n            return this.io('/r/project/workspace/store', config, callback);\n        },\n\n        /**\n         * This call loads a binary object from a file in the repository into the\n         * workspace for the specified project.\n         *\n         * @method projectWorkspaceLoad\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>repo</dt>\n         *    <dd>specifies the repository name</dd>\n         *\n         *      <dt>filename</dt>\n         *      <dd>specifies the repository file name</dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>specifies the repository file author</dd>\n         *\n         *      <dt>version</dt>\n         *      <dd>(optional) specifies the repository file version</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceLoad: function(config, callback) {\n            return this.io('/r/project/workspace/load', config, callback);\n        },\n\n        /**\n         * This call deletes an object from the workspace for the specified project.\n         *\n         * @method projectWorkspaceDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies the object name</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceDelete: function(config, callback) {            \n            return this.io('/r/project/workspace/delete', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Project Management APIs\n        /////////////////////////////////////\n\n        /**\n         * This call creates a new project for the currently authenticated user.\n         * If the projectname parameter is specified on the call, then the newly\n         * created project will be a persistent project . If the projectname parameter\n         * is omitted on the call, then the newly created project will be a temporary\n         * project. The projectdescr parameter is ignored if the projectname parameter\n         * is omitted.\n         *\n         * The blackbox parameter ensures that calls on the temporary project are\n         * limited to the Blackbox API Controls .\n         *\n         * Using the inputs , preloadfile , preloadobject and adopt parameters the\n         * project can be pre-initialized with data in the workspace and/or working\n         * directory.\n         *\n         * The inputs parameter allows the caller to pass RevoDeployR-encoded R object\n         * values as inputs. These inputs are turned into R objects in the workspace\n         * of the new R session before the call returns.\n         *\n         * The preloadfile parameters allow the caller to load one or more files from\n         * the repository into the working directory of the new R session before the\n         * call returns.\n         *\n         * The preloadobject parameters allow the caller to load one or more binary R\n         * objects (.rData) from the repository into the workspace of the new R\n         * session before the call returns.\n         *\n         * The adopt parameters allow the caller to load a pre-existing project\n         * workspace, project working directory and/or project package dependencies\n         * into the new R session before the call returns.\n         *\n         * @method projectCreate\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>projectname</dt>\n         *    <dd>(optional) names a new persistent project</dd>\n         *\n         *    <dt>projectdescr</dt>\n         *    <dd>(optional) describes a new persistent project</dd>\n         *\n         *    <dt>blackbox</dt>\n         *    <dd>\n         *       (optional) when enabled, a temporary project is limited to blackbox\n         *       API controls\n         *    </dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>\n         *       (optional) comma-separated list of authors,\n         *       author-per-preloadfilename\n         *    </dd>\n         *\n         *    <dt>preloadfileversion</dt>\n         *    <dd>\n         *       (optional) comma-separated list of versions,\n         *       version-per-preloadfilename\n         *    </dd>\n         *\n         *    <dt>preloadobjectname</dt>\n         *    <dd>\n         *       (optional) comma-separated list of repository object (.rData)\n         *       filenames\n         *    </dd>\n         *\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>\n         *       (optional) comma-separated list of authors,\n         *       author-per-preloadobjectname\n         *    </dd>\n         *\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>\n         *       (optional) comma-separated list of versions,\n         *       version-per-object-preloadobjectname\n         *    </dd>\n         *\n         *    <dt>adoptworkspace</dt>\n         *    <dd>\n         *       (optional) identifies the project whose workspace is to be adopted\n         *    </dd>\n         *\n         *    <dt>adoptdirectory</dt>\n         *    <dd>\n         *       (optional) identifies the project whose directory is to be adopted\n         *    </dd>\n         *\n         *    <dt>adoptpackages</dt>\n         *    <dd>\n         *       (optional) identifies the project whose package dependencies are to\n         *       be adopted\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectCreate: function(config, callback) {\n            return this.io('/r/project/create', config, callback);            \n        },\n\n        /**\n         * This call creates a pool of temporary projects for the currently\n         * authenticated user. The caller can specify their preferred number of\n         * projects to create using the poolsize parameter. RevoDeployR will attempt\n         * to create up to poolsize number of projects. However, standard com\n         * policy contraints apply to individual users and on the grid so there is no\n         * guarantee that poolsize projects will be returned. If the number of\n         * projects returned on this call is less than poolsize the caller can inspect\n         * the error and errorCode properties in the response markup to determine\n         * exactly why their pool size was limited.\n         *\n         * The blackbox parameter ensures that calls on each project in the pool are\n         * limited to the Blackbox API Controls .\n         *\n         * Using the inputs, preloadfile, preloadobject and adopt parameters each\n         * project in the pool can be pre-initialized with data in the workspace\n         * and/or working directory.\n         *\n         * The inputs parameter allows the caller to pass RevoDeployR-encoded R object\n         * values as inputs. These inputs are turned into R objects in the workspace\n         * of the new R session before the call returns.\n         *\n         * The preloadfile parameters allow the caller to load one or more files from\n         * the repository into the working directory of the new R session before the\n         * call returns.\n         *\n         * The preloadobject parameters allow the caller to load one or more binary R\n         * objects (.rData) from the repository into the workspace of the new R\n         * session before the call returns.\n         *\n         * The adopt parameters allow the caller to load a pre-existing project\n         * workspace, project working directory and/or project package dependencies\n         * into the new R session before the call returns.\n         *\n         * @method projectPool\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>poolsize</dt>\n         *    <dd>the preferred size of the pool of temporary projects</dd>\n         *    <dt>blackbox</dd>\n         *    <dd>(optional) when enabled, each temporary project in the pool is limited to blackbox API controls</dd>\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded inputs</dd>\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *    <dt>preloadfileversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *    <dt>preloadobjectname</dt>\n         *    <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *    <dt>adoptworkspace</dt>\n         *    <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *    <dt>adoptdirectory</dt>\n         *    <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *    <dt>adoptpackages</dt>\n         *    <dd>(optional) identifies project from which package dependencies are to be adopted</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectPool: function(config, callback) {\n            return this.io('/r/project/pool', config, callback);\n        },\n\n        /**\n         * This call recycles the R session associated with the project by deleting\n         * all R objects from the workspace and all files from the working directory.\n         *\n         * Recycling a project is a convenient and efficient alternative to starting\n         * over by closing an existing project and then creating a new project.\n         *\n         * @method projectRecycle\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         * supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *    <dt>preserveworkspace</dt>\n         *    <dd>(optional) if true, the objects in the workspace are preserved on recycle</dd>\n         *    <dt>preservedirectory</dt>\n         *    <dd>(optional) if true, the files in the working directory are preserved on recycle</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectRecycle: function(config, callback) {\n            return this.io('/r/project/recycle', config, callback);\n        },\n\n        /**\n         * This call lists all projects owned by the currently authenticated user\n         * and/or all projects shared by other users.\n         *\n         * Shared projects are available as read-only projects to the caller. The\n         * shared or private nature of a project can be controlled using the\n         * <code>/r/project/about/update</code> call\n         * <a href=\"#method_projectAboutUpdate\">projectAboutUpdate</a>.\n         *\n         * @method projectList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>sharedprojectsalso</dt>\n         *    <dd>\n         *       (optional) when true, the project response list contains the caller's\n         *       projects plus projects shared by other users\n         *    </dd>\n         *\n         *    <dt>sharedprojectsonly</dt>\n         *    <dd>\n         *       (optional) when true, the project response list contains only\n         *       projects shared by other users and not the users's own projects\n         *    </dd>\n         *\n         *    <dt>isordered</dt>\n         *    <dd>\n         *       (optional) when true, the project response list is ordered in a\n         *       most-recently-modified first order. Otherwise the list is ordered\n         *       chronologically by creation date\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectList: function(config, callback) {\n            return this.io('/r/project/list', config, callback);\n        },\n        /**\n         * This call pings the specified project to determine if the project is live\n         * on the RevoDeployR grid.\n         *\n         * @method projectPing\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         *  <dl>\n         *      <dt>project</dt>\n         *      <dd>specifies the project identifier</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectPing: function(config, callback) {\n            return this.io('/r/project/ping', config, callback);\n        },\n\n        /**\n         * This call retrieves a set of properties that describe the specified\n         * project.\n         *\n         * @method projectAbout\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectAbout: function(config, callback) {\n            return this.io('/r/project/about', config, callback);\n        },\n\n        /**\n         * This call updates a set of properties that describe the specified project.\n         *\n         * @method projectAboutUpdate\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies the project name</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies the project description</dd>\n         *\n         *    <dt>longdescr</dt>\n         *    <dd>(optional) specifies the project long description</dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, specifies that the project is a\n         *       shared project\n         *    </dd>\n         *\n         *    <dt>projectcookie</dt>\n         *    <dd>\n         *       (optional) specifies a client-application specific project cookie\n         *    </dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectAboutUpdate: function(config, callback) {\n            return this.io('/r/project/about/update', config, callback);\n        },\n\n        /**\n         * This call saves the persistent state of the project indicated.\n         *\n         * The set of drop parameters allows the caller to selectively drop aspects,\n         * such as workspace, working directory, or execution history of the project\n         * state when saving. The flushhistory parameter allows the caller to preserve\n         * the project execution history itself while destroying all generated console\n         * output and results associated with that history.\n         *\n         * @method projectSave\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>(optional) specifies the project name</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies the project description</dd>\n         *\n         *    <dt>longdescr</dt>\n         *    <dd>(optional) specifies the project long description</dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>(optional) if true, specifies the project is a shared project</dd>\n         *\n         *    <dt>projectcookie</dt>\n         *    <dd>(optional) specifies a client-application specific project cookie</dd>\n         *\n         *    <dt>dropworkspace</dt>\n         *    <dd>(optional) if true, the content of the project's workspace is dropped on save</dd>\n         *\n         *    <dt>dropdirectory</dt>\n         *    <dd>(optional) if true, the content of the project's working directory is dropped on save</dd>\n         *\n         *    <dt>drophistory</dt>\n         *    <dd>(optional) if true, the project's execution history is dropped on save</dd>\n         *\n         *    <dt>flushhistory</dt>\n         *    <dd>(optional) if true, the project's execution history is flushed on save</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectSave: function(config, callback) {\n            return this.io('/r/project/save', config, callback);\n        },\n\n        /**\n         * This call saves the persistent state of the specified project to a new\n         * persistent project.\n         *\n         * The set of drop parameters allows the caller to selectively drop aspects,\n         * such as workspace, working directory, or execution history of the project\n         * state when saving to the new project. The flushhistory parameter allows the\n         * caller to preserve the project execution history itself for the new project\n         * while dropping all generated console output and results associated with the\n         * original history.\n         *\n         * @method projectSaveas\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies the new project name</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies the new project description</dd>\n         *\n         *    <dt>longdescr</dt>\n         *    <dd>(optional) specifies the new project long description</dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>(optional) if true, specifies the new project is a shared project</dd>\n         *\n         *    <dt>projectcookie</dt>\n         *    <dd>(optional) specifies a client-application specific cookie for the new project</dd>\n         *\n         *    <dt>dropworkspace</dt>\n         *    <dd>(optional) if true, the content of the original project's workspace is dropped when saving to the new project</dd>\n         *\n         *    <dt>dropdirectory</dt>\n         *    <dd>(optional) if true, the content of the project's working directory is dropped when saving to the new project</dd>\n         *\n         *    <dt>drophistory</dt>\n         *    <dd>(optional) if true, the project's execution history is dropped when saving to the new project</dd>\n         *\n         *    <dt>flushhistory</dt>\n         *    <dd>(optional) if true, the project's execution history is flushed when saving to the new project</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectSaveas: function(config, callback) {\n            return this.io('/r/project/saveas', config, callback);\n        },\n\n        /**\n         * This call closes the project indicated.\n         *\n         * Closing a live project releases all resources associated with the project\n         * on the RevoDeployR grid. If the specified project is a persistent project\n         * then the default autosave semantics will cause the project to be saved\n         * automatically. The caller can override that default behavior using the\n         * disableautosave parameter.\n         *\n         * The set of drop parameters allow the caller to selectively drop aspects,\n         * such as workspace, working directory, or execution history, of the project\n         * state when closing. The flushhistory parameter allows the caller to\n         * preserve the project execution history itself while destroying all\n         * generated console output and results associated with that history.\n         *\n         * @method projectClose\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies project identifier</dd>\n         *\n         *    <dt>disableautosave</dt>\n         *    <dd>(optional) if true, the default autosave semantics for persistent projects are disabled</dd>\n         *\n         *    <dt>projectcookie</dt>\n         *    <dd>(optional) specifies a client-application specific project cookie</dd>\n         *\n         *    <dt>dropworkspace</dt>\n         *    <dd>(optional) if true, the content of the project's workspace is dropped on close</dd>\n         *\n         *    <dt>dropdirectory</dt>\n         *    <dd>(optional) if true, the content of the project's working directory is dropped on close</dd>\n         *\n         *    <dt>drophistory</dt>\n         *    <dd>(optional) if true, the project's execution history is dropped on close</dd>\n         *\n         *    <dt>flushhistory</dt>\n         *    <dd>(optional) if true, the project's execution history is flushed on close</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectClose: function(config, callback) {\n            return this.io('/r/project/close', config, callback);\n        },\n\n        /**\n         * This call grants authorship of the specified project to other users.\n         *\n         * @method projectGrant\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>newauthor</dt>\n         *    <dd>\n         *       specifies a comma-separated list of usernames indicating the new\n         *       owners\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectGrant: function(config, callback) {\n            return this.io('/r/project/grant', config, callback);\n        },\n\n        /**\n         * This call imports the specified project archive as a new persistent\n         * project.\n         *\n         * @method projectImport\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>name</dt>\n         *    <dd>specifies the name of the project archive file</dd>\n         *\n         *    <dt>file</dt>\n         *    <dd>...file content...</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>\n         *       (optional) specifies a description for the newly imported project\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectImport: function(config, callback) {\n            config.format = \"text\";\n            var ioConfig = {\n                data: config,\n                method: \"POST\",\n                form: {\n                    id: config.formId\n                },\n                on: callback\n            };\n            return this.io('/r/project/import', config, callback);\n        },\n        /**\n         * This call exports a compressed archive file for the specified project.\n         *\n         * The set of drop parameters allow the caller to selectively drop aspects,\n         * such as workspace, working directory, or execution history of the project\n         * state when generating the archive. The flushhistory parameter allows the\n         * caller to preserve the project execution history itself while excluding all\n         * generated console output and results associated with that history.\n         *\n         * @method projectExport\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies project identifier</dd>\n         *\n         *    <dt>dropworkspace</dt>\n         *    <dd>(optional) if true, the content of the project's workspace is dropped on export</dd>\n         *\n         *    <dt>dropdirectory</dt>\n         *    <dd>(optional) if true, the content of the project's working directory is dropped on export</dd>\n         *\n         *    <dt>drophistory</dt>\n         *    <dd>(optional) if true, the project's execution history is dropped on export</dd>\n         *\n         *    <dt>flushhistory</dt>\n         *    <dd>(optional) if true, the project's execution history is flushed on export</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExport: function(config, callback) {\n            return this.io('/r/project/export', config, callback);\n        },\n\n        /**\n         * This call deletes the specified project.\n         * Deleting a project is a permanent operation that cannot be undone or\n         * recovered.\n         *\n         * @method projectDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies project identifier</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDelete: function(config, callback) {\n            return this.io('/r/project/delete', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Project Execution APIs\n        /////////////////////////////////////\n\n        /**\n         * This call executes a block of R code on the R session identified by the\n         * project parameter.\n         *\n         * Please note the following pre and post execution parameters:\n         *\n         * <strong>Pre-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The inputs parameter allows the caller to pass RevoDeployR-encoded\n         *       R object values as inputs. These inputs are turned into R objects\n         *       in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadfile parameters allows the caller to load one or more\n         *       files from the repository into the working directory before the\n         *       execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadobject parameters allow the caller to load one or more\n         *       binary R objects (.rData) from the repository into the workspace\n         *       before the execution begins.\n         *    </li>\n         *    <li>\n         *       The adopt parameters allow the caller to load a pre-existing\n         *       project workspace, project working directory and/or project package\n         *       dependencies before the execution begins.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Post-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The robjects parameter allows the caller to specify a comma-separated\n         *       list of object names that will be returned as RevoDeployR-encoded R\n         *       objects on the response markup after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storefile parameter allows the caller specify a comma-separated\n         *       list of working directory files to be stored in the repository after\n         *       the execution completes.\n         *    </li>\n         *    <li>\n         *       The storeobject parameter allows the caller specify a comma-separated\n         *       list of workspace objects to be stored in the repository after the\n         *       execution completes.\n         *    </li>\n         *    <li>\n         *       The storeworkspace parameter allows the caller to store the entire\n         *       workspace in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storedirectory parameter allows the caller to specify a target\n         *       repository directory for stored files and objects after the execution\n         *       completes.\n         *    </li>\n         *    <li>\n         *       The storenewversion parameter allows the caller to create new\n         *       versions of each stored file in the repository after the execution\n         *       completes. By default, stored files overwrite any pre-existing file\n         *       by the same name.\n         *    </li>\n         *    <li>\n         *       The storepublic parameter allows the caller to assign public access\n         *       to each stored file in the repository after the execution completes.\n         *    </li>\n         * </ol>\n         *\n         *  <strong>Some key data indicated in the response markup on this call:</strong>\n         *\n         * <ol>\n         *    <li>code - indicates the code that has been executed</li>\n         *    <li>\n         *       console - indicates the console output resulting from the code\n         *       execution\n         *    </li>\n         *    <li>\n         *       results - indicates the list of files generated by the R graphics\n         *       device\n         *    </li>\n         *    <li>\n         *       artifacts - indicates the list of files generated or modified in the\n         *       working directory\n         *    </li>\n         *    <li>\n         *       objects -  indicates the list of R objects returned from the\n         *       workspace\n         *    </li>\n         *    <li>\n         *       files - indicates the list of files and objects stored in the\n         *       repository after the execution completes\n         *    </li>\n         *    <li>\n         *       interrupted - indicates the interrupted status of execution\n         *    </li>\n         *    <li>\n         *       error - on failure, indicates the reason for failure\n         *    </li>\n         *    <li>\n         *       errorCode - on failure, indicates the error code for failure\n         *    </li>\n         * </ol>\n         *\n         * @method projectExecuteCode\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>code</dt>\n         *    <dd>specifies the block of R code</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded script inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *\n         *    <dt>preloadfileversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *\n         *    <dt>preloadobjectname</dt>\n         *    <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *\n         *    <dt>adoptworkspace</dt>\n         *    <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *\n         *    <dt>adoptdirectory</dt>\n         *    <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *\n         *    <dt>adoptpackages</dt>\n         *    <dd>(optional) identifies project from which package dependencies are to be adopted</dd>\n         *\n         *    <dt>tag</dt>\n         *    <dd>(optional) specifies a tag that labels the execution</dd>\n         *\n         *    <dt>echooff</dt>\n         *    <dd>(optional) if true R commands will not appear in the console output</dd>\n         *\n         *    <dt>consoleoff</dt>\n         *    <dd>(optional) if true console output is not returned in the response markup</dd>\n         *\n         *      <dt>graphics</dt>\n         *      <dd>(optional) specifies preferred R graphics device for execution: png or svg</dd>\n         *\n         *      <dt>graphicswidth</dt>\n         *      <dd>(optional) specifies preferred width for R graphics device images</dd>\n         *\n         *      <dt>graphicsheight</dt>\n         *      <dd>(optional) specifies preferred height for R graphics device images</dd>\n         *\n         *      <dt>robjects</dt>\n         *      <dd>(optional) specifies a comma-separated list of objects for retrieval following the execution</dd>\n         *\n         *      <dt>storefile</dt>\n         *      <dd>(optional) comma-separated list of working directory filenames</dd>\n         *\n         *      <dt>storeobject</dt>\n         *      <dd>(optional) comma-separated list of workspace object names</dd>\n         *\n         *      <dt>storeworkspace</dt>\n         *      <dd>(optional) filename (.rData) where workspace contents will be saved in the repository</dd>\n         *\n         *      <dt>storenewversion</dt>\n         *      <dd>(optional) if <code>true</code>, ensures each file stored in\n         *    repository results in new version being created if needed</dd>\n         *\n         *      <dt>storepublic</dt>\n         *      <dd>(optional) if <code>true</code>, publishes each file stored in the repository</dd>\n         *\n         *      <dt>infinity</dt>\n         *      <dd>(optional) specifies custom value for Infinity appearing in R object\n         *    data returned on call, otherwise Infinity is represented by <code>0x7ff0000000000000L</code>\n         *    </dd>\n         *\n         *      <dt>nan</dt>\n         *      <dd>(optional) specifies custom value for NaN appearing in R object data\n         *    returned on call, otherwise NaN is represented by <code>null</code></dd>\n         *\n         *      <dt>encodeDataFramePrimitiveAsVector</dt>\n         *      <dd>(optional) if <code>true</code>, data.frame primitives are encoded vectors in R object data returned on call</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteCode: function(config, callback) {           \n            return this.io('/r/project/execute/code', config, callback);\n        },\n        /**\n         * This call executes executes repository-managed scripts or external scripts\n         * on the R session identified by the project parameter.\n         *\n         * To execute a single repository-managed script the caller must provide\n         * parameter values for filename, author and optionally version. To execute\n         * a chain of repository-managed scripts the caller must provide a\n         * comma-separated list of values on the filename , author and optionally\n         * version parameters.\n         *\n         * To execute a single external script the caller must provide a valid URL or\n         * file path using the externalsource parameter. To execute a chain of\n         * external scripts the caller must provide a comma-separated list of values\n         * on the externalsource parameter. Note, to execute an external script the\n         * caller must have POWER_USER privileges.\n         *\n         * Note: A chained execution executes each of the scripts identified on the\n         * call in a sequential fashion on the R session, with execution occuring in\n         * the order specified on the parameter list.\n         *\n         * Please not the following pre and post execution parameters:\n         *\n         * <strong>Pre-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The inputs parameter allows the caller to pass RevoDeployR-encoded\n         *       R object values as inputs. These inputs are turned into R objects\n         *       in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadfile parameters allows the caller to load one or more\n         *       files from the repository into the working directory before the\n         *       execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadobject parameters allow the caller to load one or more\n         *       binary R objects (.rData) from the repository into the workspace\n         *       before the execution begins.\n         *    </li>\n         *    <li>\n         *       The adopt parameters allow the caller to load a pre-existing\n         *       project workspace, project working directory and/or project package\n         *       dependencies before the execution begins.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Post-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The robjects parameter allows the caller to specify a comma-separated\n         *       list of object names that will be returned as RevoDeployR-encoded R\n         *       objects on the response markup after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storefile parameter allows the caller specify a comma-separated\n         *       list of working directory files to be stored in the repository after\n         *       the execution completes.\n         *    </li>\n         *    <li>\n         *       The storeobject parameter allows the caller specify a comma-separated\n         *       list of workspace objects to be stored in the repository after the\n         *       execution completes.\n         *    </li>\n         *    <li>\n         *       The storeworkspace parameter allows the caller to store the entire\n         *       workspace in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storedirectory parameter allows the caller to specify a target\n         *       repository directory for stored files and objects after the execution\n         *       completes.\n         *    </li>\n         *    <li>\n         *       The storenewversion parameter allows the caller to create new\n         *       versions of each stored file in the repository after the execution\n         *       completes. By default, stored files overwrite any pre-existing file\n         *       by the same name.\n         *    </li>\n         *    <li>\n         *       The storepublic parameter allows the caller to assign public access\n         *       to each stored file in the repository after the execution completes.\n         *    </li>\n         * </ol>\n         *\n         * <strong>\n         *    Some of the key data indicated in the response markup on this call\n         *    include:\n         * </strong>\n         *\n         * <ol>\n         *    <li>\n         *       console - indicates the console output resulting from the script\n         *       execution\n         *    </li>\n         *    <li>\n         *       results - indicates the list of files generated by the R graphics\n         *       device\n         *    </li>\n         *    <li>\n         *       artifacts - indicates the list of files generated or modified in the\n         *       working directory\n         *    </li>\n         *    <li>\n         *       objects - indicates the list of R objects returned from the workspace\n         *    </li>\n         *    <li>\n         *       files - indicates the list of files and objects stored in the\n         *       repository after the execution completes\n         *    </li>\n         *    <li>interrupted - indicates the interrupted status of execution</li>\n         *    <li>error - on failure, indicates the reason for failure</li>\n         *    <li>errorCode - on failure, indicates the error code for failure</li>\n         * </ol>\n         *\n         * @method projectExecuteScript\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         *  <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>(optional) comma-separated list of repository-managed script filenames</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) comma-separated list of repository-managed directories for\n         *       scripts, defaults to root\n         *    </dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-filename</dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-filename</dd>\n         *\n         *    <dt>externalsource</dt>\n         *    <dd>(optional) comma-separated list of URLs or file paths to external scripts</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded script inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *\n         *    <dt>preloadfileversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *\n         *    <dt>preloadobjectname</dt>\n         *    <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *\n         *    <dt>adoptworkspace</dt>\n         *    <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *\n         *    <dt>adoptdirectory</dt>\n         *    <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *\n         *    <dd>adoptpackages</dd>\n         *    <dt>(optional) identifies project from which package dependencies are to be adopted</dt>\n         *\n         *    <dt>tag</dt>\n         *    <dd>(optional) specifies a tag that labels the execution</dd>\n         *\n         *    <dt>echooff</dt>\n         *    <dd>(optional) if true R commands will not appear in the console output</dd>\n         *\n         *    <dt>graphics</dt>\n         *    <dd>(optional) specifies preferred R graphics device for execution: png or svg</dd>\n         *\n         *    <dt>graphicswidth</dt>\n         *    <dd>(optional) specifies preferred width for R graphics device images</dd>\n         *\n         *    <dt>graphicsheight</dt>\n         *    <dd>(optional) specifies preferred height for R graphics device images</dd>\n         *\n         *    <dt>robjects</dt>\n         *    <dd>(optional) specifies a comma-separated list of objects for retrieval following the execution</dd>\n         *\n         *    <dt>storefile</dt>\n         *    <dd>(optional) comma-separated list of working directory filenames</dd>\n         *\n         *    <dt>storeobject</dt>\n         *    <dd>(optional) comma-separated list of workspace object names</dd>\n         *\n         *    <dt>storeworkspace</dt>\n         *    <dd>(optional) filename (.rData) where workspace contents will be saved in the repository</dd>\n         *\n         *    <dt>storenewversion</dt>\n         *    <dd>(optional) if <code>true</code>, ensures each file stored in repository results in new version being created if needed</dd>\n         *\n         *    <dt>storepublic</dt>\n         *    <dd>(optional) if <code>true</code>, publishes each file stored in the repository</dd>\n         *\n         *    <dt>infinity</dt>\n         *    <dd>(optional) specifies custom value for Infinity appearing in R object data returned on call, otherwise Infinity is represented by <code>0x7ff0000000000000L</code></dd>\n         *\n         *    <dt>nan</dt>\n         *    <dd>(optional) specifies custom value for NaN appearing in R object data returned on call, otherwise NaN is represented by <code>null</code></dd>\n         *\n         *    <dt>encodeDataFramePrimitiveAsVector</dt>\n         *    <dd>(optional) if <code>true</code>, data.frame primitives are encoded vectors in R object data returned on call</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteScript: function(config, callback) {            \n            return this.io('/r/project/execute/script', config, callback);\n        },\n\n        /**\n         * This call interrupts the current execution on specified project.\n         *\n         * @method projectExecuteInterrupt\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         *  <dl>\n         *      <dt>project</dt>\n         *      <dd>specifies the project identifier</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteInterrupt: function(config, callback) {\n            return this.io('/r/project/execute/interrupt', config, callback);\n        },\n\n        /**\n         * This call retrieves the R console output for the latest execution on\n         * specified project.\n         *\n         * @method projectExecuteConsole\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         *  <dl>\n         *    <dt>project</dt>\n         *      <dd>specifies the project identifier</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteConsole: function(config, callback) {\n            return this.io('/r/project/execute/console', config, callback);\n        },\n\n        /**\n         * This call retrieves the execution history for the specified project.\n         *\n         * Some of the key data indicated for each history item in the response markup\n         * on this call include:\n         *\n         * <ol>\n         *  <li>code - indicates the code that has been executed</li>\n         *  <li>console - indicates the console output resulting from the code execution</li>\n         *  <li>resultsGenerated - indicates the number of generated results on the execution</li>\n         *  <li>resultsAvailable - indicates the number of generated results still stored on the execution</li>\n         *  <li>resourceUsage - indicates the current storage byte count for results on the execution</li>\n         *  <li>execution - indicates the execution identifier, which can then be used on /r/project/execution/result calls to retrieve or manage results</li>\n         *  <li>interrupted - indicates the interrupted status of execution</li>\n         *  <li>error - on failure, indicates the reason for failure</li>\n         *  <li>errorCode - on failure, indicates the error code for failure</li>\n         * </ol>\n         * @method projectExecuteHistory\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filterdepth</dt>\n         *    <dd>specifies the max number of executions to be returned in the history</dd>\n         *\n         *    <dt>execution</dt>\n         *    <dd>(optional) specifies the comma-separated list of execution identifiers on which to filter history</dd>\n         *\n         *    <dt>filtertag</dt>\n         *    <dd>(optional) specifies the execution tag on which to filter history</dd>\n         *\n         *    <dt>reversed</dt>\n         *    <dd>\n         *       (optional) if true, the execution history is returned in a\n         *       reverse-chronological order\n         *    </dt>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteHistory: function(config, callback) {\n            return this.io('/r/project/execute/history', config, callback);\n        },\n\n        /**\n         * This call flushes executions in the history on the specified project.\n         * Flushing an execution deletes both the R console output and the generated\n         * results associated with that execution but does not remove the execution\n         * itself from the history. By omitting the execution parameter, the caller\n         * can flush every execution in the history on the specified project.\n         *\n         * This flushing facility is provided to help users manage the levels of\n         * resource usage associated with their persistent projects.\n         *\n         * @method projectExecuteFlush\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         *  <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>execution</dt>\n         *    <dd>(optional) comma-separated list of execution identifiers</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteFlush: function(config, callback) {\n            return this.io('/r/project/execute/flush', config, callback);\n        },\n\n        /**\n         * This call lists the execution results for the specified project.\n         *\n         * By specifying a value for the execution parameter the caller can limit the\n         * response to those results found on a specific execution or set of\n         * executions.\n         *\n         * <blockquote>\n         *    Important! The URLs indicated in the response markup on this call remain\n         *    valid for as long as the results remain part of the project.\n         * </blockquote>\n         *\n         * @method projectExecuteResultList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>execution</dt>\n         *    <dd>\n         *       (optional) specifies a comma-separated list of execution identifiers\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteResultList: function(config, callback) {\n            return this.io('/r/project/execute/result/list', config, callback);\n        },\n\n        /**\n         * This call downloads the execution results for the specified project.\n         *\n         * By specifying a value for the execution parameter the caller can download\n         * only results on the specified executions. By specifying a value for the\n         * filename parameter the caller can download a specific result on the\n         * specified execution.\n         *\n         * @method projectExecuteResultDownload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>execution</dt>\n         *    <dd>\n         *       (optional) specifies a comma-separated list of execution identifiers\n         *    </dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>(optional) specifies a result file name</dd>\n         *\n         *    <dt>inline</dt>\n         *    <dd>\n         *       (optional) if true, the Content-Disposition response header\n         *       indicating attachment is omitted\n         *    </dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteResultDownload: function(config, callback) {\n            return this.io('/r/project/execute/result/download', config, callback);\n        },\n\n        /**\n         * This call deletes the execution results for the specified project.\n         *\n         * By specifying a value for the execution parameter the caller can delete\n         * only those results on the specified executions. By specifying a value for\n         * the filename parameter the caller can delete a specific result on the\n         * specified executions.\n         *\n         * @method projectExecuteResultDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *   <dt>project</dt>\n         *   <dd>specifies the project identifier</dd>\n         *\n         *   <dt>execution</dt>\n         *   <dd>\n         *      (optional) specifies a comma-separated list of execution identifiers\n         *   </dd>\n         *\n         *   <dt>filename</dt>\n         *   <dd>(optional) specifies a result file name</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteResultDelete: function(config, callback) {\n            return this.io('/r/project/execute/result/delete', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Project Directory APIs\n        /////////////////////////////////////\n\n        /**\n         * This call lists working directory files for the specified project.\n         *\n         * The filter parameter can be specified on the call to filter, the types of\n         * files returned according to their category. The following filter values are\n         * supported:\n         *\n         * <ol>\n         *    <li>plot - files ending with a .png, .svg or .jpg extension</li>\n         *    <li>script - files ending with a .R or .r extension</li>\n         *    <li>R - files ending with a .rData or .rdata extension</li>\n         *    <li>data - files ending with a .csv or .xls extension</li>\n         *    <li>text - files ending with a .txt extension</li>\n         * </ol>\n         *\n         * @method projectDirectoryList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filter</dt>\n         *    <dd>(optional) specifies the filter by category value</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryList: function(config, callback) {\n            return this.io('/r/project/directory/list', config, callback);\n        },\n\n        /**\n         * This call uploads a file into the working directory for the specified\n         * project.\n         *\n         * @method projectDirectoryUpload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>specifies the name of the file</dd>\n         *\n         *    <dt>file</dt>\n         *    <dd>...file content...</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies the description to be associated with file</dd>\n         *\n         *    <dt>overwrite</dt>\n         *    <dd>(optional) if true, overwrites the existing file of same name</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryUpload: function(config, callback) {\n            config.format = \"text\";\n            var ioConfig = {\n                data: config,\n                method: \"POST\",\n                form: {\n                    id: config.formId\n                },\n                on: callback\n            };\n            return this.io('/r/project/directory/upload', config, callback);\n        },\n\n        /**\n         * This call transfers a file from a URL into the working directory for the\n         * specified project.\n         *\n         * @method projectDirectoryTransfer\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>specifies the name of the file</dd>\n         *\n         *    <dt>url</dt>\n         *    <dd>specifies the URL for the file</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies the description to be associated with file</dd>\n         *\n         *    <dt>overwrite</dt>\n         *    <dd>(optional) if true, overwrites the existing file of same name</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryTransfer: function(config, callback) {\n            return this.io('/r/project/directory/transfer', config, callback);\n        },\n\n        /**\n         * This call writes a text file into the working directory for the specified\n         * project.\n         *\n         * @method projectDirectoryWrite\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>specifies the name of the file</dd>\n         *\n         *    <dt>text</dt>\n         *    <dd>specifies the text content for the file</dd>\n         *\n         *    <dt>delimiter</dt>\n         *    <dd>\n         *       (optional) specifies a custom delimiter for text when writing\n         *       multiple files, defaults to #,#\n         *    </dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies the description to be associated with file</dd>\n         *\n         *    <dt>overwrite</dt>\n         *    <dd>(optional) if true, overwrites the existing file of same name</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryWrite: function(config, callback) {\n            return this.io('/r/project/directory/write', config, callback);\n        },\n\n        /** \n         * This call updates a file name and/or description in the working directory\n         * for the specified project.\n         *\n         * @method projectDirectoryUpdate\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>specifies the name of the file</dd>\n         *\n         *    <dt>rename</dt>\n         *    <dd>(optional) specifies the new name for the file</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifices the new description for the file</dd>\n         *\n         *    <dt>overwrite</dt>\n         *    <dd>(optional) if true, overwrites the existing file of same name</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryUpdate: function(config, callback) {\n            return this.io('/r/project/directory/update', config, callback);\n        },\n\n        /**\n         * This call stores a file from the working directory to the repository.\n         *\n         * @method projectDirectoryStore\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>(optional) specifies the file for storing</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies a description to accompany the saved file</dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>\n         *       (optional) specifies tag words to associate with repository file\n         *    </dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *        (optional) comma-separated list of role names, which makes the file\n         *        visible to authenticated users with these roles\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if true, the file will be shared , which makes the file\n         *       visible to authenticated users\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if true, the file will be published , which makes the\n         *       file visible to authenticated and anonymous users\n         *    </dd>\n         *\n         *    <dt>newversion</dt>\n         *    <dd>\n         *       (optional) if true, the new file will be renamed to avoid overwriting\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryStore: function(config, callback) {\n            return this.io('/r/project/directory/store', config, callback);\n        },\n\n        /**\n         * This call loads a file from the repository into the working directory for\n         * the specified project.\n         *\n         * @method projectDirectoryLoad\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>specifies the repository file name</dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>specifies the author name</dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>(optional) specifies the repository file version</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryLoad: function(config, callback) {\n            return this.io('/r/project/directory/load', config, callback);\n        },\n\n        /**\n         * This call downloads the working directory contents for the specified\n         * project.\n         *\n         * By specifying a single value for the filename parameter, the caller can\n         * download a specific file. By specifying multiple values for the filename\n         * parameter, the caller can download a zip archive of those files. By\n         * omitting the filename parameter, then the caller can download a zip archive\n         * with all of the files in the working directory.\n         *\n         * @method projectDirectoryDownload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>(optional) specifies comma-separated file names for download</dd>\n         *\n         *    <dt>inline</dt>\n         *    <dd>\n         *       (optional) if true, the Content-Disposition response header\n         *       indicating attachment is omitted\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryDownload: function(config, callback) {\n            return this.io('/r/project/directory/download', config, callback);\n        },\n\n        /**\n         * This call deletes files from the working directory for the specified\n         * project.\n         *\n         * @method projectDirectoryDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>specifies a comma-separated list of file names for deletion</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryDelete: function(config, callback) {\n            return this.io('/r/project/directory/delete', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Project Package APIs\n        /////////////////////////////////////\n\n        /**\n         * This call lists R package dependencies for the specified project.\n         *\n         * @method projectPackageList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>installed</dt>\n         *    <dd>\n         *       if true, response lists all packages installed in project environment\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectPackageList: function(config, callback) {\n            return this.io('/r/project/package/list', config, callback);\n        },\n\n        /**\n         * This call attaches R package dependencies for the specified project.\n         *\n         * @method projectPackageAttach\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies a comma-separated list of R package names to attach</dd>\n         *\n         *    <dt>repo</dt>\n         *    <dd>(optional) specifies R repository location for named packages</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectPackageAttach: function(config, callback) {\n            return this.io('/r/project/package/attach', config, callback);\n        },\n\n        /**\n         * This call detaches R package dependencies for the specified project.\n         *\n         * @method projectPackageDetach\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies a comma-separated list of R package names to detach</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectPackageDetach: function(config, callback) {\n            return this.io('/r/project/package/detach', config, callback);\n        },\n\n        /////////////////////////////////////\n        // User APIs\n        /////////////////////////////////////\n\n        /**\n         * This call signs the user in by authenticating the credentials with the\n         * RevoDeployR server.\n         *\n         * @method userLogin\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>username</dt>\n         *    <dd>specifies the username</dd>\n         *\n         *    <dt>password</dt>\n         *    <dd>specifies the password</dd>\n         *\n         *    <dt>disableautosave</dt>\n         *    <dd>\n         *       (optional) when true, disables autosave semantics for persistent\n         *       projects\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        userLogin: function(config, callback) {\n            return this.io('/r/user/login', config, callback);            \n        },\n\n        /**\n         * This call signs out the currently authenticated user.\n         *\n         * @method userLogout\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>usercookie</dt>\n         *    <dd>\n         *       (optional) when specified, value sets application-specific persistent\n         *       user cookie, which is retrievable on response to\n         *       <a href=\"#method_userLogin\">userLogin</a> call.\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        userLogout: function(config, callback) {\n            return this.io('/r/user/logout', config, callback);            \n        },\n\n        /**\n         * This call retrieves details about the currently authenticated user. The\n         * details returned in the response markup on this call are exactly the same\n         * details as those returned in the response markup on the\n         * <a href=\"#method_userLogin\">userLogin</a> call.\n         *\n         * @method userAbout\n         * @static\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        userAbout: function(callback) {            \n            return this.io('/r/user/about', {}, callback);\n        },\n\n        /**\n         * This call enables or disables the autosave semantics on persistent projects\n         * for the duration of the current users HTTP session. By default, all live\n         * persistent projects are autosaved under the following conditions:\n         *\n         * <ul>\n         *    <li>\n         *       When a user closes a project using the\n         *       <a href=\"#method_projectClose\">projectClose</a> call.\n         *    </li>\n         *    <li>\n         *       When a user signs-out using the\n         *       <a href=\"#method_userLogout\">userLogout</a> call.\n         *    </li>\n         *    <li>\n         *       When a user is automatically signed-out by the system after a\n         *       prolonged period of inactivity.\n         *    </li>\n         * </ul>\n         *\n         * When the autosave feature is disabled a user must make an explicit call on\n         * <a href=\"#method_projectSave\">projectSave</a> in order to save a project.\n         *\n         * @method userAutosave\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>enable</dt>\n         *    <dd>(optional) toggles autosave semantics for persistent projects.</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        userAutosave: function(config, callback) {\n            return this.io('/r/user/autosave', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Repository Script APIs\n        /////////////////////////////////////\n\n        /**\n         * This call lists repository-managed scripts.\n         *\n         * This call is available to authenticated and anonymous users. However, if\n         * the caller is an anonymous user then only published scripts will be\n         * returned in the response markup.\n         *\n         * @method repositoryScriptList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) when specified, call returns list of script versions for\n         *       filename\n         *   </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files that are restricted but\n         *       visible or shared by other users are included in the response markup\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, scripts published by other users are\n         *       included in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryScriptList: function(callback) {            \n            return this.io('/r/repository/script/list', {}, callback);\n        },\n        /**\n         * This call executes repository-managed scripts or external scripts on an\n         * Anonymous Project.\n         *\n         * To execute a single repository-managed script the caller must provide\n         * parameter values for filename, author and optionally version. To execute a\n         * chain of repository-managed scripts the caller must provide a\n         * comma-separated list of values on the filename , author and optionally\n         * version parameters.\n         *\n         * To execute a single external script the caller must provide a valid URL\n         * or file path using the externalsource parameter. To execute a chain of\n         * external scripts the caller must provide a comma-separated list of\n         * values on the externalsource parameter. Note, to execute an external script\n         * the caller must have POWER_USER privileges so this feature is not available\n         * to anonymous users on this call.\n         *\n         * Note: A chained execution executes each of the scripts identified on the\n         * call in a sequential fashion on the R session, with execution occuring in\n         * the order specified on the parameter list.\n         *\n         * <strong>Pre-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The inputs parameter allows the caller to pass RevoDeployR-encoded\n         *       R object values as inputs. These inputs are turned into R objects\n         *       in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadfile parameters allows the caller to load one or more\n         *       files from the repository into the working directory before the\n         *       execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadobject parameters allow the caller to load one or more\n         *       binary R objects (.rData) from the repository into the workspace\n         *       before the execution begins.\n         *    </li>\n         *    <li>\n         *       The adopt parameters allow the caller to load a pre-existing\n         *       project workspace, project working directory and/or project package\n         *       dependencies before the execution begins.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Post-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The robjects parameter allows the caller to specify a comma-separated\n         *       list of object names that will be returned as RevoDeployR-encoded R\n         *       objects on the response markup after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storefile parameter allows the caller specify a comma-separated\n         *       list of working directory files to be stored in the repository after\n         *       the execution completes.\n         *    </li>\n         *    <li>\n         *       The storeobject parameter allows the caller specify a comma-separated\n         *       list of workspace objects to be stored in the repository after the\n         *       execution completes.\n         *    </li>\n         *    <li>\n         *       The storeworkspace parameter allows the caller to store the entire\n         *       workspace in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storedirectory parameter allows the caller to specify a target\n         *       repository directory for stored files and objects after the execution\n         *       completes.\n         *    </li>\n         *    <li>\n         *       The storenewversion parameter allows the caller to create new\n         *       versions of each stored file in the repository after the execution\n         *       completes. By default, stored files overwrite any pre-existing file\n         *       by the same name.\n         *    </li>\n         *    <li>\n         *       The storepublic parameter allows the caller to assign public access\n         *       to each stored file in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The infinity , nan and encodeDataFramePrimitiveAsVector parameters\n         *       allow the caller to control how RevoDeployR-encoded R object data is\n         *       encoded in the response markkup.\n         *    </li>\n         * </ol>\n         *\n         *  <strong>\n         *     Some key data indicated in the response markup on this call:\n         *  </strong>\n         *\n         *  <ol>\n         *    <li>\n         *       console - indicates the console output resulting from the code\n         *       execution\n         *    </li>\n         *    <li>\n         *       results - indicates the list of files generated by the R graphics\n         *       device\n         *    </li>\n         *    <li>\n         *       artifacts - indicates the list of files generated or modified in the\n         *       working directory\n         *    </li>\n         *    <li>\n         *       objects -  indicates the list of R objects returned from the\n         *       workspace\n         *    </li>\n         *    <li>\n         *       files - indicates the list of files and objects stored in the\n         *       repository after the execution completes\n         *    </li>\n         *    <li>interrupted - indicates the interrupted status of execution</li>\n         *    <li>error - on failure, indicates the reason for failure</li>\n         *    <li>errorCode - on failure, indicates the error code for failure</li>\n         * </ol>\n         * @method repositoryScriptExecute\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>comma-separated list of repository-managed script filenames</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) comma-separated list of repository-managed directories for\n         *       scripts, defaults to root\n         *    </dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-filename</dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-filename</dd>\n         *\n         *    <dt>externalsource</dt>\n         *    <dd>(optional) comma-separated list of URLs or file paths to external scripts</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded script inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *\n         *    <dt>preloadfileversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *\n         *    <dt>preloadobjectname</dt>\n         *    <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *\n         *    <dt>adoptworkspace</dt>\n         *    <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *\n         *    <dt>adoptdirectory</dt>\n         *    <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *\n         *    <dt>adoptpackages</dt>\n         *    <dd>(optional) identifies project from which package dependencies are to be adopted</dd>\n         *\n         *    <dt>blackbox</dt>\n         *      <dd>\n         *       (optional) if true, the execution will occur on the HTTP blackbox\n         *       project for the current HTTP session\n         *    </dd>\n         *\n         *      <dt>recycle</dt>\n         *      <dd>\n         *       (optional) if true, recycles the R session associated with the HTTP\n         *       blackbox project on the current HTTP session\n         *    </dd>\n         *\n         *    <dt>tag</dt>\n         *    <dd>(optional) specifies a tag that labels the execution</dd>\n         *\n         *    <dt>echooff</dt>\n         *    <dd>(optional) </dd>\n         *\n         *    <dt>graphics</dt>\n         *    <dd>(optional) specifies preferred R graphics device for execution: png or svg</dd>\n         *\n         *    <dt>graphicswidth</dt>\n         *    <dd>(optional) specifies preferred width for R graphics device images</dd>\n         *\n         *    <dt>graphicsheight</dt>\n         *    <dd>(optional) specifies preferred height for R graphics device images</dd>\n         *\n         *    <dt>robjects</dt>\n         *    <dd>(optional) specifies a comma-separated list of objects for retrieval following the execution</dd>\n         *\n         *    <dt>storefile</dt>\n         *    <dd>(optional) comma-separated list of working directory filenames</dd>\n         *\n         *    <dt>storeobject</dt>\n         *    <dd>(optional) comma-separated list of workspace object names</dd>\n         *\n         *    <dt>storeworkspace</dt>\n         *    <dd>(optional) filename (.rData) where workspace contents will be saved in the repository</dd>\n         *\n         *    <dt>storenewversion</dt>\n         *    <dd>(optional) if <code>true</code>, ensures each file stored in repository results in new version being created if needed</dd>\n         *\n         *    <dt>storepublic</dt>\n         *    <dd>(optional) if <code>true</code>, publishes each file stored in the repository</dd>\n         *\n         *    <dt>infinity</dt>\n         *    <dd>\n         *       (optional) specifies custom value for Infinity appearing in R object\n         *       data returned on call, otherwise Infinity is represented by\n         *       <code>0x7ff0000000000000L</code>\n         *    </dd>\n         *\n         *    <dt>nan</dt>\n         *    <dd>\n         *       (optional) specifies custom value for NaN appearing in R object data\n         *       returned on call, otherwise NaN is represented by <code>null</code>\n         *    </dd>\n         *\n         *    <dt>encodeDataFramePrimitiveAsVector</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, data.frame primitives are encoded\n         *       vectors in R object data returned on call\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryScriptExecute: function(config, callback) {            \n            return this.io('/r/repository/script/execute', config, callback);\n        },\n\n\n        /**\n         * This call executes repository-managed scripts or external scripts on an\n         * Anonymous Project and returns a simple HTML page that displays the results\n         * generated on the execution.\n         *\n         * On a successful execution, the HTML page will display the following data\n         * when available on the response:\n         *\n         * <ul>\n         *    <li>R console output</li>\n         *    <li>R workspace object data</li>\n         *    <li>R generated plots</li>\n         *    <li>Links to R working directory artifacts</li>\n         *    <li>Links to Repository stored artifacts</li>\n         * </ul>\n         *\n         * On a failed execution, the HTML page will display an error message\n         * indicating the cause of the failure and when available, R console output.\n         *\n         * The API call makes it very simple to integrate outputs generated by\n         * RevoDeployR-managed R scripts into any third-party application. It can also\n         * be used as a very simple test and debugging aid for R script and\n         * application developers.\n         *\n         * To execute a single repository-managed script the caller must provide\n         * parameter values for filename , author and optionally version . To execute\n         * a chain of repository-managed scripts the caller must provide a\n         * comma-separated list of values on the filename , author and optionally\n         * version parameters.\n         *\n         * To execute a single external script the caller must provide a valid URL or\n         * file path using the externalsource parameter. To execute a chain of\n         * external scripts the caller must provide a comma-separated list of values\n         * on the externalsource parameter. Note, to execute an external script the\n         * caller must have POWER_USER privileges so this feature is not available to\n         * anonymous users on this call.\n         *\n         * Note: A chained execution executes each of the scripts identified on the\n         * call in a sequential fashion on the R session, with execution occuring in\n         * the order specified on the parameter list.\n         *\n         * Please note the following pre and post execution parameters:\n         *\n         * <strong>Pre-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The inputs parameter allows the caller to pass RevoDeployR-encoded\n         *       R object values as inputs. These inputs are turned into R objects\n         *       in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The csvinputs parameter allows the caller to pass R object primitive\n         *       values as comma-separated name/value pairs. These inputs are turned\n         *       into R objects in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadfile parameters allows the caller to load one or more\n         *       files from the repository into the working directory before the\n         *       execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadobject parameters allow the caller to load one or more\n         *       binary R objects (.rData) from the repository into the workspace\n         *       before the execution begins.\n         *    </li>\n         *    <li>\n         *       The adopt parameters allow the caller to load a pre-existing\n         *       project workspace, project working directory and/or project package\n         *       dependencies before the execution begins.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Post-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The robjects parameter allows the caller to specify a comma-separated\n         *       list of object names that will be returned as RevoDeployR-encoded R\n         *       objects on the response markup after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storefile parameter allows the caller to specify a comma-separated\n         *       list of working directory files to be stored in the repository after\n         *       the execution completes.\n         *    </li>\n         *    <li>\n         *       The storeobject parameter allows the caller to specify a comma-separated\n         *       list of workspace objects to be stored in the repository after the\n         *       execution completes.\n         *    </li>\n         *    <li>\n         *       The storeworkspace parameter allows the caller to store the entire\n         *       workspace in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storedirectory parameter allows the caller to specify a target\n         *       repository directory for stored files and objects after the execution\n         *       completes.\n         *    </li>\n         *    <li>\n         *       The storenewversion parameter allows the caller to create new\n         *       versions of each stored file in the repository after the execution\n         *       completes. By default, stored files overwrite any pre-existing file\n         *       by the same name.\n         *    </li>\n         *    <li>\n         *       The storepublic parameter allows the caller to assign public access\n         *       to each stored file in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *      The infinity , nan and encodeDataFramePrimitiveAsVector parameters\n         *      allow the caller to control how RevoDeployR-encoded R object data is\n         *      encoded in the response markkup.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Some key data indicated in the response markup on this call:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       console - indicates the R console output resulting from the execution\n         *    </li>\n         *    <li>\n         *       results - indicates the list of files generated by the R graphics\n         *       device\n         *    </li>\n         *    <li>\n         *       artifacts - indicates the list of files generated or modified in the\n         *       working directory\n         *    </li>\n         *    <li>\n         *       objects -  indicates the list of R objects returned from the\n         *       workspace\n         *    </li>\n         *    <li>\n         *       files - indicates the list of files and objects stored in the\n         *       repository after the execution completes\n         *    </li>\n         *    <li>\n         *       interrupted - indicates the interrupted status of execution\n         *    </li>\n         *    <li>\n         *       error - on failure, indicates the reason for failure\n         *    </li>\n         *    <li>\n         *       errorCode - on failure, indicates the error code for failure\n         *    </li>\n         * </ol>\n         *\n         * @method repositoryScriptRender\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of repository-managed script\n         *       filenames\n         *    </dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) comma-separated list of repository-managed directories for\n         *       scripts, defaults to root\n         *    </dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>\n         *       (optional) comma-separated list of authors, one author per filename\n         *    </dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>\n         *       (optional) comma-separated list of versions, one version per filename\n         *    </dd>\n         *\n         *    <dt>externalsource</dt>\n         *    <dd>\n         *       (optional) comma-separated list of URLs or file paths to external\n         *       scripts\n         *    </dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded script inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *\n         *    <dt>preloadfileversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *\n         *    <dt>preloadobjectname</dt>\n         *    <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *\n         *    <dt>adoptworkspace</dt>\n         *    <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *\n         *    <dt>adoptdirectory</dt>\n         *    <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *\n         *    <dt>adoptpackages</dt>\n         *    <dd>(optional) identifies project from which package dependencies are to be adopted</dd>\n         *\n         *      <dt>blackbox</dt>\n         *      <dd>(optional) if true, the execution will occur on the HTTP blackbox project for the current HTTP session</dd>\n         *\n         *      <dt>recycle</dt>\n         *      <dd>(optional) if true, recycles the R session associated with the HTTP blackbox project on the current HTTP session</dd>\n         *\n         *    <dt>tag</dt>\n         *    <dd>(optional) specifies a tag that labels the execution</dd>\n         *\n         *    <dt>echooff</dt>\n         *    <dd>(optional) if true R commands will not appear in the console output</dd>\n         *\n         *    <dt>consoleoff</dt>\n         *    <dd>(optional) if true console output is not returned in the response markup</dd>\n         *\n         *    <dt>graphics</dt>\n         *    <dd>(optional) specifies preferred R graphics device for execution: png or svg</dd>\n         *\n         *    <dt>graphicswidth</dt>\n         *    <dd>(optional) specifies preferred width for R graphics device images</dd>\n         *\n         *    <dt>graphicsheight</dt>\n         *    <dd>(optional) specifies preferred height for R graphics device images</dd>\n         *\n         *    <dt>robjects</dt>\n         *    <dd>(optional) specifies a comma-separated list of objects for retrieval following the execution</dd>\n         *\n         *    <dt>storefile</dt>\n         *    <dd>(optional) comma-separated list of working directory filenames</dd>\n         *\n         *    <dt>storeobject</dt>\n         *    <dd>(optional) comma-separated list of workspace object names</dd>\n         *\n         *    <dt>storeworkspace</dt>\n         *    <dd>(optional) filename (.rData) where workspace contents will be saved in the repository</dd>\n         *\n         *    <dt>storenewversion</dt>\n         *    <dd>(optional) if <code>true</code>, ensures each file stored in repository results in new version being created if needed</dd>\n         *\n         *    <dt>storepublic</dt>\n         *    <dd>(optional) if <code>true</code>, publishes each file stored in the repository</dd>\n         *\n         *    <dt>infinity</dt>\n         *    <dd>\n         *       (optional) specifies custom value for Infinity appearing in R object\n         *       data returned on call, otherwise Infinity is represented by\n         *       0x7ff0000000000000L\n         *    </dd>\n         *\n         *    <dt>nan</dt>\n         *    <dd>\n         *       (optional) specifies custom value for NaN appearing in R object data\n         *       returned on call, otherwise NaN is represented by null\n         *    </dd>\n         *\n         *    <dt>encodeDataFramePrimitiveAsVector</dt>\n         *    <dd>\n         *       (optional) if true, data.frame primitives are encoded vectors in R\n         *       object data returned on call\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryScriptRender: function(config, callback) {\n            return this.io('/r/repository/script/render', config, callback);\n        },\n\n        /**\n         * This call interrupts the current execution on the HTTP Blackbox project\n         * associated with the current HTTP session.\n         *\n         * @method repositoryScriptInterrupt\n         * @static\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryScriptInterrupt: function(callback) {            \n            return this.io('/r/repository/script/interrupt', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Repository File APIs\n        /////////////////////////////////////\n\n        /**\n         * This call lists repository-managed files.\n         *\n         * @method repositoryFiletList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) when specified, call returns list of script versions for\n         *       filename\n         *   </dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files that are restricted but\n         *       visible or shared by other users are included in the response markup\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, scripts published by other users are\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>categoryFilter</dt>\n         *    <dd>\n         *       (optional) when specified list of files in response markup is limited\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileList: function(config, callback) {            \n            return this.io('/r/repository/file/list', config, callback);\n        },\n        /**\n         * This call uploads a file from the user's computer to the repository.\n         *\n         * @method repositoryFileUpload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies name of the file to upload</dd>\n         *\n         *    <dt>file</dt>\n         *    <dd>...file content...</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies a description to associate with the uploaded file</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>(optional) specifies tag words to associate with the repository file</dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>(optional) (optional) comma-separated list of role names, which makes the file visible to authenticated users with these roles</dd>\n         *\n         *     <dt>shared</dt>\n         *     <dd>(optional) if true, the file will be shared which makes the file visible to authenticated users</dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>(optional) if true, the file will be published which makes the file visible to authenticated and anonymous users</dd>\n         *\n         *    <dt>newversion</dt>\n         *    <dd>(optional) if true, the repository will create new version rather than overwrite</dd>\n         *\n         *    <dt>newversionmsg</dt>\n         *    <dd>(optional) if newversion is true, message to associate with new version</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) specifies the inputs property on a repository-managed script</dd>\n         *\n         *    <dt>outputs</dt>\n         *    <dd>(optional) specifies the outputs property on a repository-managed script</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileUpload: function(config, callback) {\n            config.format = \"text\";\n            var ioConfig = {\n                data: config,\n                method: \"POST\",\n                form: {\n                    id: config.formId\n                },\n                on: callback\n            };\n            return this.io('/r/repository/file/upload', config, callback);\n        },\n\n        /**\n         * This call transfers a file from a URL to the repository.\n         *\n         * @method repositoryFileTransfer\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies name of the file to upload</dd>\n         *\n         *    <dt>url</dt>\n         *    <dd>specifies a url of the file to upload</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies a description to associate with the uploaded file</dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>(optional) specifies tag words to associate with the repository file</dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>(optional) (optional) comma-separated list of role names, which makes the file visible to authenticated users with these roles</dd>\n         *\n         *     <dt>shared</dt>\n         *     <dd>(optional) if true, the file will be shared which makes the file visible to authenticated users</dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>(optional) if true, the file will be published which makes the file visible to authenticated and anonymous users</dd>\n         *\n         *    <dt>newversion</dt>\n         *    <dd>(optional) if true, the repository will create new version rather than overwrite</dd>\n         *\n         *    <dt>newversionmsg</dt>\n         *    <dd>(optional) if newversion is true, message to associate with new version</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) specifies the inputs property on a repository-managed script</dd>\n         *\n         *    <dt>outputs</dt>\n         *    <dd>(optional) specifies the outputs property on a repository-managed script</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileTransfer: function(config, callback) {\n            return this.io('/r/repository/file/transfer', config, callback);\n        },\n\n        /**\n         * This call writes a text file to the repository.\n         *\n         * @method repositoryFileWrite\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies name of the file to upload</dd>\n         *\n         *    <dt>text</dt>\n         *    <dd>specifies the text content of the file to upload</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>\n         *       (optional) specifies a description to associate with the uploaded\n         *       file\n         *    </dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>\n         *       (optional) specifies tag words to associate with the repository file\n         *    </dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *       (optional) (optional) comma-separated list of role names, which makes\n         *       the file visible to authenticated users with these roles\n         *    </dd>\n         *\n         *    <dt>share</dt>\n         *    <dd>\n         *       (optional) if true, ile is shared and visible to authenticated users\n         *    </dd>\n         *\n         *    <dt>publish</dt>\n         *    <dd>\n         *       (optional) if true, the file will be published which makes the file\n         *       visible to authenticated and anonymous users\n         *    </dd>\n         *\n         *    <dt>newversion</dt>\n         *    <dd>\n         *       (optional) if true, the repository will create new version rather\n         *       than overwrite\n         *    </dd>\n         *\n         *    <dt>newversionmsg</dt>\n         *    <dd>\n         *       (optional) if newversion is true, message to associate with new\n         *       version\n         *    </dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>\n         *       (optional) specifies the inputs property on a repository-managed\n         *       script\n         *    </dd>\n         *\n         *    <dt>outputs</dt>\n         *    <dd>\n         *       (optional) specifies the outputs property on a repository-managed\n         *       script\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileWrite: function(config, callback) {\n            return this.io('/r/repository/file/write', config, callback);\n        },\n\n        /**\n         * This call updates the properties on a repository-managed file.\n         *\n         * @method repositoryFileUpdate\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies name of the file to upload</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies a description to associate with the uploaded file</dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>(optional) specifies tag words to associate with the repository file</dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *       (optional) (optional) comma-separated list of role names, which makes\n         *       the file visible to authenticated users with these roles\n         *    </dd>\n         *\n         *     <dt>shared</dt>\n         *     <dd>(optional) if true, the file will be shared which makes the file visible to authenticated users</dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>(optional) if true, the file will be published which makes the file visible to authenticated and anonymous users</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) specifies the inputs property on a repository-managed script</dd>\n         *\n         *    <dt>outputs</dt>\n         *    <dd>(optional) specifies the outputs property on a repository-managed script</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileUpdate: function(config, callback) {\n            return this.io('/r/repository/file/update', config, callback);\n        },\n\n        /**\n         * This call reverts the current working copy of a file to a specific version\n         * found in the files version history.\n         *\n         * @method repositoryFileRevert\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies name of the file to upload</dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>specifies the repository file version to revert into the current working copy</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies a description to associate with the uploaded file</dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>(optional) (optional) comma-separated list of role names, which makes the file visible to authenticated users with these roles</dd>\n         *\n         *     <dt>shared</dt>\n         *     <dd>(optional) if true, the file will be shared which makes the file visible to authenticated users</dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>(optional) if true, the file will be published which makes the file visible to authenticated and anonymous users</dd>\n         *\n         *    <dt>newversion</dt>\n         *    <dd>(optional) if true, the repository will create new version rather than overwrite</dd>\n         *\n         *    <dt>newversionmsg</dt>\n         *    <dd>(optional) if newversion is true, message to associate with new version</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) specifies the inputs property on a repository-managed script</dd>\n         *\n         *    <dt>outputs</dt>\n         *    <dd>(optional) specifies the outputs property on a repository-managed script</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileRevert: function(config, callback) {\n            return this.io('/r/repository/file/revert', config, callback);\n        },\n\n        /**\n         * This call generates a diff between the current working copy of a file and\n         * a specific version found in the files version history.\n         *\n         * @method repositoryFileDiff\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies the repository file name</dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>specifies the repository file author</dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>\n         *       specifies the repository file version to diff against the current\n         *       working copy\n         *    </dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileDiff: function(config, callback) {\n            return this.io('/r/repository/file/diff', config, callback);\n        },\n\n        /**\n         * This call grants ownership rights on a file to one or more authenticated\n         * users.\n         *\n         * Note, unlike most repository APIs that require both filename and author\n         * parameters, there is no explicit author parameter on this call. The author\n         * is understood to be the caller.\n         *\n         * @method repositoryFileGrant\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies the name of the repository file</dd>\n         *\n         *    <dt>newauthor</dt>\n         *    <dd> specifies a comma-separated list of grantee usernames</dd>\n         *\n         *    <dt>revokeauthor</dt>\n         *    <dd>\n         *       (optional) specifies a comma-separated list of revokee usernames\n         *    </dd>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileGrant: function(config, callback) {\n            return this.io('/r/repository/file/grant', config, callback);\n        },\n\n        /**\n         * This call downloads a repository-managed file.\n         *\n         * @method repositoryFileDownload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *      <dt>filename</dt>\n         *      <dd>specifies the repository file name</dd>\n         *\n         *      <dt>author</dt>\n         *      <dd>specifies the repository author</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *      <dt>version</dt>\n         *      <dd>(optional) specifies the repository file version</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileDownload: function(config, callback) {\n            return this.io('/r/repository/file/download', config, callback);\n        },\n\n        /**\n         * This call deletes a file from the repository.\n         *\n         * @method repositoryFileDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *      <dt>filename</dt>\n         *      <dd>specifies the repository file name</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileDelete: function(config, callback) {\n            return this.io('/r/repository/file/delete', config, callback);\n        },\n\n        /**\n         * This call fetches the latest meta-data on a file in the repository.\n         *\n         * @method repositoryFileFetch\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *      <dt>filename</dt>\n         *      <dd>specifies the repository file name</dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>\n         *       (optional) specifies the repository file author\n         *    </dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>\n         *       (optional) specifies the repository file version\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileFetch: function(config, callback) {\n            return this.io('/r/repository/file/fetch', config, callback);\n        },\n\n        /**\n         * This call copies one or more repository-managed files to the destination\n         * directory.\n         *\n         * If the destination directory already contains a filename matching an\n         * incoming filename, then a new version of the file is automatically created.\n         *\n         * @method repositoryFileCopy\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *      <dt>filename</dt>\n         *      <dd>specifies the repository file name</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>destination</dt>\n         *    <dd>\n         *       (optional) specifies the name of the destination user directory in\n         *       the repository\n         *    </dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>\n         *       (optional) specifies the repository file version\n         *    </dd>\n         *\n         *    <dt>filerename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of new filenames for copied files\n         *       identified on filename parameter\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileCopy: function(config, callback) {            \n            return this.io('/r/repository/file/copy', config, callback);\n        },\n\n        /**\n         * This call moves one or more repository-managed files to the destination\n         * directory.\n         *\n         * If the destination directory already contains a filename matching an\n         * incoming filename, then a new version of the file is automatically created.\n         *\n         * @method repositoryFileMove\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *      <dt>filename</dt>\n         *      <dd>specifies the repository file name</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>destination</dt>\n         *    <dd>\n         *       (optional) specifies the name of the destination user directory in\n         *       the repository\n         *    </dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>\n         *       (optional) specifies the repository file version\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileMove: function(config, callback) {            \n            return this.io('/r/repository/file/move', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Repository Directory APIs\n        /////////////////////////////////////\n\n        /**\n         * This call lists repository-managed directories.\n         * By default, a list of the caller's user directories ( root and custom ) are\n         * returned in the response markup.\n         *\n         * If the userfiles parameter is specified, the files in all of the caller's\n         * user directories are listed in the response markup. Note, depending on the\n         * number of files owned by the caller, when this parameter is enabled the\n         * response markup returned on this call can be a verbose.\n         *\n         * If the directory parameter is specified then only the files in the\n         * directory indicated are returned in the response markup.\n         *\n         * Additional parameters are provided to return files in the caller's archived\n         * directories and/or files in the Restricted , Shared and Public system\n         * directories.\n         *\n         * Note: The metadata property in the response markup on this call is provided\n         * as a convenience for client application developers. It provides a complete\n         * list fo the user directories available to the current caller.\n         *\n         * @method repositoryDirectoryList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>userfiles</dt>\n         *    <dd>\n         *       (optional) if specified, files in all user directories are listed in\n         *       the response markup\n         *    </dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>archived</dt>\n         *    <dd>\n         *       (optional) if true, files found in archived directories are included\n         *       in the response markup\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if true, files that are restricted but visible or shared\n         *       by other users are included in the response markup\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if true, files that are published by other users are\n         *       included in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryList: function(config, callback) {            \n            return this.io('/r/repository/directory/list', config, callback);\n        },\n\n        /**\n         * This call creates a repository-managed custom directory.\n         *\n         * If the name of the new custom directory is already in use by the caller the\n         * response markup will indicate an appropriate error.\n         *\n         * @method repositoryDirectoryList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryCreate: function(config, callback) {            \n            return this.io('/r/repository/directory/create', config, callback);\n        },\n\n        /**\n         * This call renames an existing repository-managed user directory\n         * ( custom or archived ). When renaming a user directory, all files in the\n         * source directory are automatically moved to the destination directory. If\n         * the destination directory already exists the call will be rejected and the\n         * response markup will indicate an appropriate error.\n         *\n         * You can use this call to convert an archived directory back into a custom\n         * directory, essentially unarchiving the archived directory.\n         *\n         * Note: You can not rename the root directory. To move files from the root\n         * directory use the /r/repository/directory/move call.\n         *\n         * <strong>Important:</strong>\n         *\n         * This call will only move files that are owned by a single author to the\n         * destination directory. If a repository-managed file in the source directory\n         * has multiple authors, as a result of collaboration using the\n         * /r/repository/file/grant call, the file will not be moved to the\n         * destination directory and a warning to that affect will be indicated in the\n         * response markup.\n         *\n         * @method repositoryDirectoryRename\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>destination</dt>\n         *    <dd>\n         *       (optional) specifies the new name for the destination custom directory\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryRename: function(config, callback) {           \n            return this.io('/r/repository/directory/rename', config, callback);\n        },\n\n        /** \n         * This call copies one or more repository-managed files from a source user\n         * directory to a destination user directory.\n         *\n         * If the filename parameter is specified, only those files indicated on that\n         * parameter are copied. Otherwise, all files in the source directory are\n         * copied.\n         *\n         * To ensure copying files does not accidentally overwrite any existing files\n         * in the destination directory, all copied files are created as new versions\n         * in the destination directory.\n         *\n         * @method repositoryDirectoryCopy\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>destination</dt>\n         *    <dd>\n         *       (optional) specifies the new name for the destination custom directory\n         *    </dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of filenames to be copied. If omitted,\n         *       all files in the source directory are copied\n         *    </dd>\n         *\n         *    <dt>filerename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of new filenames for copied files\n         *       identified on filename parameter\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryCopy: function(config, callback) {            \n            return this.io('/r/repository/directory/copy', config, callback);\n        },\n\n        /**\n         * This call moves one or more repository-managed files from a source user\n         * directory to a destination user directory.\n         *\n         * If the filename parameter is specified, only those files indicated on that\n         * parameter are moved. Otherwise, all files in the source directory are moved.\n         *\n         * To ensure moving files does not accidentally overwrite any existing files\n         * in the destination directory, all moved files are created as new versions\n         * in the destination directory.\n         *\n         * <strong>Important:</strong>\n         *\n         * This call will only move files that are owned by a single author to the\n         * destination directory. If a repository-managed file in the source directory\n         * has multiple authors, as result of collaboration using the\n         * /r/repository/file/grant call, the file will not be moved to the\n         * destination directory and a warning to that affect will be indicated in the\n         * response markup.\n         *\n         * @method repositoryDirectoryMove\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>destination</dt>\n         *    <dd>\n         *       (optional) specifies the new name for the destination custom directory\n         *    </dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of filenames to be copied. If omitted,\n         *       all files in the source directory are copied\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryMove: function(config, callback) {            \n            return this.io('/r/repository/directory/move', config, callback);\n        },\n\n        /**\n         * This call updates repository-managed file access controls by directory.\n         *\n         * If the filename parameter is specified, only those files indicated on that\n         * parameter are updated. Otherwise, all files in the source directory are\n         * updated.\n         *\n         * @method repositoryDirectoryUpdate\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of filenames to be copied. If omitted,\n         *       all files in the source directory are copied\n         *    </dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *       (optional) specifies the new name for the destination custom directory\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files are shared and visible to\n         *       authenticated users\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files are published and visible to\n         *       authenticated and anonymous users\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryUpdate: function(config, callback) {\n            return this.io('/r/repository/directory/update', config, callback);\n        },\n\n        /**\n         * This call archives one or more repository-managed files from a source user\n         * directory ( root or custom ) to an archive directory.\n         *\n         * If the value of the archive parameter indicates an existing archive\n         * directory then the files in the source directory are added to the existing\n         * archive. Otherwise, a new archive directory is automatically created on\n         * behalf of the caller. Archived directories automatically have a .archive\n         * postfix appended to their name if it is not supplied on the archive\n         * parameter value.\n         *\n         * If all of the files in the source directory are successfully archived, the\n         * source directory is automatically deleted from the repository. If the\n         * source directory was root , an empty root directory is preserved. If any of\n         * the files in the source directory are skipped or can not be archived (see\n         * following note), those files and the source directory are preserved.\n         *\n         * <strong>Important:</strong>\n         *\n         * This call will only archive files that are owned by a single author to the\n         * destination directory. If a repository-managed file in the source directory\n         * has multiple authors, as a result of collaboration using the\n         * /r/repository/file/grant call, the file will not be archived to the\n         * destination directory and a warning to that affect will be indicated in the\n         * response markup.\n         *\n         * @method repositoryDirectoryArchive\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of filenames to be copied. If omitted,\n         *       all files in the source directory are copied\n         *    </dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *       (optional) specifies the new name for the destination custom directory\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files are shared and visible to\n         *       authenticated users\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files are published and visible to\n         *       authenticated and anonymous users\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryArchive: function(config, callback) {\n\n            return this.io('/r/repository/directory/archive', config, callback);\n        },\n\n        /**\n         * This call uploads a set of files in a zip archive into an existing\n         * repository-managed user directory ( root , custom or archived ).\n         *\n         * @method repositoryDirectoryUpload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>file</dt>\n         *    <dd>\n         *       ...zip archive file content...\n         *    </dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>\n         *       (optional) specifies a description to associate with the uploaded file\n         *    </dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>\n         *       (optional) specifies tag words to associate with the repository file\n         *    </dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *       (optional) specifies the new name for the destination custom directory\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files are shared and visible to\n         *       authenticated users\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files are published and visible to\n         *       authenticated and anonymous users\n         *    </dd>\n         *\n         *    <dt>newversion</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, the repository will create new\n         *       version rather than overwrite\n         *    </dd>\n         *\n         *    <dt>newversionmsg</dt>\n         *    <dd>\n         *       (optional) if newversion is true, message to associate with new\n         *       version\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryUpload: function(config, callback) {\n            config = config || {};\n            config.format = 'text';\n            var ioConfig = {\n                data: config,\n                method: 'POST',\n                form: {\n                    id: config.formId\n                },\n                on: callback\n            };\n            return this.io('/r/repository/directory/upload', config, callback);\n        },\n\n        /**\n         * This call downloads one or more repository-managed files from a directory\n         * in the repository. The response type on this call is a zip archive file.\n         *\n         * If the filename parameter is specified, only those files indicated on that\n         * parameter are downloaded. Otherwise, all files in the source directory are\n         * downloaded.\n         *\n         * @method repositoryDirectoryDownload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of filenames to be copied. If omitted,\n         *       all files in the source directory are copied\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryDownload: function(config, callback) {            \n            return this.io('/r/repository/directory/download', config, callback);\n        },\n\n        /**\n         * This call deletes a repository-managed user directory ( root , custom or\n         * archived ).\n         *\n         * When deleting a user directory, all files in the directory are\n         * automatically deleted along with the directory. If the target directory is\n         * root, an empty root directory is preserved.\n         *\n         * @method repositoryDirectoryDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryDelete: function(config, callback) {\n            return this.io('/r/repository/directory/delete', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Job APIs\n        /////////////////////////////////////\n\n        /**  \n         * This call lists jobs for the currently authenticated user.\n         *\n         * The openonly parameter allows the caller to see only those jobs in an open\n         * state. The set of job open states are shown here:\n         *\n         * <ul>\n         *  <li>Scheduled : job is scheduled but not yet queued for running.</li>\n         *  <li>Queued : job is queued for running.</li>\n         *  <li>Running : job is running.</li>\n         * </ul>\n         *\n         * <blockquote>\n         *    Important! Any open job can be cancelled using the\n         *    <a href=\"#method_jobCancel\">jobCancel</a> call.\n         * </blockquote>\n         *\n         * @method jobList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>openonly</dt>\n         *    <dd>\n         *       (optional) if true, only jobs in an open-state are listed in the\n         *       response markup\n         *    </dd>\n         *\n         *    <dt>extended</dt>\n         *    <dd>\n         *       (optional) If true, additional data properties describing each job\n         *       are listed in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        jobList: function(config, callback) {\n            return this.io('/r/job/list', config, callback);\n        },\n\n        /**\n         * This call submits a job for background execution on behalf of the user.\n         *\n         * To submit the execution of an arbitrary block of R code the caller must\n         * provide a value on the code parameter.\n         *\n         *\n         * To submit the execution of a single repository-managed script the caller\n         * must provide parameter values for rscriptname , rscriptauthor and\n         * optionally rscriptversion . To submit the execution of a chain of\n         * repository-managed scripts the caller must provide a comma-separated list\n         * of values on the rscriptname,, _rscriptauthor and optionally rscriptversion\n         * parameters.\n         *\n         *\n         * To submit the execution of a single external script the caller must\n         * provide a valid URL or file path using the externalsource parameter. To\n         * submit the execution of a chain of external scripts the caller must\n         * provide a comma-separated list of values on the externalsource parameter.\n         * Note, to submit the execution of an external script the caller must have\n         * POWER_USER privileges.\n         *\n         * Note: A chained execution executes each of the scripts identified on the\n         * call in a sequential fashion on the R session for the job, with execution\n         * occuring in the order specified on the parameter list.\n         *\n         * Please not the following pre and post execution parameters:\n         *\n         * <strong>Pre-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The inputs parameter allows the caller to pass RevoDeployR-encoded\n         *       R object values as inputs. These inputs are turned into R objects\n         *       in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadfile parameters allows the caller to load one or more\n         *       files from the repository into the working directory before the\n         *       execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadobject parameters allow the caller to load one or more\n         *       binary R objects (.rData) from the repository into the workspace\n         *       before the execution begins.\n         *    </li>\n         *    <li>\n         *       The adopt parameters allow the caller to load a pre-existing\n         *       project workspace, project working directory and/or project package\n         *       dependencies before the execution begins.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Post-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The storefile parameter allows the caller specify a comma-separated\n         *       list of working directory files to be stored in the repository after\n         *       the execution completes.\n         *    </li>\n         *    <li>\n         *       The storeobject parameter allows the caller specify a comma-separated\n         *       list of workspace objects to be stored in the repository after the\n         *       execution completes.\n         *    </li>\n         *    <li>\n         *       The storeworkspace parameter allows the caller to store the entire\n         *       workspace in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storedirectory parameter allows the caller to specify a target\n         *       repository directory for stored files and objects after the execution\n         *       completes.\n         *    </li>\n         *    <li>\n         *       The storenewversion parameter allows the caller to create new\n         *       versions of each stored file in the repository after the execution\n         *       completes. By default, stored files overwrite any pre-existing file\n         *       by the same name.\n         *    </li>\n         *    <li>\n         *       The storepublic parameter allows the caller to assign public access\n         *       to each stored file in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storenoproject parameter allows the caller to skip the\n         *       persistence-to-project step after the execution.\n         *    </li>\n         * </ol>\n         *\n         * @method jobSubmit\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>name</dt>\n         *    <dd>job name</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) job description</dd>\n         *\n         *    <dt>code</dt>\n         *    <dd>(optional) R code to execute on job</dd>\n         *\n         *      <dt>rscriptname</dt>\n         *      <dd>(optional) comma-separated list of repository-managed script filenames</dd>\n         *\n         *    <dt>rscriptdirectory</dt>\n         *    <dd>(optional) comma-separated list of repository-managed directories for scripts, defaults to root</dd>\n         *\n         *      <dt>rscriptauthor</dt>\n         *      <dd>(optional) comma-separated list of authors, author-per-rscriptname</dd>\n         *\n         *      <dt>rscriptversion</dt>\n         *      <dd>(optional) comma-separated list of versions, version-per-rscriptname</dd>\n         *\n         *      <dt>externalsource</dt>\n         *      <dd>(optional) comma-separated list of URLs or file paths to external scripts</dd>\n         *\n         *      <dt>inputs</dt>\n         *      <dd>(optional) RevoDeployR-encoded script inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *      <dt>preloadfilename</dt>\n         *      <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *      <dt>preloadfileauthor</dt>\n         *      <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *\n         *      <dt>preloadfileversion</dt>\n         *      <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *\n         *      <dt>preloadobjectname</dt>\n         *      <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *\n         *      <dt>preloadobjectauthor</dt>\n         *      <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *\n         *      <dt>preloadobjectversion</dt>\n         *      <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *\n         *      <dt>adoptworkspace</dt>\n         *      <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *\n         *      <dt>adoptdirectory</dt>\n         *      <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *\n         *      <dt>adoptpackages</dt>\n         *      <dd>(optional) identifies project from which package dependencies are to be adopted</dd>\n         *\n         *      <dt>priority</dt>\n         *      <dd>(optional) specifies the scheduling priority for the job: low (default), medium or high</dd>\n         *\n         *      <dt>tag</dt>\n         *      <dd>(optional) specifies a tag that labels the execution</dd>\n         *\n         *      <dt>echooff</dt>\n         *      <dd>\n         *       (optional) if true R commands will not appear in the console output\n         *       saved on the project execution history for the job\n         *    </dd>\n         *\n         *      <dt>graphics</dt>\n         *      <dd>(optional) specifies preferred R graphics device for execution: png or svg</dd>\n         *\n         *      <dt>graphicswidth</dt>\n         *      <dd>(optional) specifies preferred width for R graphics device images</dd>\n         *\n         *      <dt>graphicsheight</dt>\n         *      <dd>(optional) specifies preferred height for R graphics device images</dd>\n         *\n         *      <dt>storefile</dt>\n         *      <dd>(optional) comma-separated list of working directory filenames</dd>\n         *\n         *      <dt>storeobject</dt>\n         *      <dd>(optional) comma-separated list of workspace object names</dd>\n         *\n         *      <dt>storeworkspace</dt>\n         *      <dd>(optional) filename (.rData) where workspace contents will be saved in the repository</dd>\n         *\n         *      <dt>storenewversion</dt>\n         *      <dd>(optional) if <code>true</code>, ensures each file stored in repository results in new version being created if needed</dd>\n         *\n         *      <dt>storepublic</dt>\n         *      <dd>(optional) if <code>true</code>, publishes each file stored in the repository</dd>\n         *\n         *      <dt>storenoproject</dt>\n         *      <dd>(optional) if <code>true</code>, no project persistence following job execution</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        jobSubmit: function(config, callback) {            \n            return this.io('/r/job/submit', config, callback);\n        },\n\n        /**\n         * This call schedules a job for background execution on behalf of the user.\n         *\n         * The schedstart parameter identifies the start time for the job. This\n         * parameter value is specified as UTC in milliseconds. The schedrepeat\n         * parameter indicates the number of times the job is to be repeated, and if\n         * omitted the job is executed just once. The schedinterval parameter\n         * indicates the interval, measured in milliseconds, between repeat\n         * executions.\n         *\n         * To schedule the execution of an arbitrary block of R code the caller\n         * must provide a value on the code parameter.\n         *\n         * To schedule the execution of a single repository-managed script the\n         * caller must provide parameter values for rscriptname , rscriptauthor and\n         * optionally rscriptversion . To schedule the execution of a chain of\n         * repository-managed scripts the caller must provide a comma-separated list\n         * of values on the rscriptname,, _rscriptauthor and optionally rscriptversion\n         * parameters.\n         *\n         * To schedule the execution of a single external script the caller must\n         * provide a valid URL or file path using the externalsource parameter. To\n         * schedule the execution of a chain of external scripts the caller must\n         * provide a comma-separated list of values on the externalsource parameter.\n         * Note, to schedule the execution of an external script the caller must\n         * have POWER_USER privileges.\n         *\n         * Note: A chained execution executes each of the scripts identified on the\n         * call in a sequential fashion on the R session for the job, with\n         * execution occuring in the order specified on the parameter list.\n         *\n         * Please not the following pre and post execution parameters:\n         *\n         * <strong>Pre-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The inputs parameter allows the caller to pass RevoDeployR-encoded\n         *       R object values as inputs. These inputs are turned into R objects\n         *       in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadfile parameters allows the caller to load one or more\n         *       files from the repository into the working directory before the\n         *       execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadobject parameters allow the caller to load one or more\n         *       binary R objects (.rData) from the repository into the workspace\n         *       before the execution begins.\n         *    </li>\n         *    <li>\n         *       The adopt parameters allow the caller to load a pre-existing\n         *       project workspace, project working directory and/or project package\n         *       dependencies before the execution begins.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Post-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The storefile parameter allows the caller specify a comma-separated\n         *       list of working directory files to be stored in the repository after\n         *       the execution completes.\n         *    </li>\n         *    <li>\n         *       The storeobject parameter allows the caller specify a comma-separated\n         *       list of workspace objects to be stored in the repository after the\n         *       execution completes.\n         *    </li>\n         *    <li>\n         *       The storeworkspace parameter allows the caller to store the entire\n         *       workspace in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storedirectory parameter allows the caller to specify a target\n         *       repository directory for stored files and objects after the execution\n         *       completes.\n         *    </li>\n         *    <li>\n         *       The storenewversion parameter allows the caller to create new\n         *       versions of each stored file in the repository after the execution\n         *       completes. By default, stored files overwrite any pre-existing file\n         *       by the same name.\n         *    </li>\n         *    <li>\n         *       The storepublic parameter allows the caller to assign public access\n         *       to each stored file in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storenoproject parameter allows the caller to skip the\n         *       persistence-to-project step after the execution.\n         *    </li>\n         * </ol>\n         *\n         * @method jobSchedule\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>name</dt>\n         *    <dd>job name</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) job description</dd>\n         *\n         *    <dt>schedstart</dt>\n         *    <dd>(optional) specifies the start time for job</dd>\n         *\n         *    <dt>schedrepeat</dt>\n         *    <dd>(optional) specifies the number of times job is to be repeated</dd>\n         *\n         *    <dt>schedinterval</dt>\n         *    <dd>(optional) specifies the interval (ms) on which job is to be repeated</dd>\n         *\n         *    <dt>code</dt>\n         *    <dd>(optional) R code to execute on job</dd>\n         *\n         *    <dt>rscriptname</dt>\n         *    <dd>(optional) comma-separated list of repository-managed script filenames</dd>\n         *\n         *    <dt>rscriptdirectory</dt>\n         *    <dd>(optional) comma-separated list of repository-managed directories for scripts, defaults to root</dd>\n         *\n         *    <dt>rscriptauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-rscriptname</dd>\n         *\n         *    <dt>rscriptversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-rscriptname</dd>\n         *\n         *    <dt>externalsource</dt>\n         *    <dd>(optional) comma-separated list of URLs or file paths to external scripts</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded script inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *\n         *    <dt>preloadfileversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *\n         *    <dt>preloadobjectname</dt>\n         *    <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *\n         *    <dt>adoptworkspace</dt>\n         *    <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *\n         *    <dt>adoptdirectory</dt>\n         *    <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *\n         *    <dt>adoptpackages</dt>\n         *    <dd>(optional) identifies project from which package dependencies are to be adopted</dd>\n         *\n         *      <dt>priority</dt>\n         *      <dd>(optional) specifies the scheduling priority for the job: low (default), medium or high</dd>\n         *\n         *    <dt>tag</dt>\n         *    <dd>(optional) specifies a tag that labels the execution</dd>\n         *\n         *    <dt>echooff</dt>\n         *    <dd>\n         *       (optional) if true R commands will not appear in the console output\n         *       saved on the project execution history for the job\n         *    </dd>\n         *\n         *    <dt>consoleoff</dt>\n         *    <dd>\n         *       (optional) if true console output is not saved on the project\n         *       execution history for the job\n         *    </dd>\n         *\n         *    <dt>graphics</dt>\n         *    <dd>(optional) specifies preferred R graphics device for execution: png or svg</dd>\n         *\n         *    <dt>graphicswidth</dt>\n         *    <dd>(optional) specifies preferred width for R graphics device images</dd>\n         *\n         *    <dt>graphicsheight</dt>\n         *    <dd>(optional) specifies preferred height for R graphics device images</dd>\n         *\n         *    <dt>storefile</dt>\n         *    <dd>(optional) comma-separated list of working directory filenames</dd>\n         *\n         *    <dt>storeobject</dt>\n         *    <dd>(optional) comma-separated list of workspace object names</dd>\n         *\n         *    <dt>storeworkspace</dt>\n         *    <dd>(optional) filename (.rData) where workspace contents will be saved in the repository</dd>\n         *\n         *    <dt>storenewversion</dt>\n         *    <dd>(optional) if <code>true</code>, ensures each file stored in repository results in new version being created if needed</dd>\n         *\n         *    <dt>storepublic</dt>\n         *    <dd>(optional) if <code>true</code>, publishes each file stored in the repository</dd>\n         *\n         *    <dt>storenoproject</dt>\n         *    <dd>(optional) if <code>true</code>, no project persistence following job execution</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        jobSchedule: function(config, callback) {           \n            return this.io('/r/job/schedule', config, callback);\n        },\n\n        /**\n         * This call queries the job status. The status property will indicate one of\n         * the following values:\n         *\n         * Scheduled, Queued, Running, Completed, Cancelling, Cancelled, Interrupted,\n         * Aborted, Failed.\n         *\n         * @method jobQuery\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         * supports the following properties:\n         * <dl>\n         *    <dt>job</dt>\n         *    <dd>specifies a comma-separated list of job identifiers</dd>\n         *\n         *    <dt>extended</dt>\n         *    <dd>\n         *       (optional) if true, only jobs in an extended-state are listed in the\n         *       response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        jobQuery: function(config, callback) {\n            return this.io('/r/job/query', config, callback);\n        },\n\n        /**\n         * This call cancels the specified job.\n         *\n         * Only jobs in an open-state can be cancelled. The set of job open-states are\n         * shown here:\n         *\n         * <ul>\n         *    <li>Scheduled : job is scheduled but not yet queued for running.</li>\n         *    <li>Queued : job is queued for running.</li>\n         *    <li>Running : job is running.</li>\n         * </ul>\n         * @method jobCancel\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>job</dt>\n         *    <dd>specifies a comma-separated list of job identifiers</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        jobCancel: function(config, callback) {\n            return this.io('/r/job/list', config, callback);\n        },\n\n        /**\n         * This call deletes the specified job.\n         *\n         * Only jobs in one of the completed-states can be deleted. The set of job\n         * compelted-states are shown here:\n         *\n         * <ul>\n         *    <li>Completed : job execution has run to successful completion.</li>\n         *    <li>Interrupted : job execution has been interrupted.</li>\n         *    <li>Cancelled : job has been cancelled.</li>\n         *    <li>Aborted : job execution has been aborted.</li>\n         *    <li>Failed : job execution has resulted in failure.</li>\n         * </ul>\n         *\n         * Jobs in an open-state must first run to completion or be cancelled before\n         * they are eligible for deletion.\n         *\n         * <blockquote>\n         *    Important! Deleting jobs will not delete the projects that resulted from\n         *    those jobs.\n         * </blockquote>\n         *\n         * @method jobDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *  <dt>job</dt>\n         *  <dd>specifies a comma-separated list of job identifiers</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        jobDelete: function(config, callback) {\n            return this.io('/r/job/delete', config, callback);\n        }\n    } // DeployR\n\n};\n\nmodule.exports = Deprecated;","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nvar Base = require('./selfish').Base;\n\nfunction debug(msg) { }\n\nmodule.exports = Base.extend({\n\n  initialize: function() {\n    this.events = {};\n    this.scope  = null;\n  },\n\n  /**\n   * Adds a listener.  Multiple can be added per name.  Aliased as `on`.\n   *\n   * @param {String} name The name of the event\n   * @param {Function} handler A callback\n   * @return {Emitter} `this` for chaining      \n   */\n  on: function(name, handler) {\n    if (name in this.events === false) { this.events[name] = []; }        \n\n    this.events[name].push(handler);\n    debug('Emitter.on(\"' + name + '\")');\n\n    return this;\n  },\n\n  /**\n   * Triggers all matching listeners.\n   *\n   * @param {String} name The name of the event\n   * @return {Emitter} `this` for chaining   \n   */\n  emit: function(name) {\n    if (name in this.events === false) { return this; }\n\n    for (var i = 0; i < this.events[name].length; i++) {\n      debug('Fired event: \"' + name + '\"');\n      this.events[name][i].apply(this.scope || this, Array.prototype.slice.call(arguments, 1));       \n    }\n\n    return this;\n  },\n\n  /**\n   * Removes all matching listeners.\n   *\n   * @param {String} name The name of the event\n   * @return {Emitter} `this` for chaining\n   */\n  offAll: function(name) {\n    if (!name) {\n      for (var e in this.events) {\n        delete this.events[e];\n      }\n    } else {\n      if (name in this.events === false) { return this; }\n      delete this.events[name];        \n    }\n\n    return this;\n  },\n\n  /**\n   * Removes a listener based on an index.\n   *\n   * @private\n   * @param {String} name The name of the event\n   * @param {Number} index The index of the event \n   */\n  offAt: function(name, index) {\n    var array = this.events[name],\n        rest  = array.slice(index + 1);\n\n    array.length = index;\n    array.push.apply(array, rest);\n    this.events[name] = array;\n  },\n\n  /**\n   * Removes a listener based on the handler function.\n   *\n   * @param {String} name The name of the event\n   * @param {Function} handler The handler function to remove\n   * @return {Emitter} `this` for chaining\n   */\n  off: function(name, handler) {\n    if (name in this.events === false) { return this; }\n\n    // remove all events handlers by this name\n    if (!handler) {\n      return this.offAll(name);\n    } else { // remove all events handlers == 'handler' by this name\n      for (var i = 0; i < this.events[name].length; i++) {\n        if (this.events[name][i] == handler) {\n          this.offAt(name, i);\n          return this;\n        }\n      }\n    } \n\n    return this;\n  }\n\n}); ","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more\n * details.\n */\nvar Lang = require('./lang'),\n    RTypes = require('./rtypes'),\n    R = RTypes.r,\n    DeployR = RTypes.deployr;\n\nfunction formatDates(dates, type) {\n    var formats = [];\n\n    for (var i = 0; i < dates.length; i++) {\n        formats.push(formatDate(dates[i], type));\n    }\n\n    return formats;\n}\n\nfunction formatDate(date, type) {    \n   var year   = date.getFullYear(),\n       month  = (date.getMonth() + 1),\n       day    = date.getDate(),    \n       hour   = date.getHours(),\n       min    = date.getMinutes(),\n       sec    = date.getSeconds(),\n       zone   = date.getTimezoneOffset(),\n       format = '';\n\n       month  = (month < 10 ? '0' + month : month);\n       hour   = (hour < 10 ? '0' + hour : hour);\n       min    = (min < 10 ? '0' + min : min);\n       sec    = (sec < 10 ? '0' + sec : sec);       \n       format = year + '-' + month + '-' + day;\n\n    function leftZeroFill(number, targetLength, forceSign) {\n        var output = '' + Math.abs(number),\n            sign = number >= 0;\n\n        while (output.length < targetLength) {\n            output = '0' + output;\n        }\n        return (sign ? (forceSign ? '+' : '') : '-') + output;\n    }\n   \n    if (type === DeployR.RPOSIX_DATE || type === DeployR.RPOSIX_DATE_VECTOR) {\n        var time  = hour + ':' + min + ':' + sec,\n            a = -zone,\n            b = \"+\";\n\n        if (a < 0) {\n            a = -a;\n            b = \"-\";\n        }\n\n        zone = b + leftZeroFill((a / 60), 2) + '' + leftZeroFill(a % 60, 2);\n        format += (' ' + time + ' ' + zone);\n    }\n\n    return format;\n}\n\nfunction encodeEmbeddedDataframe(obj, rdf) {\n    var dfValue = obj.value;\n    for (var index = 0; index < dfValue.length; index++) {\n        var dfObj = dfValue[index];\n        if (dfObj.type === DeployR.RDATAFRAME) {\n            rdf = encodeEmbeddedDataframe(dfObj, rdf);\n        } else {\n            // format dates\n            if (RTypes.isDate(dfObj.type)) {\n                if (Lang.isArray(dfObj.value)) {\n                    dfObj.value = formatDates(dfObj.value, dfObj.type);\n                } else {\n                    dfObj.value = formatDate(dfObj.value, dfObj.type);\n                }\n            }\n\n            dfObj.type = RTypes.deployrToR(dfObj.type);\n            rdf.value.push(dfObj);            \n        }\n\n    }\n    return rdf;\n};\n\nfunction encodeDataframe(obj) {\n    var rdf = {\n            type: R.DATAFRAME,\n            value: [],\n            name: obj.name\n        },\n        dfValue = obj.value;\n\n    for (var index = 0; index < dfValue.length; index++) {\n        var dfObj = dfValue[index];\n\n        if (dfObj.type === DeployR.RDATAFRAME) {\n            rdf = encodeEmbeddedDataframe(dfObj, rdf);\n        } else {\n            // format dates\n            if (RTypes.isDate(dfObj.type)) {\n                if (Lang.isArray(dfObj.value)) {\n                    dfObj.value = formatDates(dfObj.value, dfObj.type);\n                } else {\n                    dfObj.value = formatDate(dfObj.value, dfObj.type);\n                }\n            }\n\n            dfObj.type = RTypes.deployrToR(dfObj.type);\n            rdf.value.push(dfObj);\n        }\n\n    }\n    return rdf;\n};\n\nfunction encodeList(obj) {\n    var rlist = {\n            type: R.LIST,\n            value: [],\n            name: obj.name\n        },\n        dfValue = obj.value,\n        r;\n\n    for (var index = 0; index < dfValue.length; index++) {\n        var dfObj = dfValue[index];\n\n        switch (dfObj.type) {\n            case DeployR.RDATAFRAME:\n                r = encodeDataframe(dfObj);\n                break;\n\n            case DeployR.RLIST:\n                r = encodeList(dfObj);\n                break;\n\n            case DeployR.RNUMERIC_MATRIX:\n            case DeployR.RINTEGER_MATRIX:\n            case DeployR.RBOOLEAN_MATRIX:\n            case DeployR.RSTRING_MATRIX:\n                r = {\n                    name: dfObj.name,\n                    type: R.MATRIX,\n                    value: dfObj.value\n                };\n                break;\n\n            case DeployR.RDATE:\n            case DeployR.RPOSIX_DATE:\n                r = {\n                    name: dfObj.name,\n                    type: R.DATE,\n                    format: dfObj.format,\n                    value: formatDate(dfObj.value, dfObj.type)\n                };\n                break;\n\n            case DeployR.RFACTOR:\n            case DeployR.RORDERED:\n                r = {\n                    name: dfObj.name,\n                    type: R.FACTOR,\n                    ordered: dfObj.ordered,\n                    labels: dfObj.labels,\n                    levels: dfObj.levels,\n                    value: dfObj.value\n                };\n                break;\n\n            case DeployR.RSTRING:\n            case DeployR.RBOOLEAN:\n            case DeployR.RNUMERIC:\n            case DeployR.RINTEGER:\n                r = {\n                    name: dfObj.name,\n                    type: R.PRIMITIVE,\n                    value: dfObj.value\n                };\n                break;\n\n            case DeployR.RNUMERIC_VECTOR:\n            case DeployR.RINTEGER_VECTOR:\n            case DeployR.RBOOLEAN_VECTOR:\n            case DeployR.RSTRING_VECTOR:\n                r = {\n                    name: dfObj.name,\n                    type: R.VECTOR,\n                    value: dfObj.value\n                };\n                break;\n\n            case DeployR.RDATE_VECTOR:\n            case DeployR.RPOSIX_DATE_VECTOR:\n                r = {\n                    name: dfObj.name,\n                    type: R.VECTOR,                    \n                    value: formatDates(dfObj.value, dfObj.type),\n                    format: dfObj.format\n                };\n                break;\n\n            default:\n                throw new Error('No RDataType found for \"' + dfObj.type + '\"');\n                break;\n        }\n\n        rlist.value.push(r);\n    }\n    return rlist;\n};\n\nmodule.exports = {\n\n    /**\n     * Flattens a given <code>Revolution.RData</code> type into a JSON string\n     * representing the\n     * expected DeployR input format.\n     *\n     * @method parseInputs\n     * @public\n     * @param {Array} rdata An Array of RData Objects to be flattened.\n     * @return {String} The flattend RData JSON string representing the DeployR\n     *                  input format.\n     */\n    encode: function(rdata) {\n        var r = {};\n\n        for (var index = 0; index < rdata.length; index++) {\n            var obj = rdata[index];\n\n            switch (obj.type) { // -- DeployR Type -- //\n\n                case DeployR.RDATAFRAME:\n                    r[obj.name] = encodeDataframe(obj);\n                    break;\n\n                case DeployR.RLIST:\n                    r[obj.name] = encodeList(obj);\n                    break;\n\n                case DeployR.RNUMERIC_MATRIX:\n                case DeployR.RINTEGER_MATRIX:\n                case DeployR.RBOOLEAN_MATRIX:\n                case DeployR.RSTRING_MATRIX:\n                    r[obj.name] = {\n                        type: R.MATRIX,\n                        value: obj.value\n                    };\n                    break;\n\n                case DeployR.RDATE:\n                case DeployR.RPOSIX_DATE:\n                    r[obj.name] = {\n                        type: R.DATE,\n                        format: obj.format,                        \n                        value: formatDate(obj.value, obj.type)\n                    };\n                    break;\n\n                case DeployR.RFACTOR:\n                case DeployR.RORDERED:                \n                    r[obj.name] = {\n                        type: R.FACTOR,\n                        ordered: obj.ordered,\n                        labels: obj.labels,\n                        levels: obj.levels,\n                        value: obj.value\n                    };\n                    break;\n\n                case DeployR.RSTRING:\n                case DeployR.RBOOLEAN:\n                case DeployR.RNUMERIC:\n                case DeployR.RINTEGER:\n                    r[obj.name] = {\n                        type: R.PRIMITIVE,\n                        value: obj.value\n                    };\n                    break;\n\n                case DeployR.RNUMERIC_VECTOR:\n                case DeployR.RINTEGER_VECTOR:\n                case DeployR.RBOOLEAN_VECTOR:\n                case DeployR.RSTRING_VECTOR:\n                    r[obj.name] = {\n                        type: R.VECTOR,\n                        value: obj.value\n                    };\n                    break;\n\n                case DeployR.RDATE_VECTOR:\n                case DeployR.RPOSIX_DATE_VECTOR:\n                    r[obj.name] = {\n                        type: R.VECTOR,            \n                        value: formatDates(obj.value, obj.type),\n                        format: obj.format\n                    };\n                    break;\n\n                default:\n                    throw new Error('No RDataType found for \"' + obj.type + '\"');\n                    break;\n            }\n        }\n\n        return (JSON.stringify(r));\n    }\n};"," var optional = require('./optional'),\n     WS       = optional('ws'),\n     Queue    = require('./queue'),     \n     Emitter  = require('./emitter'),\n     Base     = require('./selfish').Base,\n     merge    = require('./utils').merge;\n\n/**\n * Initialize a new `EventStream` with the given set of `options`.\n *\n * @param {Object} options\n * @api private\n */\nvar EventStream = Base.extend(Emitter, {   \n\n  initialize: function initialize(host, options) {\n    Emitter.initialize.call(this, {});\n\n    this.host        = host;\n    this.options     = options || {};\n    this.options.log = this.options.log || this.LOG.error;\n    this.ws          = null;\n    this.q           = new Queue();\n    this.channel     = {};     \n  },  \n\n  LOG: { \n    info: 'info', \n    debug: 'debug', \n    error: 'error' \n  },\n  \n  open: function(options) {    \n    var self   = this,\n        uri    = (this.host || '') + '/deployr/r/event/stream?',\n        params = [];\n\n    options = options || {};\n    options.headers = options.headers || {};\n    options = this.options = merge(options, this.channel);    \n\n    this.cookies = !this.cookies ? options.headers.Cookie : this.cookies;\n\n    // -- append option parameters --\n    if (options.project) {\n      params.push('project=' + options.project);\n    } else {\n      if (options.job) {\n        params.push('job=' + options.job);\n      }\n    }\n\n    if (options.management) {\n      params.push('managementEventOnly=true');\n    } else {\n      if (options.httponly) {\n        params.push('httpEventOnly=true');\n      } else {\n        if (options.revoonly) {\n          params.push('revoEventOnly=true');\n        }\n      }\n    }\n\n    uri += params.join('&').substr(0);\n    uri = uri.replace(/^http/,'ws');\n\n    this.q.yield(true);\n    this.q.add(function() {\n\n      var headers = this.cookies ? { 'Cookie': this.cookies } : {};\n      this.emit('es:connecting', { uri: uri, headers: headers });\n\n      var ws = new WS(uri, 'http', { headers: headers });\n\n      ws.onopen = function (message) {\n        self.emit('es:open', message);\n      };\n\n      var _message = '';\n      ws.onmessage = function (message) {\n        try {          \n          if (message.data.split('!|!')[1]) {\n            _message = _message + message.data.split('!|!')[1];\n            message = JSON.parse(_message);\n            _message = '';\n            var type = message.deployr.response.event.type;\n            self.emit('es:' + type.replace('Event', ''), message);\n          }\n        } catch (e) {} \n      };\n\n      ws.onerror = function (err) { self.emit('es:error', err); };\n      ws.onclose = function (message) { self.emit('es:disconnect', message); };\n\n      this.ws = ws;\n    }, this);\n\n    if (options.force) { this.flush(); }\n\n    return this;    \n  },\n\n  close: function() {\n    if (this.ws) { this.ws.close(); }\n\n    return this;\n  },\n\n  error: function(fn) {\n    this.on('es:error', fn);\n\n    return this;\n  },  \n\n  all: function() {\n    this.channel = { revoonly: true };  // revoEventOnly=true\n\n    return this;\n  },\n\n  session: function() {\n    this.channel = { httponly: true }; //httpEventOnly=true\n\n    return this;\n  },\n\n  project: function(project) {\n    this.channel = { project: project }; // project=12345\n\n    return this;\n  },\n\n  job: function(job) {\n    this.channel = { job: job }; //job=12345\n\n    return this;\n  },\n\n  management: function() {\n    this.channel = { management: true }; //managementEventOnly=true\n\n    return this;\n  },\n\n  flush: function() {\n    this.q.yield(false);\n    this.q.flush();\n  },\n\n  share: function(cookies) {\n    this.cookies = cookies;\n  }\n\n});\n\nmodule.exports = EventStream;\n","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n *\n * This component is a DeployR port of yui-lang.js by Yahoo!\n *\n * Software License Agreement (BSD License)\n * Copyright (c) 2013, Yahoo! Inc. All rights reserved.\n *\n * Redistribution and use of this software in source and binary forms, with or \n * without modification, are permitted provided that the following conditions \n * are met:\n *\n * Redistributions of source code must retain the above copyright notice, this \n * list of conditions and the following disclaimer. Redistributions in binary \n * form must reproduce the above copyright notice, this list of conditions and \n * the following disclaimer in the documentation and/or other materials provided \n * with the distribution.\n *\n * Neither the name of Yahoo! Inc. nor the names of YUI's contributors may be \n * used to endorse or promote products derived from this software without \n * specific prior written permission of Yahoo! Inc.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" \n * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE \n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE \n * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE \n * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR \n * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF \n * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS \n * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN \n * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) \n * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE  \n * POS SIBILITY OF SUCH DAMAGE.\n */\n\n/**\n * Provides core language utilites and extensions used throughout DeployR.\n *\n * @class Lang\n * @static\n */\nvar L = {}, \n\tTOSTRING = Object.prototype.toString, \n\tTYPES = {\t\n\t\t'undefined' : 'undefined',\n\t\t'number' : 'number',\n\t\t'boolean' : 'boolean',\n\t\t'string' : 'string',\n\t\t'[object Function]' : 'function',\n\t\t'[object RegExp]' : 'regexp',\n\t\t'[object Array]' : 'array',\n\t\t'[object Date]' : 'date',\n\t\t'[object Error]' : 'error'\n\t}, unsafeNatives = false;\n\n/**\n * Determines whether or not the provided item is null.\n * @method isNull\n * @static\n * @param o The object to test.\n * @return {boolean} true if o is null.\n */\nL.isNull = function(o) {\n\treturn o === null;\n};\n\n/**\n * Determines whether or not the provided item is undefined.\n * @method isUndefined\n * @static\n * @param o The object to test.\n * @return {boolean} true if o is undefined.\n */\nL.isUndefined = function(o) {\n\treturn typeof o === 'undefined';\n};\n\n/**\n * Determines whether or not the provided item is of type object\n * or function. Note that arrays are also objects, so\n * <code>Y.Lang.isObject([]) === true</code>.\n * @method isObject\n * @static\n * @param o The object to test.\n * @param failfn {boolean} fail if the input is a function.\n * @return {boolean} true if o is an object.\n * @see isPlainObject\n */\nL.isObject = function(o, failfn) {\n\tvar t = typeof o;\n\treturn (o && (t === 'object' || (!failfn && (t === 'function' || L.isFunction(o))))) || false;\n};\n/**\n * Determines whether or not the provided item is an array.\n *\n * Returns `false` for array-like collections such as the function `arguments`\n * collection or `HTMLElement` collections.\n *\n * @method isArray\n * @param o The object to test.\n * @return {boolean} true if o is an array.\n * @static\n */\nL.isArray = (!unsafeNatives && Array.isArray) ||\nfunction(o) {\n\treturn L.type(o) === 'array';\n};\n\nL.isFunction = function isFunctionA(o) {\n\treturn (typeof(o) === \"function\");\n};\n\n/**\n * Determines whether or not the provided item is a boolean.\n * @method isBoolean\n * @static\n * @param o The object to test.\n * @return {boolean} true if o is a boolean.\n */\nL.isBoolean = function(o) {\n\treturn typeof o === 'boolean';\n};\n\n/**\n * Determines whether or not the supplied item is a date instance.\n * @method isDate\n * @static\n * @param o The object to test.\n * @return {boolean} true if o is a date.\n */\nL.isDate = function(o) {\n\treturn L.type(o) === 'date' && o.toString() !== 'Invalid Date' && !isNaN(o);\n};\n\n/**\n * Determines whether or not the provided item is a legal number.\n * @method isNumber\n * @static\n * @param o The object to test.\n * @return {boolean} true if o is a number.\n */\nL.isNumber = function(o) {\n\treturn typeof o === 'number' && isFinite(o);\n};\n\n/**\n * Determines whether or not the provided item is a string.\n * @method isString\n * @static\n * @param o The object to test.\n * @return {boolean} true if o is a string.\n */\nL.isString = function(o) {\n\treturn typeof o === 'string';\n};\n\n/**\n * Returns a string representing the type of the item passed in.\n *\n * @method type\n * @param o the item to test.\n * @return {string} the detected type.\n * @static\n */\nL.type = function(o) {\n\treturn TYPES[ typeof o] || TYPES[TOSTRING.call(o)] || ( o ? 'object' : 'null');\n};\n\nmodule.exports = L;","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n \nvar Logger = {},\n    loggerMap = {},\n    globalLogger;\n\n/**\n * Universal stdout|stderr printer\n */\nfunction log(messages, context) {\t\n\tif (!console) { return; }\n\n\tfunction sep(level) {\n\t\tvar sep = '=========================================================' +\n\t\t          '=========================================================\\n',\n\t\t    offset = 0;\n\n\t\tif (level === Logger.DEBUG || level === Logger.ERROR) offset = 8;\n\t\telse if (level === Logger.INFO || level === Logger.WARN) offset = 8;\n\t\telse offset = 7;\n\n\t\treturn { start: sep.substring(offset), end: sep };\n\t}\n\n\tvar hdlr,\n\t    args = Array.prototype.slice.call(messages, 0),\n\t    name = context.name,\n\t    error = context.level === Logger.ERROR,\n  \t    delim = sep(context.level);\n\n  \tif (context.level === Logger.WARN && console.warn) {\n  \t\thdlr = 'warn';\n  \t} else if (context.level === Logger.ERROR && console.error) {\n  \t\thdlr = 'error';\n  \t} else if (context.level === Logger.INFO && console.info) {\n  \t\thdlr = 'info';\n  \t} else {\n  \t\thdlr = 'log';\n  \t}\n\n  \t// -- custom format logging statement for deployr request/response/error --\n  \targs.unshift('[' + (error ? Logger.ERROR.name : name) + '] ' + delim.start);\n  \targs.push(delim.end);\n\n  \tconsole[hdlr](args[0], [args[1] + ' ---> ' + args[2]['call']]);\n\n    for (var i = 2; i < args.length; i++) { console.log(args[i]); }  \n}\n\n/**\n * Logging category by id.\n */\nfunction Category(id, level, fn) {\n\tthis.id = id;\n\tthis.context = level || Logger.DEBUG;\n}\n\nCategory.prototype = {\t\n\tlog: function(level, msgArgs) {\n\t\tif (level.value >= this.context.value) {\t\t\t\n\t\t\tlog(msgArgs, { \n\t\t\t\tlevel: level,\n\t\t\t\tname: this.context.name,\n\t\t\t\tvalue: this.context.value\n\t\t\t});\t\t\n\t\t}\n\t},\n\n\tdebug: function () {\t\t\n\t\tthis.log(Logger.DEBUG, arguments);\n\t},\n\n\terror: function () {\n\t\tthis.log(Logger.ERROR, arguments);\n\t},\n\n\tinfo: function () {\t\t\n\t\tthis.log(Logger.INFO, arguments);\n\t},\n\n\twarn: function () {\n\t\tthis.log(Logger.WARN, arguments);\n\t},\n\n\tsetLevel: function(level) {\n\t\tif (level && 'value' in level) {\n\t\t\tthis.context = level;\n\t\t}\n\t}\n};\n\nLogger.DEBUG = { value: 1, name: 'DEBUG' };\nLogger.INFO  = { value: 2, name: 'INFO' };\nLogger.WARN  = { value: 4, name: 'WARN' };\nLogger.ERROR = { value: 8, name: 'ERROR' };\nLogger.OFF   = { value: 99, name: 'OFF' };   \t\t\n\nLogger.setLevel = function(newLevel) {\n\tglobalLogger.setLevel(newLevel);\n};\n\nLogger.debug = function () {\n\tglobalLogger.debug.apply(globalLogger, arguments);\n};\n\nLogger.info = function () {\n\tglobalLogger.info.apply(globalLogger, arguments);\n};\n\nLogger.warn = function () {\n\tglobalLogger.warn.apply(globalLogger, arguments);\n};\n\nLogger.error = function () {\n\tglobalLogger.error.apply(globalLogger, arguments);\n};\n\nLogger.get = function (id, level, fn) {\t\n\treturn (loggerMap[id] || (function() {\n\t\tloggerMap[id] = new Category(id, level, fn);\n\t\treturn loggerMap[id];\n\t})());\n};\n\n// --- setup the global logger ---\nglobalLogger = Logger.get('global');\n\nmodule.exports \t= Logger;\n","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n \nmodule.exports = function(module) {\n  try {\n    return require(module);\n  } catch (e) {}\n};","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nfunction Queue() {\n  this.emptyCallback = null;\n  this.callbacks = [];\n  this.yielded = false;\n  this.response = null;\n  this.responseChain = [];  \n}\n\nQueue.prototype = {\n\n  add: function(fn, ctx, defer) {\n    // currently not waiting and there is no defer delay just make call\n    if (!this.yielded && !defer) {      \n      fn.apply(ctx || this, [this.response]);\n    } else { // add to queue\n      this.callbacks.push({ fn: fn, ctx: ctx });\n    }\n  },\n\n  size: function() {\n    return this.callbacks.length;\n  },\n\n  isEmpty: function() {\n    return this.callbacks.length === 0;\n  },\n\n  empty: function(fn, ctx) {\n    this.emptyCallback = { fn: fn, ctx: ctx };\n  },\n\n  yield: function(yield) {\n    this.yielded = yield;\n  },\n\n  take: function(response, error, args) { \n    var cb;\n\n    if (response) {\n      this.response = response;\n      this.responseChain.push(response);\n    }\n\n\n    if (!this.yielded && this.callbacks[0]) {\n      cb = this.callbacks.shift();\n      cb.fn.apply(cb.ctx || this, [this.responseChain, error, args]);\n\n      // notify that the queue is now empty   \n      if (this.callbacks[0] && this.emptyCallback) {\n        this.emptyCallback.fn.call(this.emptyCallback.ctx || this);         \n      }\n    }\n  },\n  \n  flush: function(response, error, args) {        \n    if (response) {\n      this.response = response;\n      this.responseChain.push(response);\n    }\n\n    // pop and call next inline\n    while (this.callbacks[0]) {\n      if (this.yielded) { break; }\n      var cb = this.callbacks.shift();\n      cb.fn.apply(cb.ctx || this, [this.responseChain, error, args]);\n\n      // notify that the queue is now empty\n      if (this.callbacks[0] && this.emptyCallback) {\n        this.emptyCallback.fn.call(this.emptyCallback.ctx || this);         \n      }\n    }\n  }\n};\n\nmodule.exports = Queue;","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nvar Base   = require('./selfish').Base,\n    RTypes = require('./rtypes');\n\nmodule.exports = Base.extend(RTypes, {\n\tinitialize: function initialize(name, value, options) {  \t\n\t\tthis.name  = name;\n\t\tthis.value = value;\n\t\tthis.options = options || {};\n\t},\n\n\tnumeric: function () {\n\t\treturn this.assert({\n\t\t\ttype: this.deployr.RNUMERIC,\n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t});\n\t},\t\n\n\tinteger: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RINTEGER,\n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tlogical: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RBOOLEAN, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tcharacter: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RSTRING, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tdate: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RDATE,\n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\tformat: 'yyyy-MM-dd',\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\tposixct: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RPOSIX_DATE, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\tformat: 'yyyy-MM-dd HH:mm:ss Z',\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\t\n\t\n\tnumericVector: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RNUMERIC_VECTOR,\n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tintegerVector: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RINTEGER_VECTOR, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tlogicalVector: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RBOOLEAN_VECTOR, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tcharacterVector: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RSTRING_VECTOR, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},  \n\t\n\tdateVector: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RDATE_VECTOR, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\tformat: 'yyyy-MM-dd',\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\t\n\t\n\tposixctVector: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RPOSIX_DATE_VECTOR, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\tformat: 'yyyy-MM-dd HH:mm:ss Z',\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tlist: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RLIST, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tdataframe: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RDATAFRAME, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\tfactor: function () {\n\t\tvar opts = this.options;\n\n\t\treturn this.assert( { \n\t\t\ttype: this.deployr.RFACTOR, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\tordered: false,\n\t\t\tlevels: opts.levels,\n\t\t\tlabels: opts.labels,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\tordered: function () {\n\t\tvar opts = this.options;\n\n\t\treturn this.assert( { \n\t\t\ttype: this.deployr.RORDERED, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\tordered: true,\n\t\t\tlevels: opts.levels,\n\t\t\tlabels: opts.labels,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\t\t\n\n\tnumericMatrix: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RNUMERIC_MATRIX, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\tintegerMatrix: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RINTEGER_MATRIX, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\tlogicalMatrix: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RBOOLEAN_MATRIX, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\tcharacterMatrix: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RSTRING_MATRIX, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\ttoString: function() {\n\t\tvar opts   = this.options || {},\n\t\t    levels = opts.levels ? '[ levels = ' + opts.levels + ']' : '',\n\t\t    labels = opts.labels ? '[ labels = ' + opts.labels + ']' : '';\n\n\t\treturn '[ name = '  + this.name + ' ] ' +\n\t\t       '[ value = ' + this.value + ' ] ' +\n\t\t       '[ type = '  + this.type + ' ] ' +\n\t\t       levels + labels;\t\t       \n\t}\n});","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nvar Base   = require('./selfish').Base,\n    RTypes = require('./rtypes'),\n    Lang   = require('./lang'),\n    RInput = require('./rinput'); \n\nfunction create(type, name, value, options) {\n\tvar rinput;\n\n\tif (Lang.isObject(name)) {\n\t\trinput = name;\n\t\tif (!rinput.type !== type) {\n\t\t\tthrow new Error('IllegalArgumentError:' + \n\t\t\t\t'Expecting \"' + type + '\" but found \"' + rinput.type + '\"');\n\t\t}\n\t} else {\n\t    rinput = RInput.new(name, value, options)[type]();\n\t} \n\n\treturn rinput;\n}\n\nmodule.exports = Base.extend(RTypes, {\t\n\tnumeric: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RNUMERIC, name, value));\n\t\treturn this;\n\t},\n\t\n\tinteger: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RINTEGER, name, value));\n\t\treturn this; \n\t},\n\t\n\tlogical: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RBOOLEAN, name, value));\n\t\treturn this; \n\t},\n\t\n\tcharacter: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RSTRING, name, value));\n\t\treturn this; \n\t},\n\t\n\tdate: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RDATE, name, value));\n\t\treturn this; \n\t},\n\n\tposixct: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RPOSIX_DATE, name, value));\n\t\treturn this; \n\t},\t\n\t\n\tnumericVector: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RNUMERIC_VECTOR, name, value));\n\t\treturn this; \n\t},\n\t\n\tintegerVector: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RINTEGER_VECTOR, name, value));\n\t\treturn this; \n\t},\n\t\n\tlogicalVector: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RBOOLEAN_VECTOR, name, value));\n\t\treturn this; \n\t},\n\t\n\tcharacterVector: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RSTRING_VECTOR, name, value));\n\t\treturn this; \n\t},  \n\t\n\tdateVector: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RDATE_VECTOR, name, value));\n\t\treturn this; \n\t},\t\n\t\n\tposixctVector: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RPOSIX_DATE_VECTOR, name, value));\n\t\treturn this; \n\t},\n\t\n\tlist: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RLIST, name, value));\n\t\treturn this; \n\t},\n\t\n\tdataframe: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RDATAFRAME, name, value));\n\t\treturn this; \n\t},\t\n\n\tfactor: function (name, value, levels, labels) {\n\t\tvar opts = { levels: levels, labels: labels };\n\t\tthis.inputs.push(create(this.deployr.RFACTOR, name, value, opts));\n\t\treturn this;\n\t},\n\n\tordered: function (name, value, levels, labels) {\n\t\tvar opts = { levels: levels, labels: labels };\n\t\tthis.inputs.push(create(this.deployr.RORDERED, name, value, opts));\n\t\treturn this;\n\t},\t\t\n\n\tnumericMatrix: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RNUMERIC_MATRIX, name, value));\n\t\treturn this; \n\t},\n\n\tintegerMatrix: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RINTEGER_MATRIX, name, value));\n\t\treturn this; \n\t},\n\n\tlogicalMatrix: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RBOOLEAN_MATRIX, name, value));\n\t\treturn this; \n\t},\n\n\tcharacterMatrix: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RSTRING_MATRIX, name, value));\n\t\treturn this;\n\t}\n});","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nvar Base = require('./selfish').Base,\n    Lang = require('./lang'),\n    map  = {}; // deployr->To->R catalog\n\nmodule.exports = Base.extend({\n\tr: {\n\t\tPRIMITIVE: 'primitive',\n\t\tDATAFRAME: 'dataframe',\n\t\tLIST: 'list',\n\t\tMATRIX: 'matrix',\n\t\tDATE: 'date',\n\t\tFACTOR: 'factor',\n\t\tVECTOR: 'vector'\n\t},\n\n\tdeployr: {\n\t\tRBOOLEAN: 'logical',\n\t\tRNUMERIC: 'numeric',\n\t\tRINTEGER: 'integer',\n\t\tRSTRING: 'character',\n\t\tRDATE: 'date',\n\t\tRPOSIX_DATE: 'posixct',\n\t\tRBOOLEAN_VECTOR: 'logicalVector',\n\t\tRNUMERIC_VECTOR:'numericVector',\n\t\tRINTEGER_VECTOR: 'integerVector',\t\n\t\tRSTRING_VECTOR: 'characterVector',\n\t\tRDATE_VECTOR: 'dateVector',\n\t\tRPOSIX_DATE_VECTOR: 'posixctVector',\n\t\tRLIST: 'list',\n\t\tRDATAFRAME: 'dataframe',\n\t\tRFACTOR: 'factor',\n\t\tRORDERED: 'ordered',\t\t\n\t\tRBOOLEAN_MATRIX: 'logicalMatrix',\n\t\tRNUMERIC_MATRIX: 'numericMatrix',\n\t\tRINTEGER_MATRIX: 'integerMatrix',\t\t\n\t\tRSTRING_MATRIX: 'characterMatrix'\n\t},\n\n\tisDate: function(type) {\n\t\treturn (type === this.deployr.RDATE || \n\t\t        type === this.deployr.RPOSIX_DATE || \n\t\t        type === this.deployr.RDATE_VECTOR ||\n\t\t        type === this.deployr.RPOSIX_DATE_VECTOR ||\n\t\t        type === this.r.DATE);\n\t},\n\n\tdeployrToR: function(type) {\t\n\t\tvar deployr = this.deployr,\n\t\t    r       = this.r;\n\n\t\tif (!map[type]) { // build catalog only once\t\n\t\t\tmap[deployr.RBOOLEAN]           = r.PRIMITIVE;\n\t\t\tmap[deployr.RNUMERIC]           = r.PRIMITIVE;\n\t\t\tmap[deployr.RINTEGER]           = r.PRIMITIVE;\n\t\t\tmap[deployr.RSTRING]            = r.PRIMITIVE;\n\t\t\tmap[deployr.RDATE]              = r.DATE;\n\t\t\tmap[deployr.RPOSIX_DATE]        = r.DATE;\n\t\t\tmap[deployr.RBOOLEAN_VECTOR]    = r.VECTOR;\n\t\t\tmap[deployr.RNUMERIC_VECTOR]    = r.VECTOR;\n\t\t\tmap[deployr.RINTEGER_VECTOR]    = r.VECTOR;\n\t\t\tmap[deployr.RSTRING_VECTOR]     = r.VECTOR;\n\t\t\tmap[deployr.RDATE_VECTOR]       = r.VECTOR;\n\t\t\tmap[deployr.RPOSIX_DATE_VECTOR] = r.VECTOR;\n\t\t\tmap[deployr.RLIST]              = r.LIST;\n\t\t\tmap[deployr.RDATAFRAME]         = r.DATAFRAME;\n\t\t\tmap[deployr.RFACTOR]            = r.FACTOR;\n\t\t\tmap[deployr.RORDERED]           = r.FACTOR;\n\t\t\tmap[deployr.RBOOLEAN_MATRIX]    = r.MATRIX;\n\t\t\tmap[deployr.RNUMERIC_MATRIX]    = r.MATRIX;\n\t\t\tmap[deployr.RINTEGER_MATRIX]    = r.MATRIX;\n\t\t\tmap[deployr.RSTRING_MATRIX]     = r.MATRIX;\n\t\t}\n\n\t\treturn map[type];\t\t\n\t},\n\n\t/**\n\t * Assert that the `rinput` value is the correct JavaScript Data Type.\n\t */\n\tassert: function (rinput) {\n\t\tvar deployr = this.deployr,\n    \t\tNOOP    = null,\n\t\t    values  = rinput.value,\n\t\t    fn;\n\n\t\tvalues = !Lang.isArray(values) ? [values] : values;\n\n\t\tfor (var i = 0; i < values.length; i++) {\n\t\t\tvar value = values[i];\n\n\t\t\tswitch (rinput.type) {\n\t\t\t\tcase deployr.RNUMERIC :\n\t\t\t\tcase deployr.RNUMERIC_VECTOR :\n\t\t\t\tcase deployr.RNUMERIC_VECTOR :\n\t\t\t\tfn = Lang.isNumber;\n\t\t\t\t// support string numbers\n\t\t\t\tvar val = parseFloat(value);\n\t\t\t    value = isNaN(val) ? value : val; \n\t\t\t    break;\n\n\t\t\t    case deployr.RINTEGER :\n\t\t\t    case deployr.RINTEGER_VECTOR :\n\t\t\t    fn = Lang.isNumber;\n\t\t\t    // support string numbers\n\t\t\t    var val = parseFloat(value);\n\t\t\t    value = isNaN(val) ? value : val; \n\t\t\t    break;\n\n\t\t\t    case deployr.RBOOLEAN :\n\t\t\t    case deployr.RBOOLEAN_VECTOR :\n\t\t\t    fn = Lang.isBoolean;\n\t\t\t    break;\n\t\t\t    \n\t\t\t    case deployr.RSTRING :\n\t\t\t    case deployr.RSTRING_VECTOR :\t\n\t\t\t    fn = Lang.isString;\n\t\t\t    break;\n\n\t\t\t    case deployr.RDATE :\n\t\t\t    case deployr.RPOSIX_DATE :\n\t\t\t    case deployr.RDATE_VECTOR :\n\t\t\t    case deployr.RPOSIX_DATE_VECTOR :\n\t\t\t    fn = Lang.isDate;\n\t\t\t    break;\n\n\t\t\t    case deployr.RFACTOR :\n\t\t\t    case deployr.RORDERED :\t\t\t    \n\t\t\t    case deployr.RDATAFRAME :\n\t\t\t    case deployr.RINTEGER_MATRIX :\n\t\t\t    case deployr.RBOOLEAN_MATRIX :\n\t\t\t    case deployr.RSTRING_MATRIX :\t    \n\t\t\t    fn = NOOP;\n\t\t\t    break\n\t\t\t}\n\n\t\t\tif (fn && !fn(value)) {\n\t\t\t\tthrow new Error('RInputFormatError: ' + '\"' + value + \n\t\t\t\t\t'\" is not a valid \"' + rinput.type + '\" type.');\n\t\t\t}\n\t\t}\n\n\t\treturn rinput;\n\t}\n});","/*!\n * https://github.com/Gozala/selfish\n */\n\n/* vim:set ts=2 sw=2 sts=2 expandtab */\n/*jshint undef: true es5: true node: true devel: true evil: true\n         forin: true latedef: false supernew: true */\n/*global define: true */\n\n!(typeof define !== \"function\" ? function($){ $(null, typeof exports !== 'undefined' ? exports : window); } : define)(function(require, exports) {\n\n\"use strict\";\n\nexports.Base = Object.freeze(Object.create(Object.prototype, {\n  /**\n   * Creates an object that inherits from `this` object (Analog of\n   * `new Object()`).\n   * @examples\n   *\n   *    var Dog = Base.extend({\n   *      bark: function bark() {\n   *        return 'Ruff! Ruff!'\n   *      }\n   *    });\n   *    var dog = Dog.new();\n   */\n  'new': { value: function create() {\n    var object = Object.create(this);\n    object.initialize.apply(object, arguments);\n    return object;\n  }},\n  /**\n   * When new instance of the this prototype is created it's `initialize`\n   * method is called with all the arguments passed to the `new`. You can\n   * override `initialize` to set up an instance.\n   */\n  initialize: { value: function initialize() {\n  }},\n  /**\n   * Merges all the properties of the passed objects into `this` instance (This\n   * method can be used on instances only as prototype objects are frozen).\n   *\n   * If two or more argument objects have own properties with the same name,\n   * the property is overridden, with precedence from right to left, implying,\n   * that properties of the object on the left are overridden by a same named\n   * property of the object on the right.\n   *\n   * @examples\n   *\n   *    var Pet = Dog.extend({\n   *      initialize: function initialize(options) {\n   *        // this.name = options.name -> would have thrown (frozen prototype)\n   *        this.merge(options) // will override all properties.\n   *      },\n   *      call: function(name) {\n   *        return this.name === name ? this.bark() : ''\n   *      },\n   *      name: null\n   *    })\n   *    var pet = Pet.new({ name: 'Benzy', breed: 'Labrador' })\n   *    pet.call('Benzy')   // 'Ruff! Ruff!'\n   */\n  merge: { value: function merge() {\n    var descriptor = {};\n    Array.prototype.forEach.call(arguments, function (properties) {\n      Object.getOwnPropertyNames(properties).forEach(function(name) {\n        descriptor[name] = Object.getOwnPropertyDescriptor(properties, name);\n      });\n    });\n    Object.defineProperties(this, descriptor);\n    return this;\n  }},\n  /**\n   * Takes any number of argument objects and returns frozen, composite object\n   * that inherits from `this` object and combines all of the own properties of\n   * the argument objects. (Objects returned by this function are frozen as\n   * they are intended to be used as types).\n   *\n   * If two or more argument objects have own properties with the same name,\n   * the property is overridden, with precedence from right to left, implying,\n   * that properties of the object on the left are overridden by a same named\n   * property of the object on the right.\n   * @examples\n   *\n   *    // ## Object composition ##\n   *\n   *    var HEX = Base.extend({\n   *      hex: function hex() {\n   *        return '#' + this.color;\n   *      }\n   *    })\n   *\n   *    var RGB = Base.extend({\n   *      red: function red() {\n   *        return parseInt(this.color.substr(0, 2), 16);\n   *      },\n   *      green: function green() {\n   *        return parseInt(this.color.substr(2, 2), 16);\n   *      },\n   *      blue: function blue() {\n   *        return parseInt(this.color.substr(4, 2), 16);\n   *      }\n   *    })\n   *\n   *    var CMYK = Base.extend(RGB, {\n   *      black: function black() {\n   *        var color = Math.max(Math.max(this.red(), this.green()), this.blue());\n   *        return (1 - color / 255).toFixed(4);\n   *      },\n   *      cyan: function cyan() {\n   *        var K = this.black();\n   *        return (((1 - this.red() / 255).toFixed(4) - K) / (1 - K)).toFixed(4);\n   *      },\n   *      magenta: function magenta() {\n   *        var K = this.black();\n   *        return (((1 - this.green() / 255).toFixed(4) - K) / (1 - K)).toFixed(4);\n   *      },\n   *      yellow: function yellow() {\n   *        var K = this.black();\n   *        return (((1 - this.blue() / 255).toFixed(4) - K) / (1 - K)).toFixed(4);\n   *      }\n   *    })\n   *\n   *    var Color = Base.extend(HEX, RGB, CMYK, {\n   *      initialize: function Color(color) {\n   *        this.color = color;\n   *      }\n   *    });\n   *\n   *    // ## Prototypal inheritance ##\n   *\n   *    var Pixel = Color.extend({\n   *      initialize: function Pixel(x, y, hex) {\n   *        Color.initialize.call(this, hex);\n   *        this.x = x;\n   *        this.y = y;\n   *      },\n   *      toString: function toString() {\n   *        return this.x + ':' + this.y + '@' + this.hex();\n   *      }\n   *    });\n   *\n   *    var pixel = Pixel.new(11, 23, 'CC3399')\n   *    pixel.toString(); // 11:23@#CC3399\n   *\n   *    pixel.red();      // 204\n   *    pixel.green();    // 51\n   *    pixel.blue();     // 153\n   *\n   *    pixel.cyan();     // 0.0000\n   *    pixel.magenta();  // 0.7500\n   *    pixel.yellow();   // 0.2500\n   *\n   */\n   extend: { value: function extend() {\n    return Object.freeze(this.merge.apply(Object.create(this), arguments));\n  }}\n}));\n\n});","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more\n * details.\n */\n\nvar Lang = require('./lang');\n\nvar get = exports.get = function(s, key) {\n    function traverse(obj, fn, parent) {\n        for (var i in obj) {\n            var result = fn.apply(this, [i, obj[i], parent]);\n            if (result) {\n                return result;\n            } else {\n                if (obj[i] instanceof Object && !(obj[i] instanceof Array)) {                \n                   traverse(obj[i], fn, i);\n               }\n            }\n        }\n    }\n\n    function getProperty(obj, property) {\n        var acc = {};\n        traverse(obj, function(key, value, parent) {\n            if (key === property) {  \n                acc = value;\n                return acc;\n            } else {\n                return null;\n            }\n        });\n        return acc;\n    }\n\n    function empty(obj) {\n        for (var prop in obj) { if (obj.hasOwnProperty(prop)) return obj; }\n        return !Lang.isObject(obj) ? obj : null;\n    }\n\n    return empty(getProperty(s, key));\n};\n\nvar inArray = exports.inArray = function(haystack, needle, key) {\n    var i, max = haystack.length;\n\n    for (i = 0; i < max; i++) {\n        if (key) {\n            if (haystack[i][key] === needle) { return haystack[i]; }\n        } else {\n            if (haystack[i] === needle) { return haystack[i]; }\n        }   \n    }\n    return null;\n};\n\nexports.merge = function(to, from) {        \n    if (!to || typeof(to) !== 'object') { to = {}; }\n    if (!from || typeof(from) !== 'object') { from = {}; }\n\n    for (var k in from) { to[k] = from[k]; }\n\n    return to;\n};\n\nexports.workspace = function(obj, name) {\n    var ws = get(obj, 'workspace');\n    return (ws ? name ? inArray(ws.objects, name, 'name') : ws.objects || ws.object: null);\n};\n\nexports.signature = function() {\n    var args   = Array.prototype.slice.call(arguments['0'], 0),\n        len    = args.length,\n        create = false,\n        opts   = {},\n        api;\n\n    if (len === 1 && Lang.isObject(args[0])) {\n        opts = args[0];\n        api  = opts.project ? '/r/project/execute/script' :\n            '/r/repository/script/execute';\n    } else if (len === 1 && Lang.isString(args[0])) {\n        args = args[0].split('\\/');\n        api  = '/r/repository/script/execute'\n        opts = {\n            author: args[1],\n            directory: args[2],\n            filename: args[3]\n        };\n    } else if (len === 2) {\n        // ex: .script('/testuser/root/DeployR - Hello World.R', project)\n        var project = args[1];\n        api = project ? '/r/project/execute/script' : '/r/repository/script/execute';\n\n        args = args[0].split('\\/');\n        opts = {\n            project: project,\n            author: args[1],\n            directory: args[2],\n            filename: args[3]\n        };\n    } else if (len > 2) {\n        // ex: .script('DeployR - Hello World.R', 'testuser', 'root')\n        opts = {\n            author: args[2],\n            directory: args[1],\n            filename: args[0]\n        };\n    }\n\n    // indicate a new project should be created\n    if (opts.project && Lang.isBoolean(opts.project)) {\n      delete opts['project'];\n      create = true;\n    }\n\n    return {\n        api: api,\n        opts: opts,\n        create: create\n    };\n};",null,"// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    draining = true;\n    var currentQueue;\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        var i = -1;\n        while (++i < len) {\n            currentQueue[i]();\n        }\n        len = queue.length;\n    }\n    draining = false;\n}\nprocess.nextTick = function (fun) {\n    queue.push(fun);\n    if (!draining) {\n        setTimeout(drainQueue, 0);\n    }\n};\n\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\n// TODO(shtylman)\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","(function (process){\n/**\n* attempt of a simple defer/promise library for mobile development\n* @author Jonathan Gotti < jgotti at jgotti dot net>\n* @since 2012-10\n* @version 0.6.0\n* @changelog\n*           - 2013-12-07 - last promise 1.1 specs test passings (thx to wizardwerdna)\n *                       - reduce promises footprint by unscoping methods that could be\n*           - 2013-10-23 - make it workig across node-webkit contexts\n*           - 2013-07-03 - bug correction in promixify method (thx to adrien gibrat )\n*           - 2013-06-22 - bug correction in nodeCapsule method\n*           - 2013-06-17 - remove unnecessary Array.indexOf method dependency\n*           - 2013-04-18 - add try/catch block around nodeCapsuled methods\n*           - 2013-04-13 - check promises/A+ conformity\n*                        - make some minication optimisations\n*           - 2013-03-26 - add resolved, fulfilled and rejected methods\n*           - 2013-03-21 - browser/node compatible\n*                        - new method nodeCapsule\n*                        - simpler promixify with full api support\n*           - 2013-01-25 - add rethrow method\n*                        - nextTick optimisation -> add support for process.nextTick + MessageChannel where available\n*           - 2012-12-28 - add apply method to promise\n*           - 2012-12-20 - add alwaysAsync parameters and property for default setting\n*/\n(function(undef){\n\t\"use strict\";\n\n\tvar nextTick\n\t\t, isFunc = function(f){ return ( typeof f === 'function' ); }\n\t\t, isArray = function(a){ return Array.isArray ? Array.isArray(a) : (a instanceof Array); }\n\t\t, isObjOrFunc = function(o){ return !!(o && (typeof o).match(/function|object/)); }\n\t\t, isNotVal = function(v){ return (v === false || v === undef || v === null); }\n\t\t, slice = function(a, offset){ return [].slice.call(a, offset); }\n\t\t, undefStr = 'undefined'\n\t\t, tErr = typeof TypeError === undefStr ? Error : TypeError\n\t;\n\tif ( (typeof process !== undefStr) && process.nextTick ) {\n\t\tnextTick = process.nextTick;\n\t} else if ( typeof MessageChannel !== undefStr ) {\n\t\tvar ntickChannel = new MessageChannel(), queue = [];\n\t\tntickChannel.port1.onmessage = function(){ queue.length && (queue.shift())(); };\n\t\tnextTick = function(cb){\n\t\t\tqueue.push(cb);\n\t\t\tntickChannel.port2.postMessage(0);\n\t\t};\n\t} else {\n\t\tnextTick = function(cb){ setTimeout(cb, 0); };\n\t}\n\tfunction rethrow(e){ nextTick(function(){ throw e;}); }\n\n\t/**\n\t * @typedef deferred\n\t * @property {promise} promise\n\t * @method resolve\n\t * @method fulfill\n\t * @method reject\n\t */\n\n\t/**\n\t * @typedef {function} fulfilled\n\t * @param {*} value promise resolved value\n\t * @returns {*} next promise resolution value\n\t */\n\n\t/**\n\t * @typedef {function} failed\n\t * @param {*} reason promise rejection reason\n\t * @returns {*} next promise resolution value or rethrow the reason\n\t */\n\n\t//-- defining unenclosed promise methods --//\n\t/**\n\t * same as then without failed callback\n\t * @param {fulfilled} fulfilled callback\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_success(fulfilled){ return this.then(fulfilled, undef); }\n\n\t/**\n\t * same as then with only a failed callback\n\t * @param {failed} failed callback\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_error(failed){ return this.then(undef, failed); }\n\n\n\t/**\n\t * same as then but fulfilled callback will receive multiple parameters when promise is fulfilled with an Array\n\t * @param {fulfilled} fulfilled callback\n\t * @param {failed} failed callback\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_apply(fulfilled, failed){\n\t\treturn this.then(\n\t\t\tfunction(a){\n\t\t\t\treturn isFunc(fulfilled) ? fulfilled.apply(null, isArray(a) ? a : [a]) : (defer.onlyFuncs ? a : fulfilled);\n\t\t\t}\n\t\t\t, failed || undef\n\t\t);\n\t}\n\n\t/**\n\t * cleanup method which will be always executed regardless fulfillment or rejection\n\t * @param {function} cb a callback called regardless of the fulfillment or rejection of the promise which will be called\n\t *                      when the promise is not pending anymore\n\t * @returns {promise} the same promise untouched\n\t */\n\tfunction promise_ensure(cb){\n\t\tfunction _cb(){ cb(); }\n\t\tthis.then(_cb, _cb);\n\t\treturn this;\n\t}\n\n\t/**\n\t * take a single callback which wait for an error as first parameter. other resolution values are passed as with the apply/spread method\n\t * @param {function} cb a callback called regardless of the fulfillment or rejection of the promise which will be called\n\t *                      when the promise is not pending anymore with error as first parameter if any as in node style\n\t *                      callback. Rest of parameters will be applied as with the apply method.\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_nodify(cb){\n\t\treturn this.then(\n\t\t\tfunction(a){\n\t\t\t\treturn isFunc(cb) ? cb.apply(null, isArray(a) ? a.splice(0,0,undefined) && a : [undefined,a]) : (defer.onlyFuncs ? a : cb);\n\t\t\t}\n\t\t\t, function(e){\n\t\t\t\treturn cb(e);\n\t\t\t}\n\t\t);\n\t}\n\n\t/**\n\t *\n\t * @param {function} [failed] without parameter will only rethrow promise rejection reason outside of the promise library on next tick\n\t *                            if passed a failed method then will call failed on rejection and throw the error again if failed didn't\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_rethrow(failed){\n\t\treturn this.then(\n\t\t\tundef\n\t\t\t, failed ? function(e){ failed(e); throw e; } : rethrow\n\t\t);\n\t}\n\n\t/**\n\t* @param {boolean} [alwaysAsync] if set force the async resolution for this promise independantly of the D.alwaysAsync option\n\t* @returns {deferred} defered object with property 'promise' and methods reject,fulfill,resolve (fulfill being an alias for resolve)\n\t*/\n\tvar defer = function (alwaysAsync){\n\t\tvar alwaysAsyncFn = (undef !== alwaysAsync ? alwaysAsync : defer.alwaysAsync) ? nextTick : function(fn){fn();}\n\t\t\t, status = 0 // -1 failed | 1 fulfilled\n\t\t\t, pendings = []\n\t\t\t, value\n\t\t\t/**\n\t\t\t * @typedef promise\n\t\t\t */\n\t\t\t, _promise  = {\n\t\t\t\t/**\n\t\t\t\t * @param {fulfilled|function} fulfilled callback\n\t\t\t\t * @param {failed|function} failed callback\n\t\t\t\t * @returns {promise} a new promise\n\t\t\t\t */\n\t\t\t\tthen: function(fulfilled, failed){\n\t\t\t\t\tvar d = defer();\n\t\t\t\t\tpendings.push([\n\t\t\t\t\t\tfunction(value){\n\t\t\t\t\t\t\ttry{\n\t\t\t\t\t\t\t\tif( isNotVal(fulfilled)){\n\t\t\t\t\t\t\t\t\td.resolve(value);\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\td.resolve(isFunc(fulfilled) ? fulfilled(value) : (defer.onlyFuncs ? value : fulfilled));\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}catch(e){\n\t\t\t\t\t\t\t\td.reject(e);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\t, function(err){\n\t\t\t\t\t\t\tif ( isNotVal(failed) || ((!isFunc(failed)) && defer.onlyFuncs) ) {\n\t\t\t\t\t\t\t\td.reject(err);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tif ( failed ) {\n\t\t\t\t\t\t\t\ttry{ d.resolve(isFunc(failed) ? failed(err) : failed); }catch(e){ d.reject(e);}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t]);\n\t\t\t\t\tstatus !== 0 && alwaysAsyncFn(execCallbacks);\n\t\t\t\t\treturn d.promise;\n\t\t\t\t}\n\n\t\t\t\t, success: promise_success\n\n\t\t\t\t, error: promise_error\n\t\t\t\t, otherwise: promise_error\n\n\t\t\t\t, apply: promise_apply\n\t\t\t\t, spread: promise_apply\n\n\t\t\t\t, ensure: promise_ensure\n\n\t\t\t\t, nodify: promise_nodify\n\n\t\t\t\t, rethrow: promise_rethrow\n\n\t\t\t\t, isPending: function(){ return !!(status === 0); }\n\n\t\t\t\t, getStatus: function(){ return status; }\n\t\t\t}\n\t\t;\n\t\t_promise.toSource = _promise.toString = _promise.valueOf = function(){return value === undef ? this : value; };\n\n\n\t\tfunction execCallbacks(){\n\t\t\tif ( status === 0 ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tvar cbs = pendings, i = 0, l = cbs.length, cbIndex = ~status ? 0 : 1, cb;\n\t\t\tpendings = [];\n\t\t\tfor( ; i < l; i++ ){\n\t\t\t\t(cb = cbs[i][cbIndex]) && cb(value);\n\t\t\t}\n\t\t}\n\n\t\t/**\n\t\t * fulfill deferred with given value\n\t\t * @param {*} val\n\t\t * @returns {deferred} this for method chaining\n\t\t */\n\t\tfunction _resolve(val){\n\t\t\tvar done = false;\n\t\t\tfunction once(f){\n\t\t\t\treturn function(x){\n\t\t\t\t\tif (done) {\n\t\t\t\t\t\treturn undefined;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdone = true;\n\t\t\t\t\t\treturn f(x);\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t}\n\t\t\tif ( status ) {\n\t\t\t\treturn this;\n\t\t\t}\n\t\t\ttry {\n\t\t\t\tvar then = isObjOrFunc(val) && val.then;\n\t\t\t\tif ( isFunc(then) ) { // managing a promise\n\t\t\t\t\tif( val === _promise ){\n\t\t\t\t\t\tthrow new tErr(\"Promise can't resolve itself\");\n\t\t\t\t\t}\n\t\t\t\t\tthen.call(val, once(_resolve), once(_reject));\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tonce(_reject)(e);\n\t\t\t\treturn this;\n\t\t\t}\n\t\t\talwaysAsyncFn(function(){\n\t\t\t\tvalue = val;\n\t\t\t\tstatus = 1;\n\t\t\t\texecCallbacks();\n\t\t\t});\n\t\t\treturn this;\n\t\t}\n\n\t\t/**\n\t\t * reject deferred with given reason\n\t\t * @param {*} Err\n\t\t * @returns {deferred} this for method chaining\n\t\t */\n\t\tfunction _reject(Err){\n\t\t\tstatus || alwaysAsyncFn(function(){\n\t\t\t\ttry{ throw(Err); }catch(e){ value = e; }\n\t\t\t\tstatus = -1;\n\t\t\t\texecCallbacks();\n\t\t\t});\n\t\t\treturn this;\n\t\t}\n\t\treturn /**@type deferred */ {\n\t\t\tpromise:_promise\n\t\t\t,resolve:_resolve\n\t\t\t,fulfill:_resolve // alias\n\t\t\t,reject:_reject\n\t\t};\n\t};\n\n\tdefer.deferred = defer.defer = defer;\n\tdefer.nextTick = nextTick;\n\tdefer.alwaysAsync = true; // setting this will change default behaviour. use it only if necessary as asynchronicity will force some delay between your promise resolutions and is not always what you want.\n\t/**\n\t* setting onlyFuncs to false will break promises/A+ conformity by allowing you to pass non undefined/null values instead of callbacks\n\t* instead of just ignoring any non function parameters to then,success,error... it will accept non null|undefined values.\n\t* this will allow you shortcuts like promise.then('val','handled error'')\n\t* to be equivalent of promise.then(function(){ return 'val';},function(){ return 'handled error'})\n\t*/\n\tdefer.onlyFuncs = true;\n\n\t/**\n\t * return a fulfilled promise of given value (always async resolution)\n\t * @param {*} value\n\t * @returns {promise}\n\t */\n\tdefer.resolved = defer.fulfilled = function(value){ return defer(true).resolve(value).promise; };\n\n\t/**\n\t * return a rejected promise with given reason of rejection (always async rejection)\n\t * @param {*} reason\n\t * @returns {promise}\n\t */\n\tdefer.rejected = function(reason){ return defer(true).reject(reason).promise; };\n\n\t/**\n\t * return a promise with no resolution value which will be resolved in time ms (using setTimeout)\n\t * @param {int} [time] in ms default to 0\n\t * @returns {promise}\n\t */\n\tdefer.wait = function(time){\n\t\tvar d = defer();\n\t\tsetTimeout(d.resolve, time || 0);\n\t\treturn d.promise;\n\t};\n\n\t/**\n\t * return a promise for the return value of function call which will be fulfilled in delay ms or rejected if given fn throw an error\n\t * @param {function} fn\n\t * @param {int} [delay] in ms default to 0\n\t * @returns {promise}\n\t */\n\tdefer.delay = function(fn, delay){\n\t\tvar d = defer();\n\t\tsetTimeout(function(){ try{ d.resolve(fn.apply(null)); }catch(e){ d.reject(e); } }, delay || 0);\n\t\treturn d.promise;\n\t};\n\n\t/**\n\t * if given value is not a promise return a fulfilled promise resolved to given value\n\t * @param {*} promise a value or a promise\n\t * @returns {promise}\n\t */\n\tdefer.promisify = function(promise){\n\t\tif ( promise && isFunc(promise.then) ) { return promise;}\n\t\treturn defer.resolved(promise);\n\t};\n\n\tfunction multiPromiseResolver(callerArguments, returnPromises){\n\t\tvar promises = slice(callerArguments);\n\t\tif ( promises.length === 1 && isArray(promises[0]) ) {\n\t\t\tif(! promises[0].length ){\n\t\t\t\treturn defer.fulfilled([]);\n\t\t\t}\n\t\t\tpromises = promises[0];\n\t\t}\n\t\tvar args = []\n\t\t\t, d = defer()\n\t\t\t, c = promises.length\n\t\t;\n\t\tif ( !c ) {\n\t\t\td.resolve(args);\n\t\t} else {\n\t\t\tvar resolver = function(i){\n\t\t\t\tpromises[i] = defer.promisify(promises[i]);\n\t\t\t\tpromises[i].then(\n\t\t\t\t\tfunction(v){\n\t\t\t\t\t\tif (! (i in args) ) { //@todo check this is still required as promises can't be resolve more than once\n\t\t\t\t\t\t\targs[i] = returnPromises ? promises[i] : v;\n\t\t\t\t\t\t\t(--c) || d.resolve(args);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\t, function(e){\n\t\t\t\t\t\tif(! (i in args) ){\n\t\t\t\t\t\t\tif( ! returnPromises ){\n\t\t\t\t\t\t\t\td.reject(e);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\targs[i] = promises[i];\n\t\t\t\t\t\t\t\t(--c) || d.resolve(args);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t};\n\t\t\tfor( var i = 0, l = c; i < l; i++ ){\n\t\t\t\tresolver(i);\n\t\t\t}\n\t\t}\n\t\treturn d.promise;\n\t}\n\n\t/**\n\t * return a promise for all given promises / values.\n\t * the returned promises will be fulfilled with a list of resolved value.\n\t * if any given promise is rejected then on the first rejection the returned promised will be rejected with the same reason\n\t * @param {array|...*} [promise] can be a single array of promise/values as first parameter or a list of direct parameters promise/value\n\t * @returns {promise} of a list of given promise resolution value\n\t */\n\tdefer.all = function(){ return multiPromiseResolver(arguments,false); };\n\n\t/**\n\t * return an always fulfilled promise of array<promise> list of promises/values regardless they resolve fulfilled or rejected\n\t * @param {array|...*} [promise] can be a single array of promise/values as first parameter or a list of direct parameters promise/value\n\t *                     (non promise values will be promisified)\n\t * @returns {promise} of the list of given promises\n\t */\n\tdefer.resolveAll = function(){ return multiPromiseResolver(arguments,true); };\n\n\t/**\n\t * transform a typical nodejs async method awaiting a callback as last parameter, receiving error as first parameter to a function that\n\t * will return a promise instead. the returned promise will resolve with normal callback value minus the first error parameter on\n\t * fulfill and will be rejected with that error as reason in case of error.\n\t * @param {object} [subject] optional subject of the method to encapsulate\n\t * @param {function} fn the function to encapsulate if the normal callback should receive more than a single parameter (minus the error)\n\t *                      the promise will resolve with the list or parameters as fulfillment value. If only one parameter is sent to the\n\t *                      callback then it will be used as the resolution value.\n\t * @returns {Function}\n\t */\n\tdefer.nodeCapsule = function(subject, fn){\n\t\tif ( !fn ) {\n\t\t\tfn = subject;\n\t\t\tsubject = void(0);\n\t\t}\n\t\treturn function(){\n\t\t\tvar d = defer(), args = slice(arguments);\n\t\t\targs.push(function(err, res){\n\t\t\t\terr ? d.reject(err) : d.resolve(arguments.length > 2 ? slice(arguments, 1) : res);\n\t\t\t});\n\t\t\ttry{\n\t\t\t\tfn.apply(subject, args);\n\t\t\t}catch(e){\n\t\t\t\td.reject(e);\n\t\t\t}\n\t\t\treturn d.promise;\n\t\t};\n\t};\n\n\ttypeof window !== undefStr && (window.D = defer);\n\ttypeof module !== undefStr && module.exports && (module.exports = defer);\n\n})();\n\n}).call(this,require('_process'))\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/d.js/lib/D.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["/**\n* attempt of a simple defer/promise library for mobile development\n* @author Jonathan Gotti < jgotti at jgotti dot net>\n* @since 2012-10\n* @version 0.6.0\n* @changelog\n*           - 2013-12-07 - last promise 1.1 specs test passings (thx to wizardwerdna)\n *                       - reduce promises footprint by unscoping methods that could be\n*           - 2013-10-23 - make it workig across node-webkit contexts\n*           - 2013-07-03 - bug correction in promixify method (thx to adrien gibrat )\n*           - 2013-06-22 - bug correction in nodeCapsule method\n*           - 2013-06-17 - remove unnecessary Array.indexOf method dependency\n*           - 2013-04-18 - add try/catch block around nodeCapsuled methods\n*           - 2013-04-13 - check promises/A+ conformity\n*                        - make some minication optimisations\n*           - 2013-03-26 - add resolved, fulfilled and rejected methods\n*           - 2013-03-21 - browser/node compatible\n*                        - new method nodeCapsule\n*                        - simpler promixify with full api support\n*           - 2013-01-25 - add rethrow method\n*                        - nextTick optimisation -> add support for process.nextTick + MessageChannel where available\n*           - 2012-12-28 - add apply method to promise\n*           - 2012-12-20 - add alwaysAsync parameters and property for default setting\n*/\n(function(undef){\n\t\"use strict\";\n\n\tvar nextTick\n\t\t, isFunc = function(f){ return ( typeof f === 'function' ); }\n\t\t, isArray = function(a){ return Array.isArray ? Array.isArray(a) : (a instanceof Array); }\n\t\t, isObjOrFunc = function(o){ return !!(o && (typeof o).match(/function|object/)); }\n\t\t, isNotVal = function(v){ return (v === false || v === undef || v === null); }\n\t\t, slice = function(a, offset){ return [].slice.call(a, offset); }\n\t\t, undefStr = 'undefined'\n\t\t, tErr = typeof TypeError === undefStr ? Error : TypeError\n\t;\n\tif ( (typeof process !== undefStr) && process.nextTick ) {\n\t\tnextTick = process.nextTick;\n\t} else if ( typeof MessageChannel !== undefStr ) {\n\t\tvar ntickChannel = new MessageChannel(), queue = [];\n\t\tntickChannel.port1.onmessage = function(){ queue.length && (queue.shift())(); };\n\t\tnextTick = function(cb){\n\t\t\tqueue.push(cb);\n\t\t\tntickChannel.port2.postMessage(0);\n\t\t};\n\t} else {\n\t\tnextTick = function(cb){ setTimeout(cb, 0); };\n\t}\n\tfunction rethrow(e){ nextTick(function(){ throw e;}); }\n\n\t/**\n\t * @typedef deferred\n\t * @property {promise} promise\n\t * @method resolve\n\t * @method fulfill\n\t * @method reject\n\t */\n\n\t/**\n\t * @typedef {function} fulfilled\n\t * @param {*} value promise resolved value\n\t * @returns {*} next promise resolution value\n\t */\n\n\t/**\n\t * @typedef {function} failed\n\t * @param {*} reason promise rejection reason\n\t * @returns {*} next promise resolution value or rethrow the reason\n\t */\n\n\t//-- defining unenclosed promise methods --//\n\t/**\n\t * same as then without failed callback\n\t * @param {fulfilled} fulfilled callback\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_success(fulfilled){ return this.then(fulfilled, undef); }\n\n\t/**\n\t * same as then with only a failed callback\n\t * @param {failed} failed callback\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_error(failed){ return this.then(undef, failed); }\n\n\n\t/**\n\t * same as then but fulfilled callback will receive multiple parameters when promise is fulfilled with an Array\n\t * @param {fulfilled} fulfilled callback\n\t * @param {failed} failed callback\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_apply(fulfilled, failed){\n\t\treturn this.then(\n\t\t\tfunction(a){\n\t\t\t\treturn isFunc(fulfilled) ? fulfilled.apply(null, isArray(a) ? a : [a]) : (defer.onlyFuncs ? a : fulfilled);\n\t\t\t}\n\t\t\t, failed || undef\n\t\t);\n\t}\n\n\t/**\n\t * cleanup method which will be always executed regardless fulfillment or rejection\n\t * @param {function} cb a callback called regardless of the fulfillment or rejection of the promise which will be called\n\t *                      when the promise is not pending anymore\n\t * @returns {promise} the same promise untouched\n\t */\n\tfunction promise_ensure(cb){\n\t\tfunction _cb(){ cb(); }\n\t\tthis.then(_cb, _cb);\n\t\treturn this;\n\t}\n\n\t/**\n\t * take a single callback which wait for an error as first parameter. other resolution values are passed as with the apply/spread method\n\t * @param {function} cb a callback called regardless of the fulfillment or rejection of the promise which will be called\n\t *                      when the promise is not pending anymore with error as first parameter if any as in node style\n\t *                      callback. Rest of parameters will be applied as with the apply method.\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_nodify(cb){\n\t\treturn this.then(\n\t\t\tfunction(a){\n\t\t\t\treturn isFunc(cb) ? cb.apply(null, isArray(a) ? a.splice(0,0,undefined) && a : [undefined,a]) : (defer.onlyFuncs ? a : cb);\n\t\t\t}\n\t\t\t, function(e){\n\t\t\t\treturn cb(e);\n\t\t\t}\n\t\t);\n\t}\n\n\t/**\n\t *\n\t * @param {function} [failed] without parameter will only rethrow promise rejection reason outside of the promise library on next tick\n\t *                            if passed a failed method then will call failed on rejection and throw the error again if failed didn't\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_rethrow(failed){\n\t\treturn this.then(\n\t\t\tundef\n\t\t\t, failed ? function(e){ failed(e); throw e; } : rethrow\n\t\t);\n\t}\n\n\t/**\n\t* @param {boolean} [alwaysAsync] if set force the async resolution for this promise independantly of the D.alwaysAsync option\n\t* @returns {deferred} defered object with property 'promise' and methods reject,fulfill,resolve (fulfill being an alias for resolve)\n\t*/\n\tvar defer = function (alwaysAsync){\n\t\tvar alwaysAsyncFn = (undef !== alwaysAsync ? alwaysAsync : defer.alwaysAsync) ? nextTick : function(fn){fn();}\n\t\t\t, status = 0 // -1 failed | 1 fulfilled\n\t\t\t, pendings = []\n\t\t\t, value\n\t\t\t/**\n\t\t\t * @typedef promise\n\t\t\t */\n\t\t\t, _promise  = {\n\t\t\t\t/**\n\t\t\t\t * @param {fulfilled|function} fulfilled callback\n\t\t\t\t * @param {failed|function} failed callback\n\t\t\t\t * @returns {promise} a new promise\n\t\t\t\t */\n\t\t\t\tthen: function(fulfilled, failed){\n\t\t\t\t\tvar d = defer();\n\t\t\t\t\tpendings.push([\n\t\t\t\t\t\tfunction(value){\n\t\t\t\t\t\t\ttry{\n\t\t\t\t\t\t\t\tif( isNotVal(fulfilled)){\n\t\t\t\t\t\t\t\t\td.resolve(value);\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\td.resolve(isFunc(fulfilled) ? fulfilled(value) : (defer.onlyFuncs ? value : fulfilled));\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}catch(e){\n\t\t\t\t\t\t\t\td.reject(e);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\t, function(err){\n\t\t\t\t\t\t\tif ( isNotVal(failed) || ((!isFunc(failed)) && defer.onlyFuncs) ) {\n\t\t\t\t\t\t\t\td.reject(err);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tif ( failed ) {\n\t\t\t\t\t\t\t\ttry{ d.resolve(isFunc(failed) ? failed(err) : failed); }catch(e){ d.reject(e);}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t]);\n\t\t\t\t\tstatus !== 0 && alwaysAsyncFn(execCallbacks);\n\t\t\t\t\treturn d.promise;\n\t\t\t\t}\n\n\t\t\t\t, success: promise_success\n\n\t\t\t\t, error: promise_error\n\t\t\t\t, otherwise: promise_error\n\n\t\t\t\t, apply: promise_apply\n\t\t\t\t, spread: promise_apply\n\n\t\t\t\t, ensure: promise_ensure\n\n\t\t\t\t, nodify: promise_nodify\n\n\t\t\t\t, rethrow: promise_rethrow\n\n\t\t\t\t, isPending: function(){ return !!(status === 0); }\n\n\t\t\t\t, getStatus: function(){ return status; }\n\t\t\t}\n\t\t;\n\t\t_promise.toSource = _promise.toString = _promise.valueOf = function(){return value === undef ? this : value; };\n\n\n\t\tfunction execCallbacks(){\n\t\t\tif ( status === 0 ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tvar cbs = pendings, i = 0, l = cbs.length, cbIndex = ~status ? 0 : 1, cb;\n\t\t\tpendings = [];\n\t\t\tfor( ; i < l; i++ ){\n\t\t\t\t(cb = cbs[i][cbIndex]) && cb(value);\n\t\t\t}\n\t\t}\n\n\t\t/**\n\t\t * fulfill deferred with given value\n\t\t * @param {*} val\n\t\t * @returns {deferred} this for method chaining\n\t\t */\n\t\tfunction _resolve(val){\n\t\t\tvar done = false;\n\t\t\tfunction once(f){\n\t\t\t\treturn function(x){\n\t\t\t\t\tif (done) {\n\t\t\t\t\t\treturn undefined;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdone = true;\n\t\t\t\t\t\treturn f(x);\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t}\n\t\t\tif ( status ) {\n\t\t\t\treturn this;\n\t\t\t}\n\t\t\ttry {\n\t\t\t\tvar then = isObjOrFunc(val) && val.then;\n\t\t\t\tif ( isFunc(then) ) { // managing a promise\n\t\t\t\t\tif( val === _promise ){\n\t\t\t\t\t\tthrow new tErr(\"Promise can't resolve itself\");\n\t\t\t\t\t}\n\t\t\t\t\tthen.call(val, once(_resolve), once(_reject));\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tonce(_reject)(e);\n\t\t\t\treturn this;\n\t\t\t}\n\t\t\talwaysAsyncFn(function(){\n\t\t\t\tvalue = val;\n\t\t\t\tstatus = 1;\n\t\t\t\texecCallbacks();\n\t\t\t});\n\t\t\treturn this;\n\t\t}\n\n\t\t/**\n\t\t * reject deferred with given reason\n\t\t * @param {*} Err\n\t\t * @returns {deferred} this for method chaining\n\t\t */\n\t\tfunction _reject(Err){\n\t\t\tstatus || alwaysAsyncFn(function(){\n\t\t\t\ttry{ throw(Err); }catch(e){ value = e; }\n\t\t\t\tstatus = -1;\n\t\t\t\texecCallbacks();\n\t\t\t});\n\t\t\treturn this;\n\t\t}\n\t\treturn /**@type deferred */ {\n\t\t\tpromise:_promise\n\t\t\t,resolve:_resolve\n\t\t\t,fulfill:_resolve // alias\n\t\t\t,reject:_reject\n\t\t};\n\t};\n\n\tdefer.deferred = defer.defer = defer;\n\tdefer.nextTick = nextTick;\n\tdefer.alwaysAsync = true; // setting this will change default behaviour. use it only if necessary as asynchronicity will force some delay between your promise resolutions and is not always what you want.\n\t/**\n\t* setting onlyFuncs to false will break promises/A+ conformity by allowing you to pass non undefined/null values instead of callbacks\n\t* instead of just ignoring any non function parameters to then,success,error... it will accept non null|undefined values.\n\t* this will allow you shortcuts like promise.then('val','handled error'')\n\t* to be equivalent of promise.then(function(){ return 'val';},function(){ return 'handled error'})\n\t*/\n\tdefer.onlyFuncs = true;\n\n\t/**\n\t * return a fulfilled promise of given value (always async resolution)\n\t * @param {*} value\n\t * @returns {promise}\n\t */\n\tdefer.resolved = defer.fulfilled = function(value){ return defer(true).resolve(value).promise; };\n\n\t/**\n\t * return a rejected promise with given reason of rejection (always async rejection)\n\t * @param {*} reason\n\t * @returns {promise}\n\t */\n\tdefer.rejected = function(reason){ return defer(true).reject(reason).promise; };\n\n\t/**\n\t * return a promise with no resolution value which will be resolved in time ms (using setTimeout)\n\t * @param {int} [time] in ms default to 0\n\t * @returns {promise}\n\t */\n\tdefer.wait = function(time){\n\t\tvar d = defer();\n\t\tsetTimeout(d.resolve, time || 0);\n\t\treturn d.promise;\n\t};\n\n\t/**\n\t * return a promise for the return value of function call which will be fulfilled in delay ms or rejected if given fn throw an error\n\t * @param {function} fn\n\t * @param {int} [delay] in ms default to 0\n\t * @returns {promise}\n\t */\n\tdefer.delay = function(fn, delay){\n\t\tvar d = defer();\n\t\tsetTimeout(function(){ try{ d.resolve(fn.apply(null)); }catch(e){ d.reject(e); } }, delay || 0);\n\t\treturn d.promise;\n\t};\n\n\t/**\n\t * if given value is not a promise return a fulfilled promise resolved to given value\n\t * @param {*} promise a value or a promise\n\t * @returns {promise}\n\t */\n\tdefer.promisify = function(promise){\n\t\tif ( promise && isFunc(promise.then) ) { return promise;}\n\t\treturn defer.resolved(promise);\n\t};\n\n\tfunction multiPromiseResolver(callerArguments, returnPromises){\n\t\tvar promises = slice(callerArguments);\n\t\tif ( promises.length === 1 && isArray(promises[0]) ) {\n\t\t\tif(! promises[0].length ){\n\t\t\t\treturn defer.fulfilled([]);\n\t\t\t}\n\t\t\tpromises = promises[0];\n\t\t}\n\t\tvar args = []\n\t\t\t, d = defer()\n\t\t\t, c = promises.length\n\t\t;\n\t\tif ( !c ) {\n\t\t\td.resolve(args);\n\t\t} else {\n\t\t\tvar resolver = function(i){\n\t\t\t\tpromises[i] = defer.promisify(promises[i]);\n\t\t\t\tpromises[i].then(\n\t\t\t\t\tfunction(v){\n\t\t\t\t\t\tif (! (i in args) ) { //@todo check this is still required as promises can't be resolve more than once\n\t\t\t\t\t\t\targs[i] = returnPromises ? promises[i] : v;\n\t\t\t\t\t\t\t(--c) || d.resolve(args);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\t, function(e){\n\t\t\t\t\t\tif(! (i in args) ){\n\t\t\t\t\t\t\tif( ! returnPromises ){\n\t\t\t\t\t\t\t\td.reject(e);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\targs[i] = promises[i];\n\t\t\t\t\t\t\t\t(--c) || d.resolve(args);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t};\n\t\t\tfor( var i = 0, l = c; i < l; i++ ){\n\t\t\t\tresolver(i);\n\t\t\t}\n\t\t}\n\t\treturn d.promise;\n\t}\n\n\t/**\n\t * return a promise for all given promises / values.\n\t * the returned promises will be fulfilled with a list of resolved value.\n\t * if any given promise is rejected then on the first rejection the returned promised will be rejected with the same reason\n\t * @param {array|...*} [promise] can be a single array of promise/values as first parameter or a list of direct parameters promise/value\n\t * @returns {promise} of a list of given promise resolution value\n\t */\n\tdefer.all = function(){ return multiPromiseResolver(arguments,false); };\n\n\t/**\n\t * return an always fulfilled promise of array<promise> list of promises/values regardless they resolve fulfilled or rejected\n\t * @param {array|...*} [promise] can be a single array of promise/values as first parameter or a list of direct parameters promise/value\n\t *                     (non promise values will be promisified)\n\t * @returns {promise} of the list of given promises\n\t */\n\tdefer.resolveAll = function(){ return multiPromiseResolver(arguments,true); };\n\n\t/**\n\t * transform a typical nodejs async method awaiting a callback as last parameter, receiving error as first parameter to a function that\n\t * will return a promise instead. the returned promise will resolve with normal callback value minus the first error parameter on\n\t * fulfill and will be rejected with that error as reason in case of error.\n\t * @param {object} [subject] optional subject of the method to encapsulate\n\t * @param {function} fn the function to encapsulate if the normal callback should receive more than a single parameter (minus the error)\n\t *                      the promise will resolve with the list or parameters as fulfillment value. If only one parameter is sent to the\n\t *                      callback then it will be used as the resolution value.\n\t * @returns {Function}\n\t */\n\tdefer.nodeCapsule = function(subject, fn){\n\t\tif ( !fn ) {\n\t\t\tfn = subject;\n\t\t\tsubject = void(0);\n\t\t}\n\t\treturn function(){\n\t\t\tvar d = defer(), args = slice(arguments);\n\t\t\targs.push(function(err, res){\n\t\t\t\terr ? d.reject(err) : d.resolve(arguments.length > 2 ? slice(arguments, 1) : res);\n\t\t\t});\n\t\t\ttry{\n\t\t\t\tfn.apply(subject, args);\n\t\t\t}catch(e){\n\t\t\t\td.reject(e);\n\t\t\t}\n\t\t\treturn d.promise;\n\t\t};\n\t};\n\n\ttypeof window !== undefStr && (window.D = defer);\n\ttypeof module !== undefStr && module.exports && (module.exports = defer);\n\n})();\n"]}","/**\n * Module dependencies.\n */\n\nvar Emitter = require('emitter');\nvar reduce = require('reduce');\n\n/**\n * Root reference for iframes.\n */\n\nvar root = 'undefined' == typeof window\n  ? this\n  : window;\n\n/**\n * Noop.\n */\n\nfunction noop(){};\n\n/**\n * Check if `obj` is a host object,\n * we don't want to serialize these :)\n *\n * TODO: future proof, move to compoent land\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\n\nfunction isHost(obj) {\n  var str = {}.toString.call(obj);\n\n  switch (str) {\n    case '[object File]':\n    case '[object Blob]':\n    case '[object FormData]':\n      return true;\n    default:\n      return false;\n  }\n}\n\n/**\n * Determine XHR.\n */\n\nfunction getXHR() {\n  if (root.XMLHttpRequest\n    && ('file:' != root.location.protocol || !root.ActiveXObject)) {\n    return new XMLHttpRequest;\n  } else {\n    try { return new ActiveXObject('Microsoft.XMLHTTP'); } catch(e) {}\n    try { return new ActiveXObject('Msxml2.XMLHTTP.6.0'); } catch(e) {}\n    try { return new ActiveXObject('Msxml2.XMLHTTP.3.0'); } catch(e) {}\n    try { return new ActiveXObject('Msxml2.XMLHTTP'); } catch(e) {}\n  }\n  return false;\n}\n\n/**\n * Removes leading and trailing whitespace, added to support IE.\n *\n * @param {String} s\n * @return {String}\n * @api private\n */\n\nvar trim = ''.trim\n  ? function(s) { return s.trim(); }\n  : function(s) { return s.replace(/(^\\s*|\\s*$)/g, ''); };\n\n/**\n * Check if `obj` is an object.\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\n\nfunction isObject(obj) {\n  return obj === Object(obj);\n}\n\n/**\n * Serialize the given `obj`.\n *\n * @param {Object} obj\n * @return {String}\n * @api private\n */\n\nfunction serialize(obj) {\n  if (!isObject(obj)) return obj;\n  var pairs = [];\n  for (var key in obj) {\n    if (null != obj[key]) {\n      pairs.push(encodeURIComponent(key)\n        + '=' + encodeURIComponent(obj[key]));\n    }\n  }\n  return pairs.join('&');\n}\n\n/**\n * Expose serialization method.\n */\n\n request.serializeObject = serialize;\n\n /**\n  * Parse the given x-www-form-urlencoded `str`.\n  *\n  * @param {String} str\n  * @return {Object}\n  * @api private\n  */\n\nfunction parseString(str) {\n  var obj = {};\n  var pairs = str.split('&');\n  var parts;\n  var pair;\n\n  for (var i = 0, len = pairs.length; i < len; ++i) {\n    pair = pairs[i];\n    parts = pair.split('=');\n    obj[decodeURIComponent(parts[0])] = decodeURIComponent(parts[1]);\n  }\n\n  return obj;\n}\n\n/**\n * Expose parser.\n */\n\nrequest.parseString = parseString;\n\n/**\n * Default MIME type map.\n *\n *     superagent.types.xml = 'application/xml';\n *\n */\n\nrequest.types = {\n  html: 'text/html',\n  json: 'application/json',\n  xml: 'application/xml',\n  urlencoded: 'application/x-www-form-urlencoded',\n  'form': 'application/x-www-form-urlencoded',\n  'form-data': 'application/x-www-form-urlencoded'\n};\n\n/**\n * Default serialization map.\n *\n *     superagent.serialize['application/xml'] = function(obj){\n *       return 'generated xml here';\n *     };\n *\n */\n\n request.serialize = {\n   'application/x-www-form-urlencoded': serialize,\n   'application/json': JSON.stringify\n };\n\n /**\n  * Default parsers.\n  *\n  *     superagent.parse['application/xml'] = function(str){\n  *       return { object parsed from str };\n  *     };\n  *\n  */\n\nrequest.parse = {\n  'application/x-www-form-urlencoded': parseString,\n  'application/json': JSON.parse\n};\n\n/**\n * Parse the given header `str` into\n * an object containing the mapped fields.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseHeader(str) {\n  var lines = str.split(/\\r?\\n/);\n  var fields = {};\n  var index;\n  var line;\n  var field;\n  var val;\n\n  lines.pop(); // trailing CRLF\n\n  for (var i = 0, len = lines.length; i < len; ++i) {\n    line = lines[i];\n    index = line.indexOf(':');\n    field = line.slice(0, index).toLowerCase();\n    val = trim(line.slice(index + 1));\n    fields[field] = val;\n  }\n\n  return fields;\n}\n\n/**\n * Return the mime type for the given `str`.\n *\n * @param {String} str\n * @return {String}\n * @api private\n */\n\nfunction type(str){\n  return str.split(/ *; */).shift();\n};\n\n/**\n * Return header field parameters.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction params(str){\n  return reduce(str.split(/ *; */), function(obj, str){\n    var parts = str.split(/ *= */)\n      , key = parts.shift()\n      , val = parts.shift();\n\n    if (key && val) obj[key] = val;\n    return obj;\n  }, {});\n};\n\n/**\n * Initialize a new `Response` with the given `xhr`.\n *\n *  - set flags (.ok, .error, etc)\n *  - parse header\n *\n * Examples:\n *\n *  Aliasing `superagent` as `request` is nice:\n *\n *      request = superagent;\n *\n *  We can use the promise-like API, or pass callbacks:\n *\n *      request.get('/').end(function(res){});\n *      request.get('/', function(res){});\n *\n *  Sending data can be chained:\n *\n *      request\n *        .post('/user')\n *        .send({ name: 'tj' })\n *        .end(function(res){});\n *\n *  Or passed to `.send()`:\n *\n *      request\n *        .post('/user')\n *        .send({ name: 'tj' }, function(res){});\n *\n *  Or passed to `.post()`:\n *\n *      request\n *        .post('/user', { name: 'tj' })\n *        .end(function(res){});\n *\n * Or further reduced to a single call for simple cases:\n *\n *      request\n *        .post('/user', { name: 'tj' }, function(res){});\n *\n * @param {XMLHTTPRequest} xhr\n * @param {Object} options\n * @api private\n */\n\nfunction Response(req, options) {\n  options = options || {};\n  this.req = req;\n  this.xhr = this.req.xhr;\n  this.text = this.req.method !='HEAD' \n     ? this.xhr.responseText \n     : null;\n  this.setStatusProperties(this.xhr.status);\n  this.header = this.headers = parseHeader(this.xhr.getAllResponseHeaders());\n  // getAllResponseHeaders sometimes falsely returns \"\" for CORS requests, but\n  // getResponseHeader still works. so we get content-type even if getting\n  // other headers fails.\n  this.header['content-type'] = this.xhr.getResponseHeader('content-type');\n  this.setHeaderProperties(this.header);\n  this.body = this.req.method != 'HEAD'\n    ? this.parseBody(this.text)\n    : null;\n}\n\n/**\n * Get case-insensitive `field` value.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\nResponse.prototype.get = function(field){\n  return this.header[field.toLowerCase()];\n};\n\n/**\n * Set header related properties:\n *\n *   - `.type` the content type without params\n *\n * A response of \"Content-Type: text/plain; charset=utf-8\"\n * will provide you with a `.type` of \"text/plain\".\n *\n * @param {Object} header\n * @api private\n */\n\nResponse.prototype.setHeaderProperties = function(header){\n  // content-type\n  var ct = this.header['content-type'] || '';\n  this.type = type(ct);\n\n  // params\n  var obj = params(ct);\n  for (var key in obj) this[key] = obj[key];\n};\n\n/**\n * Parse the given body `str`.\n *\n * Used for auto-parsing of bodies. Parsers\n * are defined on the `superagent.parse` object.\n *\n * @param {String} str\n * @return {Mixed}\n * @api private\n */\n\nResponse.prototype.parseBody = function(str){\n  var parse = request.parse[this.type];\n  return parse && str && str.length\n    ? parse(str)\n    : null;\n};\n\n/**\n * Set flags such as `.ok` based on `status`.\n *\n * For example a 2xx response will give you a `.ok` of __true__\n * whereas 5xx will be __false__ and `.error` will be __true__. The\n * `.clientError` and `.serverError` are also available to be more\n * specific, and `.statusType` is the class of error ranging from 1..5\n * sometimes useful for mapping respond colors etc.\n *\n * \"sugar\" properties are also defined for common cases. Currently providing:\n *\n *   - .noContent\n *   - .badRequest\n *   - .unauthorized\n *   - .notAcceptable\n *   - .notFound\n *\n * @param {Number} status\n * @api private\n */\n\nResponse.prototype.setStatusProperties = function(status){\n  var type = status / 100 | 0;\n\n  // status / class\n  this.status = status;\n  this.statusType = type;\n\n  // basics\n  this.info = 1 == type;\n  this.ok = 2 == type;\n  this.clientError = 4 == type;\n  this.serverError = 5 == type;\n  this.error = (4 == type || 5 == type)\n    ? this.toError()\n    : false;\n\n  // sugar\n  this.accepted = 202 == status;\n  this.noContent = 204 == status || 1223 == status;\n  this.badRequest = 400 == status;\n  this.unauthorized = 401 == status;\n  this.notAcceptable = 406 == status;\n  this.notFound = 404 == status;\n  this.forbidden = 403 == status;\n};\n\n/**\n * Return an `Error` representative of this response.\n *\n * @return {Error}\n * @api public\n */\n\nResponse.prototype.toError = function(){\n  var req = this.req;\n  var method = req.method;\n  var url = req.url;\n\n  var msg = 'cannot ' + method + ' ' + url + ' (' + this.status + ')';\n  var err = new Error(msg);\n  err.status = this.status;\n  err.method = method;\n  err.url = url;\n\n  return err;\n};\n\n/**\n * Expose `Response`.\n */\n\nrequest.Response = Response;\n\n/**\n * Initialize a new `Request` with the given `method` and `url`.\n *\n * @param {String} method\n * @param {String} url\n * @api public\n */\n\nfunction Request(method, url) {\n  var self = this;\n  Emitter.call(this);\n  this._query = this._query || [];\n  this.method = method;\n  this.url = url;\n  this.header = {};\n  this._header = {};\n  this.on('end', function(){\n    var err = null;\n    var res = null;\n\n    try {\n      res = new Response(self); \n    } catch(e) {\n      err = new Error('Parser is unable to parse the response');\n      err.parse = true;\n      err.original = e;\n    }\n\n    self.callback(err, res);\n  });\n}\n\n/**\n * Mixin `Emitter`.\n */\n\nEmitter(Request.prototype);\n\n/**\n * Allow for extension\n */\n\nRequest.prototype.use = function(fn) {\n  fn(this);\n  return this;\n}\n\n/**\n * Set timeout to `ms`.\n *\n * @param {Number} ms\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.timeout = function(ms){\n  this._timeout = ms;\n  return this;\n};\n\n/**\n * Clear previous timeout.\n *\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.clearTimeout = function(){\n  this._timeout = 0;\n  clearTimeout(this._timer);\n  return this;\n};\n\n/**\n * Abort the request, and clear potential timeout.\n *\n * @return {Request}\n * @api public\n */\n\nRequest.prototype.abort = function(){\n  if (this.aborted) return;\n  this.aborted = true;\n  this.xhr.abort();\n  this.clearTimeout();\n  this.emit('abort');\n  return this;\n};\n\n/**\n * Set header `field` to `val`, or multiple fields with one object.\n *\n * Examples:\n *\n *      req.get('/')\n *        .set('Accept', 'application/json')\n *        .set('X-API-Key', 'foobar')\n *        .end(callback);\n *\n *      req.get('/')\n *        .set({ Accept: 'application/json', 'X-API-Key': 'foobar' })\n *        .end(callback);\n *\n * @param {String|Object} field\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.set = function(field, val){\n  if (isObject(field)) {\n    for (var key in field) {\n      this.set(key, field[key]);\n    }\n    return this;\n  }\n  this._header[field.toLowerCase()] = val;\n  this.header[field] = val;\n  return this;\n};\n\n/**\n * Remove header `field`.\n *\n * Example:\n *\n *      req.get('/')\n *        .unset('User-Agent')\n *        .end(callback);\n *\n * @param {String} field\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.unset = function(field){\n  delete this._header[field.toLowerCase()];\n  delete this.header[field];\n  return this;\n};\n\n/**\n * Get case-insensitive header `field` value.\n *\n * @param {String} field\n * @return {String}\n * @api private\n */\n\nRequest.prototype.getHeader = function(field){\n  return this._header[field.toLowerCase()];\n};\n\n/**\n * Set Content-Type to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n *      superagent.types.xml = 'application/xml';\n *\n *      request.post('/')\n *        .type('xml')\n *        .send(xmlstring)\n *        .end(callback);\n *\n *      request.post('/')\n *        .type('application/xml')\n *        .send(xmlstring)\n *        .end(callback);\n *\n * @param {String} type\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.type = function(type){\n  this.set('Content-Type', request.types[type] || type);\n  return this;\n};\n\n/**\n * Set Accept to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n *      superagent.types.json = 'application/json';\n *\n *      request.get('/agent')\n *        .accept('json')\n *        .end(callback);\n *\n *      request.get('/agent')\n *        .accept('application/json')\n *        .end(callback);\n *\n * @param {String} accept\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.accept = function(type){\n  this.set('Accept', request.types[type] || type);\n  return this;\n};\n\n/**\n * Set Authorization field value with `user` and `pass`.\n *\n * @param {String} user\n * @param {String} pass\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.auth = function(user, pass){\n  var str = btoa(user + ':' + pass);\n  this.set('Authorization', 'Basic ' + str);\n  return this;\n};\n\n/**\n* Add query-string `val`.\n*\n* Examples:\n*\n*   request.get('/shoes')\n*     .query('size=10')\n*     .query({ color: 'blue' })\n*\n* @param {Object|String} val\n* @return {Request} for chaining\n* @api public\n*/\n\nRequest.prototype.query = function(val){\n  if ('string' != typeof val) val = serialize(val);\n  if (val) this._query.push(val);\n  return this;\n};\n\n/**\n * Write the field `name` and `val` for \"multipart/form-data\"\n * request bodies.\n *\n * ``` js\n * request.post('/upload')\n *   .field('foo', 'bar')\n *   .end(callback);\n * ```\n *\n * @param {String} name\n * @param {String|Blob|File} val\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.field = function(name, val){\n  if (!this._formData) this._formData = new FormData();\n  this._formData.append(name, val);\n  return this;\n};\n\n/**\n * Queue the given `file` as an attachment to the specified `field`,\n * with optional `filename`.\n *\n * ``` js\n * request.post('/upload')\n *   .attach(new Blob(['<a id=\"a\"><b id=\"b\">hey!</b></a>'], { type: \"text/html\"}))\n *   .end(callback);\n * ```\n *\n * @param {String} field\n * @param {Blob|File} file\n * @param {String} filename\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.attach = function(field, file, filename){\n  if (!this._formData) this._formData = new FormData();\n  this._formData.append(field, file, filename);\n  return this;\n};\n\n/**\n * Send `data`, defaulting the `.type()` to \"json\" when\n * an object is given.\n *\n * Examples:\n *\n *       // querystring\n *       request.get('/search')\n *         .end(callback)\n *\n *       // multiple data \"writes\"\n *       request.get('/search')\n *         .send({ search: 'query' })\n *         .send({ range: '1..5' })\n *         .send({ order: 'desc' })\n *         .end(callback)\n *\n *       // manual json\n *       request.post('/user')\n *         .type('json')\n *         .send('{\"name\":\"tj\"})\n *         .end(callback)\n *\n *       // auto json\n *       request.post('/user')\n *         .send({ name: 'tj' })\n *         .end(callback)\n *\n *       // manual x-www-form-urlencoded\n *       request.post('/user')\n *         .type('form')\n *         .send('name=tj')\n *         .end(callback)\n *\n *       // auto x-www-form-urlencoded\n *       request.post('/user')\n *         .type('form')\n *         .send({ name: 'tj' })\n *         .end(callback)\n *\n *       // defaults to x-www-form-urlencoded\n  *      request.post('/user')\n  *        .send('name=tobi')\n  *        .send('species=ferret')\n  *        .end(callback)\n *\n * @param {String|Object} data\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.send = function(data){\n  var obj = isObject(data);\n  var type = this.getHeader('Content-Type');\n\n  // merge\n  if (obj && isObject(this._data)) {\n    for (var key in data) {\n      this._data[key] = data[key];\n    }\n  } else if ('string' == typeof data) {\n    if (!type) this.type('form');\n    type = this.getHeader('Content-Type');\n    if ('application/x-www-form-urlencoded' == type) {\n      this._data = this._data\n        ? this._data + '&' + data\n        : data;\n    } else {\n      this._data = (this._data || '') + data;\n    }\n  } else {\n    this._data = data;\n  }\n\n  if (!obj) return this;\n  if (!type) this.type('json');\n  return this;\n};\n\n/**\n * Invoke the callback with `err` and `res`\n * and handle arity check.\n *\n * @param {Error} err\n * @param {Response} res\n * @api private\n */\n\nRequest.prototype.callback = function(err, res){\n  var fn = this._callback;\n  this.clearTimeout();\n  if (2 == fn.length) return fn(err, res);\n  if (err) return this.emit('error', err);\n  fn(res);\n};\n\n/**\n * Invoke callback with x-domain error.\n *\n * @api private\n */\n\nRequest.prototype.crossDomainError = function(){\n  var err = new Error('Origin is not allowed by Access-Control-Allow-Origin');\n  err.crossDomain = true;\n  this.callback(err);\n};\n\n/**\n * Invoke callback with timeout error.\n *\n * @api private\n */\n\nRequest.prototype.timeoutError = function(){\n  var timeout = this._timeout;\n  var err = new Error('timeout of ' + timeout + 'ms exceeded');\n  err.timeout = timeout;\n  this.callback(err);\n};\n\n/**\n * Enable transmission of cookies with x-domain requests.\n *\n * Note that for this to work the origin must not be\n * using \"Access-Control-Allow-Origin\" with a wildcard,\n * and also must set \"Access-Control-Allow-Credentials\"\n * to \"true\".\n *\n * @api public\n */\n\nRequest.prototype.withCredentials = function(){\n  this._withCredentials = true;\n  return this;\n};\n\n/**\n * Initiate request, invoking callback `fn(res)`\n * with an instanceof `Response`.\n *\n * @param {Function} fn\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.end = function(fn){\n  var self = this;\n  var xhr = this.xhr = getXHR();\n  var query = this._query.join('&');\n  var timeout = this._timeout;\n  var data = this._formData || this._data;\n\n  // store callback\n  this._callback = fn || noop;\n\n  // state change\n  xhr.onreadystatechange = function(){\n    if (4 != xhr.readyState) return;\n    if (0 == xhr.status) {\n      if (self.aborted) return self.timeoutError();\n      return self.crossDomainError();\n    }\n    self.emit('end');\n  };\n\n  // progress\n  if (xhr.upload) {\n    xhr.upload.onprogress = function(e){\n      e.percent = e.loaded / e.total * 100;\n      self.emit('progress', e);\n    };\n  }\n\n  // timeout\n  if (timeout && !this._timer) {\n    this._timer = setTimeout(function(){\n      self.abort();\n    }, timeout);\n  }\n\n  // querystring\n  if (query) {\n    query = request.serializeObject(query);\n    this.url += ~this.url.indexOf('?')\n      ? '&' + query\n      : '?' + query;\n  }\n\n  // initiate request\n  xhr.open(this.method, this.url, true);\n\n  // CORS\n  if (this._withCredentials) xhr.withCredentials = true;\n\n  // body\n  if ('GET' != this.method && 'HEAD' != this.method && 'string' != typeof data && !isHost(data)) {\n    // serialize stuff\n    var serialize = request.serialize[this.getHeader('Content-Type')];\n    if (serialize) data = serialize(data);\n  }\n\n  // set header fields\n  for (var field in this.header) {\n    if (null == this.header[field]) continue;\n    xhr.setRequestHeader(field, this.header[field]);\n  }\n\n  // send stuff\n  this.emit('request', this);\n  xhr.send(data);\n  return this;\n};\n\n/**\n * Expose `Request`.\n */\n\nrequest.Request = Request;\n\n/**\n * Issue a request:\n *\n * Examples:\n *\n *    request('GET', '/users').end(callback)\n *    request('/users').end(callback)\n *    request('/users', callback)\n *\n * @param {String} method\n * @param {String|Function} url or callback\n * @return {Request}\n * @api public\n */\n\nfunction request(method, url) {\n  // callback\n  if ('function' == typeof url) {\n    return new Request('GET', method).end(url);\n  }\n\n  // url first\n  if (1 == arguments.length) {\n    return new Request('GET', method);\n  }\n\n  return new Request(method, url);\n}\n\n/**\n * GET `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} data or fn\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.get = function(url, data, fn){\n  var req = request('GET', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.query(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * HEAD `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} data or fn\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.head = function(url, data, fn){\n  var req = request('HEAD', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.send(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * DELETE `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.del = function(url, fn){\n  var req = request('DELETE', url);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * PATCH `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} data\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.patch = function(url, data, fn){\n  var req = request('PATCH', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.send(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * POST `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} data\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.post = function(url, data, fn){\n  var req = request('POST', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.send(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * PUT `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} data or fn\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.put = function(url, data, fn){\n  var req = request('PUT', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.send(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * Expose `request`.\n */\n\nmodule.exports = request;\n","\n/**\n * Expose `Emitter`.\n */\n\nmodule.exports = Emitter;\n\n/**\n * Initialize a new `Emitter`.\n *\n * @api public\n */\n\nfunction Emitter(obj) {\n  if (obj) return mixin(obj);\n};\n\n/**\n * Mixin the emitter properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\nfunction mixin(obj) {\n  for (var key in Emitter.prototype) {\n    obj[key] = Emitter.prototype[key];\n  }\n  return obj;\n}\n\n/**\n * Listen on the given `event` with `fn`.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.on =\nEmitter.prototype.addEventListener = function(event, fn){\n  this._callbacks = this._callbacks || {};\n  (this._callbacks[event] = this._callbacks[event] || [])\n    .push(fn);\n  return this;\n};\n\n/**\n * Adds an `event` listener that will be invoked a single\n * time then automatically removed.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.once = function(event, fn){\n  var self = this;\n  this._callbacks = this._callbacks || {};\n\n  function on() {\n    self.off(event, on);\n    fn.apply(this, arguments);\n  }\n\n  on.fn = fn;\n  this.on(event, on);\n  return this;\n};\n\n/**\n * Remove the given callback for `event` or all\n * registered callbacks.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.off =\nEmitter.prototype.removeListener =\nEmitter.prototype.removeAllListeners =\nEmitter.prototype.removeEventListener = function(event, fn){\n  this._callbacks = this._callbacks || {};\n\n  // all\n  if (0 == arguments.length) {\n    this._callbacks = {};\n    return this;\n  }\n\n  // specific event\n  var callbacks = this._callbacks[event];\n  if (!callbacks) return this;\n\n  // remove all handlers\n  if (1 == arguments.length) {\n    delete this._callbacks[event];\n    return this;\n  }\n\n  // remove specific handler\n  var cb;\n  for (var i = 0; i < callbacks.length; i++) {\n    cb = callbacks[i];\n    if (cb === fn || cb.fn === fn) {\n      callbacks.splice(i, 1);\n      break;\n    }\n  }\n  return this;\n};\n\n/**\n * Emit `event` with the given args.\n *\n * @param {String} event\n * @param {Mixed} ...\n * @return {Emitter}\n */\n\nEmitter.prototype.emit = function(event){\n  this._callbacks = this._callbacks || {};\n  var args = [].slice.call(arguments, 1)\n    , callbacks = this._callbacks[event];\n\n  if (callbacks) {\n    callbacks = callbacks.slice(0);\n    for (var i = 0, len = callbacks.length; i < len; ++i) {\n      callbacks[i].apply(this, args);\n    }\n  }\n\n  return this;\n};\n\n/**\n * Return array of callbacks for `event`.\n *\n * @param {String} event\n * @return {Array}\n * @api public\n */\n\nEmitter.prototype.listeners = function(event){\n  this._callbacks = this._callbacks || {};\n  return this._callbacks[event] || [];\n};\n\n/**\n * Check if this emitter has `event` handlers.\n *\n * @param {String} event\n * @return {Boolean}\n * @api public\n */\n\nEmitter.prototype.hasListeners = function(event){\n  return !! this.listeners(event).length;\n};\n","\n/**\n * Reduce `arr` with `fn`.\n *\n * @param {Array} arr\n * @param {Function} fn\n * @param {Mixed} initial\n *\n * TODO: combatible error handling?\n */\n\nmodule.exports = function(arr, fn, initial){  \n  var idx = 0;\n  var len = arr.length;\n  var curr = arguments.length == 3\n    ? initial\n    : arr[idx++];\n\n  while (idx < len) {\n    curr = fn.call(null, curr, arr[idx], ++idx, arr);\n  }\n  \n  return curr;\n};","module.exports={\n  \"name\": \"deployr\",\n  \"version\": \"7.4.1\",\n  \"description\": \"Simplified JavaScript client library for making requests to DeployR.\",\n  \"keywords\": [\n    \"deployr\",\n    \"deployr.io\",\n    \"ajax\",\n    \"R\",\n    \"api\",\n    \"simple\"\n  ],\n  \"author\": \"DeployR - Revolution Analytics Inc.\",\n  \"contributors\": [\n    \"Sean Wells\"\n  ],\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git://github.com/deployr/js-client-library.git\"\n  },\n  \"homepage\": \"http://deployr.revolutionanalytics.com/documents/dev/client-jsdoc\",\n  \"scripts\": {\n    \"start\": \"gulp start\",\n    \"build\": \"gulp\"\n  },\n  \"devDependencies\": {\n    \"browserify\": \"^9.0.3\",\n    \"gulp\": \"^3.8.11\",\n    \"gulp-connect\": \"^2.2.0\",\n    \"gulp-header\": \"^1.2.2\",\n    \"gulp-jshint\": \"^1.9.2\",\n    \"gulp-livereload\": \"^3.8.0\",\n    \"gulp-plumber\": \"^0.6.6\",\n    \"gulp-rename\": \"^1.2.2\",    \n    \"gulp-uglify\": \"^1.2.0\",\n    \"gulp-util\": \"^3.0.4\",\n    \"tape\": \"^3.5.0\",\n    \"vinyl-source-stream\": \"^1.0.0\"\n  },\n  \"dependencies\": {\n    \"d.js\": \"^0.6.0\",    \n    \"superagent\": \"^0.21.0\",\n    \"ws\": \"^0.4.32\"\n  },\n  \"main\": \"deployr.js\",\n  \"engines\": {\n    \"node\": \">= 0.10.0\"\n  },\n  \"license\": \"Apache 2.0 License\",\n  \"bugs\": {\n    \"url\": \"https://github.com/deployr/js-client-library/issues\"\n  },\n  \"directories\": {\n    \"example\": \"examples\",\n    \"test\": \"test\"\n  }\n}\n"]} +//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","deployr.js","apis.json","lib/deprecated.js","lib/emitter.js","lib/encoder.js","lib/es.js","lib/lang.js","lib/logger.js","lib/optional.js","lib/queue.js","lib/rinput.js","lib/rinputs.js","lib/rtypes.js","lib/selfish.js","lib/utils.js","node_modules/browserify/lib/_empty.js","node_modules/browserify/node_modules/process/browser.js","node_modules/d.js/lib/D.js","node_modules/superagent/lib/client.js","node_modules/superagent/node_modules/component-emitter/index.js","node_modules/superagent/node_modules/reduce-component/index.js","package.json"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC92CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/aA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtyJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACnHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC3TA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/KA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACfA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtFA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtIA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACjJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/JA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9HA;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtbA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzjCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","(function (process){\n/*!\n * Copyright (C) 2010-2015 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nvar win         = (typeof window !== 'undefined'),   \n    request     = require('superagent'),\n    D           = require('d.js'),\n    fs          = require('fs'),\n    apis        = require('./apis.json'), \n    EventStream = require('./lib/es'),\n    utils       = require('./lib/utils'),\n    Lang        = require('./lib/lang'),   \n    Logger      = require('./lib/logger'),   \n    Queue       = require('./lib/queue'),\n    Emitter     = require('./lib/emitter'),\n    encoder     = require('./lib/encoder'),\n    Base        = require('./lib/selfish').Base,\n    RInput      = require('./lib/rinput'),    \n    RInputs     = require('./lib/rinputs'),\n    merge       = utils.merge;\n\n/*\n * Turn global logging off by default\n */\nLogger.setLevel(Logger.OFF);\n\n/*\n * Global options that persist through all DeployR requests.\n */\nvar globalOptions = { \n  cors: false,\n  logging: false,\n  sticky: false,\n  cookies: null,\n  host: '',\n  allowSelfSignedSSLCert: false,\n  maxRequests: null, // no socket pooling in http.Agent\n  events:{},\n  set: function(prop, value) { \n    if (prop !== 'set') { \n      if (prop === 'host' && value) {         \n         // Be more forgiving on the entered DeployR 'endpoint':\n         //   - http(s)://dhost:port\n         //   - http(s)://dhost:port/deployr\n         //   - dhost:port\n         //   - dhost:port/deployr         \n         value = value.replace(/\\/*$|\\/*deployr\\/*$/, '');\n         value = (new RegExp('^(http|https)://', 'i')).test(value) ? value : \n            'http://' + value;\n      }\n\n      this[prop] = value; \n    } \n  }\n};\n\n/*\n * The top-level DeployR API response entities.\n */\nvar TOPLEVEL_ENTITIES = [\n  'user', \n  'project', \n  'workspace', \n  'execution', \n  'directory', \n  'repository', \n  'packages' \n];\n\n/*\n * Notify global IO error events accessible by all subscribers across requests.\n */\nfunction raiseGlobalErrors(api, res) {\n  var code    = res.deployr ? res.deployr.response.errorCode : res.status,\n      context = this;\n\n  // -- global events if provided --\n  if (globalOptions.events) {\n    if (!res.deployr) {\n      res = res.text;\n    }\n\n    context = globalOptions.events.ctx || context;\n\n    // -- general global failure --\n    if (globalOptions.events.error) {\n      globalOptions.events.error.apply(context, [api, res]);\n    }\n\n    // -- HTTP or DeployR global errors --    \n    if (globalOptions.events[code]) {\n      globalOptions.events[code].apply(context, [api, res]);\n    }\n  }\n}\n\n/**\n * The `DeployR` request class is a utility that brokers HTTP requests through a \n * simplified fluid interface to DeployR.\n *\n * @module deployr\n * @for deployr\n */\nvar DeployR = Base.extend(Emitter, RInputs, {\n\n  /**\n   * The `DeployR` Request class is a utility that brokers HTTP requests through \n   * a simplified fluid interface to DeployR.\n   * \n   * @class \n   * @constructor\n   * @param {String} api The DeployR API\n   * @param {Object} link The object literal containing the previous request.\n   * @api private\n   */\n  initialize: function initialize(api, link) {\n     Emitter.initialize.call(this, {});\n  \n     var opts = globalOptions;\n\n     if (!apis[api]) { throw new Error('Invalid API \"' + api + '\"'); }\n    \n     this.api        = merge({ 'call': api }, apis[api]);    \n     this.link       = link || {};\n     this.q          = this.link.queue || new Queue();\n     this.deferred   = this.link.deferred || D();\n     this.cookies    = this.link.cookies;\n     this.logger     = Logger.get(api, Logger.OFF); // transaction-level logging\n     this.params     = {};\n     this.inputs     = []; // rinputs list \n     this.outputs    = []; // routput object list\n     this.rstream    = false;\n     this.delayed    = false;\n     this.globalEvts = true; // suppress|raise global events fot this `io`     \n     this.file       = null; \n     this.entities   = null; \n     this.ioFilter   = function() { return true; };\n\n     // preset deployr's assigned response format for `this` api\n     this.data({ format: this.api.format });\n\n     // wrap superagent for the heavy lifting     \n     this.req = \n        request[this.api.method.toLowerCase()](opts.host + '/deployr' + api);\n     this.req.timeout(20 * 60 * 1000); // default timeout --> 20 minutes\n\n     // All CORS deployr calls require sticky sessions\n     if (win && globalOptions.cors) { this.req.withCredentials(); }\n\n     // Node.js - access an SSL endpoint with self signed certs for testing|dev\n     if (!win && globalOptions.allowSelfSignedSSLCert) {\n        process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';        \n     }\n  },\n\n  /**\n   * Binds the scope context for the configured `.end()` and `.error()` event    \n   * handler callbacks on this request.\n   *\n   * @method ctx\n   * @param {Object} context The `this` object for the configured `.end()` and\n   * `.error()` event handlers on this request.\n   * @api public   \n   */ \n  ctx: function (context) {\n    this.scope = context || this;\n\n    return this;\n  },\n\n  /**\n   * Suppress or raise global events for this `io` request.\n   *\n   * @method global\n   * @param {Boolean} raise `true` to raise global events, `false` to supress \n   * event firing globally.\n   * @return {DeployR} for chaining.\n   * @api public\n   */  \n  global: function(raise) {\n    this.globalEvts = Lang.isBoolean(raise) ? raise : this.globalEvts;\n\n    return this;\n  },  \n\n  /**\n   * Retrieve details about user.\n   *   \n   * @method about\n   * @return {Object} details about user otherwies `null`.\n   * @api public   \n   */\n  about: function() {\n    var response = this.req.res;\n\n    return this.api['call'] === '/r/user/login' && response ? \n           response.body.get('user') : null;\n  },  \n\n  /**\n   * Shares the cookies from a diffrent `.io()` agent to preserve session state\n   * across `this` request and all requests chained to it.\n   *\n   * @method share\n   * @return {DeployR} for chaining.\n   * @api public   \n   */  \n  share: function (cookies) {\n    if (globalOptions.sticky) {\n      if (globalOptions.cookies) {\n        this.cookies = globalOptions.cookies.slice(0); \n      } else {\n        if (cookies) { \n          this.cookies = cookies.slice(0); \n          globalOptions.set('cookies', this.cookies);\n        }\n      }\n    } else {\n      this.cookies = (cookies ? cookies.slice(0) : this.cookies);\n    }\n\n    return this;\n  },\n\n  /**\n   * Returns the HTTP cookie previously sent by the server with Set-Cookie.\n   * This value can be passed to `.share(ruser.getCookies())` of a diffrent\n   * `.io()` agent to preserve session state across requests.\n   *\n   * @method getCookies\n   * @return {Array} The HTTP cookie previously sent by the server with \n   * Set-Cookie.\n   * @api public   \n   */  \n  getCookies: function () {\n    return this.cookies;\n  }, \n\n  delay: function (ms) {\n    // TODO: support delayed requests based on ms for now this is just a pause.\n    this.delayed = !isNaN(parseFloat(ms)) && isFinite(ms) ? ms : true;\n\n    return this;\n  },   \n\n  /**\n   * Unwind the queue chain clearing requests that might have delays attached.\n   *\n   * @method drain\n   * @return {Promise} A promise wrapping the resolution of either \"resolve\" or\n   * \"reject\" callback.\n   * @api public   \n   */\n  drain: function () {\n    this.delayed = false;\n    this.q.flush(); \n\n    return this.deferred.promise;\n  },   \n\n  /**\n   * The `.promise()` method returns a dynamically generated Promise that is \n   * resolved once all DeployR `.io()` requests have ended.\n   *   \n   * @method promise\n   * @return {Promise} A promise wrapping the resolution of either \"resolve\" or\n   * \"reject\" callback.\n   * @api public\n   */     \n  promise: function () {\n    this.end();\n\n    return this.deferred.promise;\n  },\n\n  /**\n   * Abort the DeployR request.\n   *\n   * @method abort  \n   * @return {DeployR} for chaining.\n   * @api public\n   */  \n  abort: function () {\n    this.req.abort();\n    this.emit('abort');\n    this.deferred.reject(this._handleError({ \n        status: 'abort',\n        text: 'DeployR request aborted.'\n    }));\n\n    return this;\n  },\n\n /**\n  * Set timeout to `ms`.\n  *\n  * @method timeout  \n  * @param {Number} ms\n  * @return {DeployR} for chaining\n  * @api public\n  */  \n  timeout: function (ms) {\n    this.req.timeout(ms);\n\n    return this;\n  },\n\n /**\n  * Turn logging on for the specific transaction.\n  *\n  * @method log\n  * @return {DeployR} for chaining\n  * @api public\n  */ \n  log: function (level) {\n    this.logger.setLevel(level || Logger.DEBUG);\n\n    return this;\n  },\n\n  /**\n   * Filters successful responses to contain only a top-level DeployR API \n   * response entities:\n   * - 'user'\n   * - 'project'\n   * - 'workspace' \n   * - 'execution' \n   * - 'directory' \n   * - 'repository'\n   * - 'packages' \n   *   \n   * @method entity\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  entity: function (entity) {\n    this.entities = utils.inArray(TOPLEVEL_ENTITIES, entity);\n\n    return this;\n  },\n\n  /**\n   * Defines the request data being sent to a DeployR API. \n   *\n   * @method data\n   * @param {Object} data The object literal configuration hash. \n   * @return {DeployR} for chaining\n   * @api public\n   */\n  data: function (data) {\n    data = data || {};    \n\n    // remove any inlined rinput(s) and attach them to the rinput(s) property\n    if (data.rinput || data.rinputs) {\n      this.rinput(data.rinput);\n      this.rinputs(data.rinputs);\n    } \n\n    // remove any `reserved` values that could have been passed by mistake\n    var BLACKLIST = ['rinput', 'rinputs', '__cookies__'];\n    BLACKLIST.forEach(function(param) { delete data[param]; });  \n\n    this.params = merge(this.params, data);\n\n    return this;\n  },\n\n  /**\n   * Attaches a file to be uploaded. \n   *\n   * @method attach\n   * @param {File|Blob|path} file The file to be attached for an upload. For \n   * Browser environments the HTML5 File|Blob is used. For the Node.js \n   * environment, a file path is accepted.\n   * @param {String} filename (optional) the name of the file to be uploaded. \n   * This name does not have to match the actual source filename.\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  attach: function (file, filename) {\n    if (this.api.upload) {\n      this.file = file;\n\n      // optional filename here for convenience\n      if (filename) { this.data( { filename: filename } ); }\n    }\n\n    return this;\n  },\n\n  /**\n   * Supported only in Node.js, this method works in conjunction with the \n   * attach method to indicate that the file should be read in as a readable \n   * stream during a file upload.\n   *\n   * @method stream\n   * @param {Object} options (optional) the Readable Stream options hash.\n   *  ```\n   *    { flags: 'r',\n   *      encoding: null,\n   *      fd: null,\n   *      mode: 0666,\n   *      autoClose: true\n   *    }\n   * ```\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  stream: function () {\n    this.rstream = (!win && this.api.upload); //nodejs only\n\n    return this;\n  },\n\n  /**\n   * The `filter(λ)` method removes this DeployR request from the request chain\n   * if the provided function does *not* pass the test implemented by it.\n   *\n   * Examples:\n   *\n   * ```\n   * // Remove from the request chain\n   * .filter(function(args) {\n   *    return 5 > 10;\n   * })\n   *\n   * // Keep in the request chain\n   * .filter(function(args) {\n   *    return 10 > 5;\n   * })   \n   * ```\n   *\n   * @method filter\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining\n   * @api public   \n   */\n  filter: function(fn) {\n    if (fn) {\n      this.ioFilter = function(prevArgs) {\n        var args = {}, keep;\n\n        // copy over previous arguments and filter out internal __cookies__ \n        for (var key in prevArgs) {\n           if (key !== '__cookies__') { \n              args[key] = prevArgs[key];\n           }\n        }\n\n        keep = fn(args);\n        return (keep || keep === false ? keep : true);\n      };\n    }\n\n    return this;\n  },  \n  \n  /**\n   * Acts as a finally statement allowing you to execute \"cleanup\" type tasks \n   * in a request chain. It arranges for cleanup to be called, with no \n   * arguments, when the DeployR request chain is either completely fulfilled \n   * or rejected.\n   *\n   * @method ensure\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining\n   * @api public\n   */  \n  ensure: function (fn) {\n    this.deferred.promise.ensure(fn);\n\n    return this.deferred.promise;\n  },\n      \n  /**\n   * The general failure callback. If called, all DeployR errors for this \n   * transaction will be returned here when raised.\n   *\n   * @method error\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  error: function (fn) {\n    this.on('error', fn);\n\n    return this;\n  },\n\n  /**\n   * Stream the DeployR response into the pipe. It is important to note that if \n   * the `.pipe()` method is never called the request will not be sent.\n   *\n   * The `.pipe()` method should be be used as an alternative to `.end()` and \n   * never along side of it. `.pipe()` and `.end()` are an either-or.\n   *\n   * @method pipe\n   * @param {Stream} stream A destination Stream.\n   * @return {Stream} The passed in destination stream to be used for additional \n   * piping.\n   * @api public\n   */\n  pipe: function (dest) {\n    var q   = this.q,\n        api = this.api;        \n\n    q.add(function(responseChain, error, prevArgs) {    \n      // brake the call chain on error      \n      if (error) {        \n        this.deferred.reject(error);      \n        q.flush(responseChain, error, prevArgs); // drain the queue\n        this._clear();\n        return;\n      }\n      \n      this._prepRequest(responseChain, prevArgs);\n\n      Logger.info('pipe()', api, this.req);\n      this.logger.info('pipe()', api, this.req);   \n\n      var stream = this.req.pipe(dest);\n      q.yield(true);\n      stream.on('error', function () { });    \n      stream.on('end', function() { });     \n      stream.on('data', function() { });      \n    }, this);\n  \n    if (q.size() <= 1) { q.flush(); }\n\n    return dest;\n  },\n\n  /**\n   * Indicates that the request is ready to be sent to DeployR. It is important \n   * to note that if the `.end()` method is never called the request will not be\n   * sent.\n   *\n   * @method end\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining.\n   * @api public\n   */ \n  end: function (fn) {\n    var self     = this,\n        q        = this.q,\n        api      = this.api,\n        args     = null,\n        entities =  this.entities;\n\n    q.add(function(responseChain, error, prevArgs) {\n      // break the call chain on error      \n      if (error) {        \n        this.deferred.reject(error);        \n        q.flush(responseChain, error, prevArgs); // drain the queue\n        this._clear();\n        return;\n      }\n\n      //\n      if (!this.ioFilter(prevArgs)) {\n        if (q.size() === 0) { \n          this.deferred.resolve(responseChain || prevArgs);\n        }\n\n        q.flush(responseChain, error, prevArgs); // drain the queue\n        this._clear();\n        return;\n      }\n      \n      this._prepRequest(responseChain, prevArgs);\n\n      Logger.info('io()', api, this.req);\n      this.logger.info('io()', api, this.req);    \n\n      // send next request\n      this.req.end(function(res) {\n        self.share(self.cookies || res.headers['set-cookie']);         \n\n        // -- log cookies across requests --\n        if (self.cookies) {\n          Logger.info('cookies', api, self.cookies); \n          self.logger.info('cookies', api, self.cookies); \n        }\n\n        error = self._handleError(res);\n        var dres = (res.body && res.body.deployr ? res.body : res);             \n      \n        self.inputs = [];\n        self.outputs = [];\n\n        if (!error) {\n           // -- Log global + transaction log --\n           Logger.info('end()', api, dres, res);\n           self.logger.info('end()', api, dres, res);\n\n           // -- walk response for top-level entity response assignment --        \n           if (entities) { dres = dres.deployr.response[entities] || dres; }\n\n           dres.get = function(key) { \n              return utils.get(dres.deployr.response, key); \n           };\n\n           dres.workspace = function(name) { \n              return utils.workspace(dres.deployr.response, name); \n           };\n\n           // -- callback --\n           if (fn) { args = fn.apply(self.scope, [dres, responseChain]);}\n\n           // -- notify that the queue has been drained... --\n           if (q.size() === 0) { \n             self._clear();\n             self.deferred.resolve(responseChain || dres);\n           }          \n\n           // -- include cookies in next request in the queue --\n           args = merge(args, { __cookies__: self.cookies });          \n        }        \n\n        q.yield(false);\n        q.flush(dres, error, args); // pass result|error|args to next \n      });\n\n      q.yield(true);\n    }, this, this.delayed);\n  \n    if (!this.delayed && q.size() <= 1) { q.flush(); }\n\n    return this;\n  }, \n\n  /** \n   * Add an additional IO request to the exsisting sequential request chain.\n   *\n   * @method io\n   * @param {String} api One of the supported DeployR APIs.\n   * @return {DeployR} for chaining.\n   * @api public\n   */   \n  io: function (api) {    \n    return DeployR.new(api, { \n      cookies: this.cookies, \n      queue: this.q, \n      deferred: this.deferred\n    });\n  },\n\n  /** \n   * Convenience function for adding an additional script execution to the \n   * exsisting sequential request chain.\n   *\n   * @method script\n   * @param {Arguments} Arguments to define the fully qualified script for \n   * execution.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  script: function() {\n     var args = utils.signature(arguments),\n         opts = args.opts,\n         api  = args.api,\n         link = { \n          cookies: this.cookies, \n          queue: this.q, \n          deferred: this.deferred\n        };  \n\n    // convenience - if the project is a boolen `true` rather than a pid, first\n    // create a new project and then prepare the project api call to execute\n    if (args.create) {\n      return DeployR.new('/r/project/create', link)\n               .end(function(res) {\n                  return { project: res.get('project').project };\n                })\n               .io(api)\n               .data(opts);\n    } else {\n      return DeployR.new(api, link).data(opts);\n    }    \n  },\n\n  /** \n   * Convenience function for adding an additional repository-managed shell \n   * script execution to the exsisting sequential request chain.\n   *\n   * This call executes repository-managed shell scripts .sh, .csh, .bash, .bat \n   * on the DeployR server. Due to the special security concerns associated with \n   * excuting shell scripts on the DeployR server, only shell scripts owned by \n   * _ADMINISTRATOR_ users can be executed on this API call. Any attempt to \n   * execute a shell script stored in the repository that is not owned by an \n   * _ADMINISTRATOR_ user will be rejected.\n   *\n   * To execute a repository-managed shell script the caller must provide \n   * parameter values for _author_, _directory_, _filename_. This can be\n   * achieved by providing a fully qualified shell script \n   * `/<author>/<directory>/<filename>`, for example:\n   *\n   *  ```\n   *  .shell('/admin/external:public:admin/echo.sh', 'echo.sh args to pass.')\n   *  ```\n   *\n   * @method shell\n   * @param {String} filepath to define the fully qualified shell script for\n   * execution. \n   * @param {String} args (optional) arguments to be passed into the shell \n   * script on execution.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  shell: function(path, args) {   \n    var link = { \n          cookies: this.cookies, \n          queue: this.q, \n          deferred: this.deferred\n        },\n        tokens = Lang.isString(path) ? path.split('\\/') : [];\n\n    // handle both: `/author/directory/filename` & `author/directory/filename`\n    if (tokens.length > 3) { tokens = tokens.slice(1); }\n\n    return DeployR.new('/r/repository/shell/execute', link).data({\n      author: tokens[0],\n      directory: tokens[1],\n      filename: tokens[2],\n      args: args\n    });\n  },\n\n  /** \n   * Convenience function for executing a block of R code on the R session.\n\n   * Example:\n   *  ```\n   *  .code('x<-5')\n   *  // -- or --\n   *  .code('x<-5', projectId)\n   *  ```\n   *   \n   * @method code\n   * @param {String} r - The block of R code to execute.\n   * @param {String} project - (optional) if omitted a new project will first be \n   * created and used, otherwise it will execute on the R session identified by \n   * this `project`.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  code: function(r, project) {\n     var link = {\n             cookies: this.cookies,\n             queue: this.q,\n             deferred: this.deferred\n         },\n         api = '/r/project/execute/code';\n\n     if (!project) {\n         return DeployR.new('/r/project/create', link)\n             .end(function(res) {\n                 return { project: res.get('project').project };\n             })\n             .io(api)\n             .data({ code: r });\n     } else {\n         return DeployR.new(api, link).data({ code: r, project: project });\n     }\n  },\n  \n  /** \n   * Release any residual project resources associated with the application \n   * instance whenever a client application terminates. This includes closing \n   * any supplied projects down and logging out.\n   *\n   * @method release\n   * @param {String|Array} projects The project or list of projects to close.\n   * @param {Boolean} auth (optional) to remain authenticated.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  release: function(projects, auth) {\n     projects = Lang.isArray(projects) ? projects : [projects];\n\n     var self     = this,\n         deferred = D(),\n         empty    = !projects || !projects[0],\n         count    = 0,\n         last     = !empty ? projects.length - 1 : count,\n         cookies  = this.getCookies();           \n\n    function logout(index) {\n      if (index === last) {\n        if (!auth) {\n          DeployR.new('/r/user/logout')\n          .share(cookies)\n          .error(function() {          \n            deferred.reject(false);\n          })      \n          .end(function() { \n            deferred.resolve(true);\n          })\n          .ensure(function() {\n            self.destroy();\n          });\n        } else {\n          deferred.resolve(true);\n          self.destroy();\n        }\n      } \n    }\n\n    if (!empty) {\n      projects.forEach(function(project) {\n        DeployR.new('/r/project/close')\n        .data({ project: project })\n        .share(cookies)\n        .end()\n        .ensure(function() {\n          logout(count);\n          count++;\n        });\n      });   \n    } else {\n      logout(count);\n    }\n\n    return deferred.promise;  \n  },  \n\n  /** \n   * A convenience alternative to multiple `.rinput()` calls. Defines a name \n   * list of R objects that will be returned as DeployR-encoded R objects on the \n   * response markup.\n   *\n   * Calling this method ~.routputs([ ... ])` is equivalent to invoking multiple \n   * `.routput(...)` calls.\n   *\n   * @method routputs\n   * @param {Array} robjects A name list of R objects that will be returned.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  routputs: function (routputs) {\n    if (routputs) { this.outputs = this.outputs.concat(routputs); }\n\n    return this;\n  },\n  \n  /** \n   * Defines the name of the R object that will be returned as a DeployR-encoded \n   * R object on the response markup.\n   *\n   * @method routput\n   * @param {String} robject The name of the R object that will be returned.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  routput: function (routput) {\n    if (routput) { this.routputs([routput]); }\n\n    return this;\n  },\n\n  /** \n   * Used to pass multiple inputs at once from JavaScript to an R script using \n   * one of the defined `RInput` factories.\n   *\n   * @method rinputs\n   * @param {Array} rinputs The `RInput` list of DeployR-specific encoded R \n   * object data for use on an API call.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  rinputs: function (rinputs) {\n    if (rinputs) { this.inputs = this.inputs.concat(rinputs); }\n\n    return this;\n  },\n\n  /** \n   * Used to pass multiple inputs at once from JavaScript to an R script using \n   * one of the defined `RInput` factories.\n   *\n   * @method rinput\n   * @param {RInput} rinput The DeployR-specific encoded R object data for use \n   * on an API call.   \n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  rinput: function (rinput) {\n    if (rinput) { this.inputs.push(rinput); }\n\n    return this;\n  },\n\n  /**\n   * Destroy lifecycle method. Fires the `destroy` event, prior to invoking \n   * destructors for the class hierarchy. Called internally when `.release()`\n   * is called.\n   *\n   * @method destroy\n   * @api public   \n   */\n  destroy: function () {\n    try {\n      this.emit('destroy');\n      this.offAll();\n    \n      for (var key in this) {\n        if (this.hasOwnProperty(key)) { \n          this[key] = null; \n          delete this[key];\n        }\n      }\n    } catch(err) {}\n  },  \n\n  // --------------------------------------------------------------------------\n  // Private methods\n  // --------------------------------------------------------------------------\n\n  /**\n   * @api private\n   */\n  _clear: function() {    \n    this.params   = {};\n    this.inputs   = [];\n    this.outputs  = [];\n    this.rstream  = false;\n    this.delayed  = false;\n    this.api      = null;    \n    this.file     = null;  \n    this.entities = null;\n    this.ioFilter = null;\n  }, \n\n  /**\n   * @api private\n   */\n  _prepRequest: function (responseChain, args) {\n    var req  = this.req,\n        file = this.file;\n\n    // set the request type    \n    if (this.api.upload) {\n       // If the env is the Browser there is no need to manually set the\n       // Content-Type. The browser will automatically set the \n       // \"multipart/form-data; boundary=...\" value. If the env is Node we need\n       // to set it manually.\n       if (!win) { this.req.type('multipart/form-data'); }    \n    } else {\n      req.type('form');\n    }    \n\n    req.on('error', function(err) { \n      err = err || {  code: 'UNKNOWN CODE', text: 'UNKNOWN ERROR' };\n\n      this._handleError({ \n        status: err.code || 'UNKNOWN CODE',\n        text: err\n      });\n    }.bind(this));    \n\n    this.share(args ? args.__cookies__ : null);\n\n    // arguments returned from prev request's io().end(function() { return x; })\n    if (args) { \n       this.data(args);\n    } \n\n    if (this.inputs.length > 0) { \n      this.data({ inputs: encoder.encode(this.inputs) }); \n    }\n  \n    if (this.outputs.length > 0) { \n      this.data({ robjects: this.outputs.join() }); \n    }    \n\n    if (this.cookies) {     \n      this.cookies.forEach( function(c) { req.set('Cookie', c); });\n    }\n\n    if (this.api.upload) {    \n      for(var p in this.params) {\n        req.field(p, (this.params[p] || this.params[p] === false) ? \n           this.params[p] + '' : '');\n      } \n      req.attach('file', this.rstream ? fs.createReadStream(file) : file);\n    } else {\n      req[this.api.method === 'GET' ? 'query' : 'send'](this.params);\n    } \n  },\n\n  /**\n   * @api private\n   */\n  _handleError: function (raw) {\n    var stat  = raw.status,\n        res   = (raw.body && raw.body.deployr ? raw.body : raw),\n        error = ((stat !== 200) || res.deployr && !res.deployr.response.success);\n\n    // -- Handle errors --\n    if (error) {\n      res = {\n        get: function(key) { \n          return utils.get(this.deployr.response, key); \n        },\n        deployr: {          \n          response: {\n            success: false,\n            call: this.api['call'],\n            errorCode: res.deployr ? res.deployr.response.errorCode : stat,\n            error: res.deployr ? res.deployr.response.error : res.text\n          }\n        }\n      };\n\n      Logger.error('error()', this.api, res, raw);\n      this.logger.error('error()', this.api, res, raw);\n\n      // -- notify global errors first (if any) for this call --      \n      if (this.globalEvts) {\n        raiseGlobalErrors(this.api['call'], res);        \n      }\n\n      // -- tranaction level HTTP or DeployR errors come next --    \n      this.emit('error', res);\n      this.emit('deployr-io:' + res.deployr.response.errorCode, res);\n      this.deferred.reject(res);\n    }\n\n    return error;\n  }\n});\n\n/*****************************************************************************/\n/*****************************************************************************/\n/*****************************************************************************/\n\n// Include the `deprecated` jsDeployR for now.\nif (win) {\n  window.Revolution = window.Revolution || require('./lib/deprecated');\n}\n\n/*****************************************************************************/\n/*****************************************************************************/\n/*****************************************************************************/\n\n/**\n * Expose for a cleaner client api into DeployR\n */\nmodule.exports = {\n\n  /**\n   * Exposes the `DeployR` object for extending.\n   *\n   * ```var DeployR = require('deployr').DeployR;```\n   *\n   * @static\n   * @api public\n   * @return {DeployR} The `DeployR` object.\n   */   \n  DeployR: DeployR,\n\n  /**\n   * Exposes the supported DeployR APIs.\n   *\n   * @method apis\n   * @param {Boolean} flat (optional) if `true` will return an array of just the \n   * API's endpoint properties, for example: \n   * ```\n   * ['/r/user/login', '/r/user/logout', '/r/user/about', ...]\n   * ```\n   * @static\n   * @api public\n   * @return {Object|Array} The HTTP request to the DeployR server.      \n   */  \n  apis: function(flat) {\n    return flat ? Object.keys(apis) : apis;\n  },\n\n  /**\n   * Represents a static method for configuring all DeployR requests. Settings \n   * made here are applied globally across every request.\n   *\n   * @method configure\n   * @param {Object} options The object literal configuration hash. \n   * @static\n   * @chainable\n   * @api public\n   */\n  configure: function(options) {\n    options = options || {};\n\n    for (var i in options) { globalOptions.set(i, options[i]); }\n\n    // assert global cookies are empty if global `sticky` jsessionid is off\n    if (!globalOptions.sticky)  { globalOptions.set('cookies', null); }\n\n    // turn global logging on|off (off by default)\n    Logger.setLevel(globalOptions.logging ? Logger.DEBUG : Logger.OFF);\n\n    return this;\n  },\n\n  /**\n   * Factory for creating new IO requests to `DeployR`.\n   *\n   * Example:\n   * ```   \n   *    deployr.io('/r/user/about').end(callback);\n   * ```\n   *\n   * @method io\n   * @param {String} api One of the supported DeployR APIs.\n   * @static\n   * @return {DeployR} The HTTP request to the DeployR server.\n   * @api public   \n   */\n  io: function(api) {  \n    return DeployR.new(api);\n  },\n\n  /**\n   * Convenience function to sign the user in by authenticating the credentials \n   * with the DeployR server.   \n   *\n   * @method auth\n   * @param {String} username Specifies the username.\n   * @param {String} password Specifies the password.\n   * @static\n   * @return {DeployR} The HTTP request to the DeployR server.   \n   * @api public   \n   */   \n  auth: function(un, pw) {\n    var data = { username: un, password: pw };\n    return DeployR.new('/r/user/login').data(data).end();    \n  },\n\n  /**\n   * Convenience function to sign the user in by authenticating the credentials \n   * with the DeployR server.   \n   *\n   * Example:\n   * ```\n   *    deployr.script('/testuser/root/reduce.R')\n   *    deployr.script({ filename: 'reduce.R', author: 'testuser',\n   *                     directory: 'root'})\n   *    deployr.script('reduce.R', 'testuser', 'root')\n   *    deployr.script('/testuser/root/reduce.R', project)     \n   * ```   \n   *\n   * @method script\n   * @param {Arguments} arguments Arguments to define the fully qualified script \n   * for execution.\n   * @static\n   * @return {DeployR} The HTTP request to the DeployR server.   \n   * @api public   \n   */     \n  script: function() {\n    var args = utils.signature(arguments),\n        opts = args.opts,\n        api  = args.api;  \n\n    // convenience - if the project is a boolen `true` rather than a pid, first\n    // create a new project and then prepare the project api call to execute\n    if (args.create) {\n      return DeployR.new('/r/project/create')\n               .end(function(res) {\n                  return { project: res.get('project').project };\n                })\n               .io(api)\n               .data(opts);\n    } else {\n      return DeployR.new(api).data(opts);\n    }\n  },  \n\n  /**\n   * Run an series of chained DeployR requests in sequence and without overlap.       \n   *\n   * @method pipline\n   * @param {Array} tasks Specifies the list of `Function` tasks.\n   * @static\n   * @return {Promise} A promise wrapping the resolution of either \"resolve\" or\n   * \"reject\" callback.\n   * @api public   \n   */\n  pipeline: function(chains) {      \n    var deployr  = this,\n        deferred = D(),\n        q        = new Queue(),\n        results  = [],\n        errors   = [],\n        NOOP     = null, // NOOP errors|results for [a] batch request chain\n        orig     = {\n          sticky: globalOptions.sticky,\n          cookies: globalOptions.cookies\n        };\n\n    // make a copy\n    chains = chains.slice(0);\n\n    // turn sticky session for these request (hacky)\n    deployr.configure( { sticky: true });\n\n    function add() {\n      q.add(function() { \n        chains.shift().drain()\n        .then(function(chain) {\n          results.push(chain);  \n          errors.push(NOOP);           \n          if (q.isEmpty()) { \n            deployr.configure(orig); // reset\n            deferred.resolve({ results: results, errors: errors }); \n          }  \n\n          q.take();\n        }, function(err) {          \n          results.push(NOOP); \n          errors.push(err);\n          // rejections are only met when they [all] fail\n          if (q.isEmpty() && results.length === 0) { \n            deployr.configure(orig); // reset\n            deferred.reject(errors); \n          }  \n          q.take();\n        });       \n      }, null, true);\n    }\n\n    // convert to a seq queue for better handling\n    for(var i = 0; i < chains.length; i++) { add(); }\n\n    // start: dequeue first item and run it\n    q.take();\n\n    return deferred.promise;\n  },\n\n  /**\n   * The event stream API is unique within the DeployR API as it supports push \n   * notifications from the DeployR server to client applications. Notifications \n   * correspond to discrete events that occur within the DeployR server. There \n   * are four distinct event categories:\n   * \n   * - Stream Lifecycle events\n   * - Execution events\n   * - Job Lifecycle events\n   * - Management events\n   *\n   * Example:\n   * ```\n   * deployr.es({ username: 'testuser', password: 'secret' })\n   *    // -- connection choices for event types --\n   *    .management()  //.session() | .all() | .project(id) | .job(id)\n   *    .on('es:gridHeartbeat', function(data) {\n   *        console.log('===================');\n   *        console.log('es:gridHeartbeat');\n   *        console.log('===================');          \n   *     })\n   *     .open();\n   * ```\n   * \n   * @method es\n   * @param {Object} options The object literal configuration hash. \n   * @static\n   * @return {EventStream} a new `EventStream` for binding.\n   * @api public   \n   */  \n  es: function(options) {    \n    var stream = EventStream.new(globalOptions.host, options);\n\n    if (options && options.username && options.password) {\n      var ruser = this.auth(options.username, options.password);\n      ruser.ensure(function() { \n        stream.share(ruser.getCookies());\n        stream.flush(); \n      });\n    }\n\n    return stream;\n  },\n\n  /**\n   * Defines the factory for creating a DeployR-specific encoded R object to be \n   * sent as input parameters to an R script.\n   *\n   * Example:\n   * ```\n   *    var rinput = deployr.RInput.logical('logical_name', true);\n   *    var rinput = deployr.RInput.numeric('numeric_name', 10.5);\n   *    var rinput = deployr.RInput.integer('integer_name', 5);\n   *    var rinput = deployr.RInput.character('character_name', 'Hello');\n   *    // ect...\n   * ```\n   * @property RInput\n   * @static\n   * @api public\n   */\n  RInput: {\n    numeric: function (name, value) {\n      return RInput.new(name, value).numeric();\n    },\n\n    integer: function (name, value) {\n      return RInput.new(name, value).integer();\n    },\n\n    logical: function (name, value) {\n      return RInput.new(name, value).logical();\n    },\n\n    character: function (name, value) {\n      return RInput.new(name, value).character();\n    },\n\n    date: function (name, value) {\n      return RInput.new(name, value).date();\n    },\n\n    posixct: function (name, value) {\n      return RInput.new(name, value).posixct();\n    },  \n\n    numericVector: function(name, value) {\n      return RInput.new(name, value).numericVector();\n    }, \n\n    integerVector: function (name, value) {\n      return RInput.new(name, value).integerVector();\n    },\n\n    logicalVector: function (name, value) { \n      return RInput.new(name, value).logicalVector();\n    },\n\n    characterVector: function (name, value) { \n      return RInput.new(name, value).characterVector();\n    },  \n\n    dateVector: function (name, value) { \n      return RInput.new(name, value).dateVector();\n    },  \n\n    posixctVector: function (name, value) { \n      return RInput.new(name, value).posixctVector();\n    },\n\n    list: function (name, value) {\n      return RInput.new(name, value).list(); \n    },\n\n    dataframe: function (name, value) { \n      return RInput.new(name, value).dataframe();\n    },\n  \n    factor: function (name, value, levels, labels) {\n      var opts = { levels: levels, labels: labels };\n      return RInput.new(name, value, opts).factor();\n    },\n\n    ordered: function (name, value, levels, labels) {\n      var opts = { levels: levels, labels: labels };\n      return RInput.new(name, value, opts).ordered();\n    },\n\n    numericMatrix: function (name, value) { \n      return RInput.new(name, value).numericMatrix();\n    },\n\n    integerMatrix: function (name, value) { \n      return RInput.new(name, value).integerMatrix();\n    },\n\n    logicalMatrix: function (name, value) { \n      return RInput.new(name, value).logicalMatrix();\n    },\n\n    characterMatrix: function (name, value) {\n      return RInput.new(name, value).characterMatrix();\n    }\n  }\n};\n}).call(this,require('_process'))\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["deployr.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["/*!\n * Copyright (C) 2010-2015 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nvar win         = (typeof window !== 'undefined'),   \n    request     = require('superagent'),\n    D           = require('d.js'),\n    fs          = require('fs'),\n    apis        = require('./apis.json'), \n    EventStream = require('./lib/es'),\n    utils       = require('./lib/utils'),\n    Lang        = require('./lib/lang'),   \n    Logger      = require('./lib/logger'),   \n    Queue       = require('./lib/queue'),\n    Emitter     = require('./lib/emitter'),\n    encoder     = require('./lib/encoder'),\n    Base        = require('./lib/selfish').Base,\n    RInput      = require('./lib/rinput'),    \n    RInputs     = require('./lib/rinputs'),\n    merge       = utils.merge;\n\n/*\n * Turn global logging off by default\n */\nLogger.setLevel(Logger.OFF);\n\n/*\n * Global options that persist through all DeployR requests.\n */\nvar globalOptions = { \n  cors: false,\n  logging: false,\n  sticky: false,\n  cookies: null,\n  host: '',\n  allowSelfSignedSSLCert: false,\n  maxRequests: null, // no socket pooling in http.Agent\n  events:{},\n  set: function(prop, value) { \n    if (prop !== 'set') { \n      if (prop === 'host' && value) {         \n         // Be more forgiving on the entered DeployR 'endpoint':\n         //   - http(s)://dhost:port\n         //   - http(s)://dhost:port/deployr\n         //   - dhost:port\n         //   - dhost:port/deployr         \n         value = value.replace(/\\/*$|\\/*deployr\\/*$/, '');\n         value = (new RegExp('^(http|https)://', 'i')).test(value) ? value : \n            'http://' + value;\n      }\n\n      this[prop] = value; \n    } \n  }\n};\n\n/*\n * The top-level DeployR API response entities.\n */\nvar TOPLEVEL_ENTITIES = [\n  'user', \n  'project', \n  'workspace', \n  'execution', \n  'directory', \n  'repository', \n  'packages' \n];\n\n/*\n * Notify global IO error events accessible by all subscribers across requests.\n */\nfunction raiseGlobalErrors(api, res) {\n  var code    = res.deployr ? res.deployr.response.errorCode : res.status,\n      context = this;\n\n  // -- global events if provided --\n  if (globalOptions.events) {\n    if (!res.deployr) {\n      res = res.text;\n    }\n\n    context = globalOptions.events.ctx || context;\n\n    // -- general global failure --\n    if (globalOptions.events.error) {\n      globalOptions.events.error.apply(context, [api, res]);\n    }\n\n    // -- HTTP or DeployR global errors --    \n    if (globalOptions.events[code]) {\n      globalOptions.events[code].apply(context, [api, res]);\n    }\n  }\n}\n\n/**\n * The `DeployR` request class is a utility that brokers HTTP requests through a \n * simplified fluid interface to DeployR.\n *\n * @module deployr\n * @for deployr\n */\nvar DeployR = Base.extend(Emitter, RInputs, {\n\n  /**\n   * The `DeployR` Request class is a utility that brokers HTTP requests through \n   * a simplified fluid interface to DeployR.\n   * \n   * @class \n   * @constructor\n   * @param {String} api The DeployR API\n   * @param {Object} link The object literal containing the previous request.\n   * @api private\n   */\n  initialize: function initialize(api, link) {\n     Emitter.initialize.call(this, {});\n  \n     var opts = globalOptions;\n\n     if (!apis[api]) { throw new Error('Invalid API \"' + api + '\"'); }\n    \n     this.api        = merge({ 'call': api }, apis[api]);    \n     this.link       = link || {};\n     this.q          = this.link.queue || new Queue();\n     this.deferred   = this.link.deferred || D();\n     this.cookies    = this.link.cookies;\n     this.logger     = Logger.get(api, Logger.OFF); // transaction-level logging\n     this.params     = {};\n     this.inputs     = []; // rinputs list \n     this.outputs    = []; // routput object list\n     this.rstream    = false;\n     this.delayed    = false;\n     this.globalEvts = true; // suppress|raise global events fot this `io`     \n     this.file       = null; \n     this.entities   = null; \n     this.ioFilter   = function() { return true; };\n\n     // preset deployr's assigned response format for `this` api\n     this.data({ format: this.api.format });\n\n     // wrap superagent for the heavy lifting     \n     this.req = \n        request[this.api.method.toLowerCase()](opts.host + '/deployr' + api);\n     this.req.timeout(20 * 60 * 1000); // default timeout --> 20 minutes\n\n     // All CORS deployr calls require sticky sessions\n     if (win && globalOptions.cors) { this.req.withCredentials(); }\n\n     // Node.js - access an SSL endpoint with self signed certs for testing|dev\n     if (!win && globalOptions.allowSelfSignedSSLCert) {\n        process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';        \n     }\n  },\n\n  /**\n   * Binds the scope context for the configured `.end()` and `.error()` event    \n   * handler callbacks on this request.\n   *\n   * @method ctx\n   * @param {Object} context The `this` object for the configured `.end()` and\n   * `.error()` event handlers on this request.\n   * @api public   \n   */ \n  ctx: function (context) {\n    this.scope = context || this;\n\n    return this;\n  },\n\n  /**\n   * Suppress or raise global events for this `io` request.\n   *\n   * @method global\n   * @param {Boolean} raise `true` to raise global events, `false` to supress \n   * event firing globally.\n   * @return {DeployR} for chaining.\n   * @api public\n   */  \n  global: function(raise) {\n    this.globalEvts = Lang.isBoolean(raise) ? raise : this.globalEvts;\n\n    return this;\n  },  \n\n  /**\n   * Retrieve details about user.\n   *   \n   * @method about\n   * @return {Object} details about user otherwies `null`.\n   * @api public   \n   */\n  about: function() {\n    var response = this.req.res;\n\n    return this.api['call'] === '/r/user/login' && response ? \n           response.body.get('user') : null;\n  },  \n\n  /**\n   * Shares the cookies from a diffrent `.io()` agent to preserve session state\n   * across `this` request and all requests chained to it.\n   *\n   * @method share\n   * @return {DeployR} for chaining.\n   * @api public   \n   */  \n  share: function (cookies) {\n    if (globalOptions.sticky) {\n      if (globalOptions.cookies) {\n        this.cookies = globalOptions.cookies.slice(0); \n      } else {\n        if (cookies) { \n          this.cookies = cookies.slice(0); \n          globalOptions.set('cookies', this.cookies);\n        }\n      }\n    } else {\n      this.cookies = (cookies ? cookies.slice(0) : this.cookies);\n    }\n\n    return this;\n  },\n\n  /**\n   * Returns the HTTP cookie previously sent by the server with Set-Cookie.\n   * This value can be passed to `.share(ruser.getCookies())` of a diffrent\n   * `.io()` agent to preserve session state across requests.\n   *\n   * @method getCookies\n   * @return {Array} The HTTP cookie previously sent by the server with \n   * Set-Cookie.\n   * @api public   \n   */  \n  getCookies: function () {\n    return this.cookies;\n  }, \n\n  delay: function (ms) {\n    // TODO: support delayed requests based on ms for now this is just a pause.\n    this.delayed = !isNaN(parseFloat(ms)) && isFinite(ms) ? ms : true;\n\n    return this;\n  },   \n\n  /**\n   * Unwind the queue chain clearing requests that might have delays attached.\n   *\n   * @method drain\n   * @return {Promise} A promise wrapping the resolution of either \"resolve\" or\n   * \"reject\" callback.\n   * @api public   \n   */\n  drain: function () {\n    this.delayed = false;\n    this.q.flush(); \n\n    return this.deferred.promise;\n  },   \n\n  /**\n   * The `.promise()` method returns a dynamically generated Promise that is \n   * resolved once all DeployR `.io()` requests have ended.\n   *   \n   * @method promise\n   * @return {Promise} A promise wrapping the resolution of either \"resolve\" or\n   * \"reject\" callback.\n   * @api public\n   */     \n  promise: function () {\n    this.end();\n\n    return this.deferred.promise;\n  },\n\n  /**\n   * Abort the DeployR request.\n   *\n   * @method abort  \n   * @return {DeployR} for chaining.\n   * @api public\n   */  \n  abort: function () {\n    this.req.abort();\n    this.emit('abort');\n    this.deferred.reject(this._handleError({ \n        status: 'abort',\n        text: 'DeployR request aborted.'\n    }));\n\n    return this;\n  },\n\n /**\n  * Set timeout to `ms`.\n  *\n  * @method timeout  \n  * @param {Number} ms\n  * @return {DeployR} for chaining\n  * @api public\n  */  \n  timeout: function (ms) {\n    this.req.timeout(ms);\n\n    return this;\n  },\n\n /**\n  * Turn logging on for the specific transaction.\n  *\n  * @method log\n  * @return {DeployR} for chaining\n  * @api public\n  */ \n  log: function (level) {\n    this.logger.setLevel(level || Logger.DEBUG);\n\n    return this;\n  },\n\n  /**\n   * Filters successful responses to contain only a top-level DeployR API \n   * response entities:\n   * - 'user'\n   * - 'project'\n   * - 'workspace' \n   * - 'execution' \n   * - 'directory' \n   * - 'repository'\n   * - 'packages' \n   *   \n   * @method entity\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  entity: function (entity) {\n    this.entities = utils.inArray(TOPLEVEL_ENTITIES, entity);\n\n    return this;\n  },\n\n  /**\n   * Defines the request data being sent to a DeployR API. \n   *\n   * @method data\n   * @param {Object} data The object literal configuration hash. \n   * @return {DeployR} for chaining\n   * @api public\n   */\n  data: function (data) {\n    data = data || {};    \n\n    // remove any inlined rinput(s) and attach them to the rinput(s) property\n    if (data.rinput || data.rinputs) {\n      this.rinput(data.rinput);\n      this.rinputs(data.rinputs);\n    } \n\n    // remove any `reserved` values that could have been passed by mistake\n    var BLACKLIST = ['rinput', 'rinputs', '__cookies__'];\n    BLACKLIST.forEach(function(param) { delete data[param]; });  \n\n    this.params = merge(this.params, data);\n\n    return this;\n  },\n\n  /**\n   * Attaches a file to be uploaded. \n   *\n   * @method attach\n   * @param {File|Blob|path} file The file to be attached for an upload. For \n   * Browser environments the HTML5 File|Blob is used. For the Node.js \n   * environment, a file path is accepted.\n   * @param {String} filename (optional) the name of the file to be uploaded. \n   * This name does not have to match the actual source filename.\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  attach: function (file, filename) {\n    if (this.api.upload) {\n      this.file = file;\n\n      // optional filename here for convenience\n      if (filename) { this.data( { filename: filename } ); }\n    }\n\n    return this;\n  },\n\n  /**\n   * Supported only in Node.js, this method works in conjunction with the \n   * attach method to indicate that the file should be read in as a readable \n   * stream during a file upload.\n   *\n   * @method stream\n   * @param {Object} options (optional) the Readable Stream options hash.\n   *  ```\n   *    { flags: 'r',\n   *      encoding: null,\n   *      fd: null,\n   *      mode: 0666,\n   *      autoClose: true\n   *    }\n   * ```\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  stream: function () {\n    this.rstream = (!win && this.api.upload); //nodejs only\n\n    return this;\n  },\n\n  /**\n   * The `filter(λ)` method removes this DeployR request from the request chain\n   * if the provided function does *not* pass the test implemented by it.\n   *\n   * Examples:\n   *\n   * ```\n   * // Remove from the request chain\n   * .filter(function(args) {\n   *    return 5 > 10;\n   * })\n   *\n   * // Keep in the request chain\n   * .filter(function(args) {\n   *    return 10 > 5;\n   * })   \n   * ```\n   *\n   * @method filter\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining\n   * @api public   \n   */\n  filter: function(fn) {\n    if (fn) {\n      this.ioFilter = function(prevArgs) {\n        var args = {}, keep;\n\n        // copy over previous arguments and filter out internal __cookies__ \n        for (var key in prevArgs) {\n           if (key !== '__cookies__') { \n              args[key] = prevArgs[key];\n           }\n        }\n\n        keep = fn(args);\n        return (keep || keep === false ? keep : true);\n      };\n    }\n\n    return this;\n  },  \n  \n  /**\n   * Acts as a finally statement allowing you to execute \"cleanup\" type tasks \n   * in a request chain. It arranges for cleanup to be called, with no \n   * arguments, when the DeployR request chain is either completely fulfilled \n   * or rejected.\n   *\n   * @method ensure\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining\n   * @api public\n   */  \n  ensure: function (fn) {\n    this.deferred.promise.ensure(fn);\n\n    return this.deferred.promise;\n  },\n      \n  /**\n   * The general failure callback. If called, all DeployR errors for this \n   * transaction will be returned here when raised.\n   *\n   * @method error\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining\n   * @api public\n   */\n  error: function (fn) {\n    this.on('error', fn);\n\n    return this;\n  },\n\n  /**\n   * Stream the DeployR response into the pipe. It is important to note that if \n   * the `.pipe()` method is never called the request will not be sent.\n   *\n   * The `.pipe()` method should be be used as an alternative to `.end()` and \n   * never along side of it. `.pipe()` and `.end()` are an either-or.\n   *\n   * @method pipe\n   * @param {Stream} stream A destination Stream.\n   * @return {Stream} The passed in destination stream to be used for additional \n   * piping.\n   * @api public\n   */\n  pipe: function (dest) {\n    var q   = this.q,\n        api = this.api;        \n\n    q.add(function(responseChain, error, prevArgs) {    \n      // brake the call chain on error      \n      if (error) {        \n        this.deferred.reject(error);      \n        q.flush(responseChain, error, prevArgs); // drain the queue\n        this._clear();\n        return;\n      }\n      \n      this._prepRequest(responseChain, prevArgs);\n\n      Logger.info('pipe()', api, this.req);\n      this.logger.info('pipe()', api, this.req);   \n\n      var stream = this.req.pipe(dest);\n      q.yield(true);\n      stream.on('error', function () { });    \n      stream.on('end', function() { });     \n      stream.on('data', function() { });      \n    }, this);\n  \n    if (q.size() <= 1) { q.flush(); }\n\n    return dest;\n  },\n\n  /**\n   * Indicates that the request is ready to be sent to DeployR. It is important \n   * to note that if the `.end()` method is never called the request will not be\n   * sent.\n   *\n   * @method end\n   * @param {Function} λ the callback function.\n   * @return {DeployR} for chaining.\n   * @api public\n   */ \n  end: function (fn) {\n    var self     = this,\n        q        = this.q,\n        api      = this.api,\n        args     = null,\n        entities =  this.entities;\n\n    q.add(function(responseChain, error, prevArgs) {\n      // break the call chain on error      \n      if (error) {        \n        this.deferred.reject(error);        \n        q.flush(responseChain, error, prevArgs); // drain the queue\n        this._clear();\n        return;\n      }\n\n      //\n      if (!this.ioFilter(prevArgs)) {\n        if (q.size() === 0) { \n          this.deferred.resolve(responseChain || prevArgs);\n        }\n\n        q.flush(responseChain, error, prevArgs); // drain the queue\n        this._clear();\n        return;\n      }\n      \n      this._prepRequest(responseChain, prevArgs);\n\n      Logger.info('io()', api, this.req);\n      this.logger.info('io()', api, this.req);    \n\n      // send next request\n      this.req.end(function(res) {\n        self.share(self.cookies || res.headers['set-cookie']);         \n\n        // -- log cookies across requests --\n        if (self.cookies) {\n          Logger.info('cookies', api, self.cookies); \n          self.logger.info('cookies', api, self.cookies); \n        }\n\n        error = self._handleError(res);\n        var dres = (res.body && res.body.deployr ? res.body : res);             \n      \n        self.inputs = [];\n        self.outputs = [];\n\n        if (!error) {\n           // -- Log global + transaction log --\n           Logger.info('end()', api, dres, res);\n           self.logger.info('end()', api, dres, res);\n\n           // -- walk response for top-level entity response assignment --        \n           if (entities) { dres = dres.deployr.response[entities] || dres; }\n\n           dres.get = function(key) { \n              return utils.get(dres.deployr.response, key); \n           };\n\n           dres.workspace = function(name) { \n              return utils.workspace(dres.deployr.response, name); \n           };\n\n           // -- callback --\n           if (fn) { args = fn.apply(self.scope, [dres, responseChain]);}\n\n           // -- notify that the queue has been drained... --\n           if (q.size() === 0) { \n             self._clear();\n             self.deferred.resolve(responseChain || dres);\n           }          \n\n           // -- include cookies in next request in the queue --\n           args = merge(args, { __cookies__: self.cookies });          \n        }        \n\n        q.yield(false);\n        q.flush(dres, error, args); // pass result|error|args to next \n      });\n\n      q.yield(true);\n    }, this, this.delayed);\n  \n    if (!this.delayed && q.size() <= 1) { q.flush(); }\n\n    return this;\n  }, \n\n  /** \n   * Add an additional IO request to the exsisting sequential request chain.\n   *\n   * @method io\n   * @param {String} api One of the supported DeployR APIs.\n   * @return {DeployR} for chaining.\n   * @api public\n   */   \n  io: function (api) {    \n    return DeployR.new(api, { \n      cookies: this.cookies, \n      queue: this.q, \n      deferred: this.deferred\n    });\n  },\n\n  /** \n   * Convenience function for adding an additional script execution to the \n   * exsisting sequential request chain.\n   *\n   * @method script\n   * @param {Arguments} Arguments to define the fully qualified script for \n   * execution.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  script: function() {\n     var args = utils.signature(arguments),\n         opts = args.opts,\n         api  = args.api,\n         link = { \n          cookies: this.cookies, \n          queue: this.q, \n          deferred: this.deferred\n        };  \n\n    // convenience - if the project is a boolen `true` rather than a pid, first\n    // create a new project and then prepare the project api call to execute\n    if (args.create) {\n      return DeployR.new('/r/project/create', link)\n               .end(function(res) {\n                  return { project: res.get('project').project };\n                })\n               .io(api)\n               .data(opts);\n    } else {\n      return DeployR.new(api, link).data(opts);\n    }    \n  },\n\n  /** \n   * Convenience function for adding an additional repository-managed shell \n   * script execution to the exsisting sequential request chain.\n   *\n   * This call executes repository-managed shell scripts .sh, .csh, .bash, .bat \n   * on the DeployR server. Due to the special security concerns associated with \n   * excuting shell scripts on the DeployR server, only shell scripts owned by \n   * _ADMINISTRATOR_ users can be executed on this API call. Any attempt to \n   * execute a shell script stored in the repository that is not owned by an \n   * _ADMINISTRATOR_ user will be rejected.\n   *\n   * To execute a repository-managed shell script the caller must provide \n   * parameter values for _author_, _directory_, _filename_. This can be\n   * achieved by providing a fully qualified shell script \n   * `/<author>/<directory>/<filename>`, for example:\n   *\n   *  ```\n   *  .shell('/admin/external:public:admin/echo.sh', 'echo.sh args to pass.')\n   *  ```\n   *\n   * @method shell\n   * @param {String} filepath to define the fully qualified shell script for\n   * execution. \n   * @param {String} args (optional) arguments to be passed into the shell \n   * script on execution.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  shell: function(path, args) {   \n    var link = { \n          cookies: this.cookies, \n          queue: this.q, \n          deferred: this.deferred\n        },\n        tokens = Lang.isString(path) ? path.split('\\/') : [];\n\n    // handle both: `/author/directory/filename` & `author/directory/filename`\n    if (tokens.length > 3) { tokens = tokens.slice(1); }\n\n    return DeployR.new('/r/repository/shell/execute', link).data({\n      author: tokens[0],\n      directory: tokens[1],\n      filename: tokens[2],\n      args: args\n    });\n  },\n\n  /** \n   * Convenience function for executing a block of R code on the R session.\n\n   * Example:\n   *  ```\n   *  .code('x<-5')\n   *  // -- or --\n   *  .code('x<-5', projectId)\n   *  ```\n   *   \n   * @method code\n   * @param {String} r - The block of R code to execute.\n   * @param {String} project - (optional) if omitted a new project will first be \n   * created and used, otherwise it will execute on the R session identified by \n   * this `project`.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  code: function(r, project) {\n     var link = {\n             cookies: this.cookies,\n             queue: this.q,\n             deferred: this.deferred\n         },\n         api = '/r/project/execute/code';\n\n     if (!project) {\n         return DeployR.new('/r/project/create', link)\n             .end(function(res) {\n                 return { project: res.get('project').project };\n             })\n             .io(api)\n             .data({ code: r });\n     } else {\n         return DeployR.new(api, link).data({ code: r, project: project });\n     }\n  },\n  \n  /** \n   * Release any residual project resources associated with the application \n   * instance whenever a client application terminates. This includes closing \n   * any supplied projects down and logging out.\n   *\n   * @method release\n   * @param {String|Array} projects The project or list of projects to close.\n   * @param {Boolean} auth (optional) to remain authenticated.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  release: function(projects, auth) {\n     projects = Lang.isArray(projects) ? projects : [projects];\n\n     var self     = this,\n         deferred = D(),\n         empty    = !projects || !projects[0],\n         count    = 0,\n         last     = !empty ? projects.length - 1 : count,\n         cookies  = this.getCookies();           \n\n    function logout(index) {\n      if (index === last) {\n        if (!auth) {\n          DeployR.new('/r/user/logout')\n          .share(cookies)\n          .error(function() {          \n            deferred.reject(false);\n          })      \n          .end(function() { \n            deferred.resolve(true);\n          })\n          .ensure(function() {\n            self.destroy();\n          });\n        } else {\n          deferred.resolve(true);\n          self.destroy();\n        }\n      } \n    }\n\n    if (!empty) {\n      projects.forEach(function(project) {\n        DeployR.new('/r/project/close')\n        .data({ project: project })\n        .share(cookies)\n        .end()\n        .ensure(function() {\n          logout(count);\n          count++;\n        });\n      });   \n    } else {\n      logout(count);\n    }\n\n    return deferred.promise;  \n  },  \n\n  /** \n   * A convenience alternative to multiple `.rinput()` calls. Defines a name \n   * list of R objects that will be returned as DeployR-encoded R objects on the \n   * response markup.\n   *\n   * Calling this method ~.routputs([ ... ])` is equivalent to invoking multiple \n   * `.routput(...)` calls.\n   *\n   * @method routputs\n   * @param {Array} robjects A name list of R objects that will be returned.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  routputs: function (routputs) {\n    if (routputs) { this.outputs = this.outputs.concat(routputs); }\n\n    return this;\n  },\n  \n  /** \n   * Defines the name of the R object that will be returned as a DeployR-encoded \n   * R object on the response markup.\n   *\n   * @method routput\n   * @param {String} robject The name of the R object that will be returned.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  routput: function (routput) {\n    if (routput) { this.routputs([routput]); }\n\n    return this;\n  },\n\n  /** \n   * Used to pass multiple inputs at once from JavaScript to an R script using \n   * one of the defined `RInput` factories.\n   *\n   * @method rinputs\n   * @param {Array} rinputs The `RInput` list of DeployR-specific encoded R \n   * object data for use on an API call.\n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  rinputs: function (rinputs) {\n    if (rinputs) { this.inputs = this.inputs.concat(rinputs); }\n\n    return this;\n  },\n\n  /** \n   * Used to pass multiple inputs at once from JavaScript to an R script using \n   * one of the defined `RInput` factories.\n   *\n   * @method rinput\n   * @param {RInput} rinput The DeployR-specific encoded R object data for use \n   * on an API call.   \n   * @return {DeployR} for chaining.   \n   * @api public\n   */\n  rinput: function (rinput) {\n    if (rinput) { this.inputs.push(rinput); }\n\n    return this;\n  },\n\n  /**\n   * Destroy lifecycle method. Fires the `destroy` event, prior to invoking \n   * destructors for the class hierarchy. Called internally when `.release()`\n   * is called.\n   *\n   * @method destroy\n   * @api public   \n   */\n  destroy: function () {\n    try {\n      this.emit('destroy');\n      this.offAll();\n    \n      for (var key in this) {\n        if (this.hasOwnProperty(key)) { \n          this[key] = null; \n          delete this[key];\n        }\n      }\n    } catch(err) {}\n  },  \n\n  // --------------------------------------------------------------------------\n  // Private methods\n  // --------------------------------------------------------------------------\n\n  /**\n   * @api private\n   */\n  _clear: function() {    \n    this.params   = {};\n    this.inputs   = [];\n    this.outputs  = [];\n    this.rstream  = false;\n    this.delayed  = false;\n    this.api      = null;    \n    this.file     = null;  \n    this.entities = null;\n    this.ioFilter = null;\n  }, \n\n  /**\n   * @api private\n   */\n  _prepRequest: function (responseChain, args) {\n    var req  = this.req,\n        file = this.file;\n\n    // set the request type    \n    if (this.api.upload) {\n       // If the env is the Browser there is no need to manually set the\n       // Content-Type. The browser will automatically set the \n       // \"multipart/form-data; boundary=...\" value. If the env is Node we need\n       // to set it manually.\n       if (!win) { this.req.type('multipart/form-data'); }    \n    } else {\n      req.type('form');\n    }    \n\n    req.on('error', function(err) { \n      err = err || {  code: 'UNKNOWN CODE', text: 'UNKNOWN ERROR' };\n\n      this._handleError({ \n        status: err.code || 'UNKNOWN CODE',\n        text: err\n      });\n    }.bind(this));    \n\n    this.share(args ? args.__cookies__ : null);\n\n    // arguments returned from prev request's io().end(function() { return x; })\n    if (args) { \n       this.data(args);\n    } \n\n    if (this.inputs.length > 0) { \n      this.data({ inputs: encoder.encode(this.inputs) }); \n    }\n  \n    if (this.outputs.length > 0) { \n      this.data({ robjects: this.outputs.join() }); \n    }    \n\n    if (this.cookies) {     \n      this.cookies.forEach( function(c) { req.set('Cookie', c); });\n    }\n\n    if (this.api.upload) {    \n      for(var p in this.params) {\n        req.field(p, (this.params[p] || this.params[p] === false) ? \n           this.params[p] + '' : '');\n      } \n      req.attach('file', this.rstream ? fs.createReadStream(file) : file);\n    } else {\n      req[this.api.method === 'GET' ? 'query' : 'send'](this.params);\n    } \n  },\n\n  /**\n   * @api private\n   */\n  _handleError: function (raw) {\n    var stat  = raw.status,\n        res   = (raw.body && raw.body.deployr ? raw.body : raw),\n        error = ((stat !== 200) || res.deployr && !res.deployr.response.success);\n\n    // -- Handle errors --\n    if (error) {\n      res = {\n        get: function(key) { \n          return utils.get(this.deployr.response, key); \n        },\n        deployr: {          \n          response: {\n            success: false,\n            call: this.api['call'],\n            errorCode: res.deployr ? res.deployr.response.errorCode : stat,\n            error: res.deployr ? res.deployr.response.error : res.text\n          }\n        }\n      };\n\n      Logger.error('error()', this.api, res, raw);\n      this.logger.error('error()', this.api, res, raw);\n\n      // -- notify global errors first (if any) for this call --      \n      if (this.globalEvts) {\n        raiseGlobalErrors(this.api['call'], res);        \n      }\n\n      // -- tranaction level HTTP or DeployR errors come next --    \n      this.emit('error', res);\n      this.emit('deployr-io:' + res.deployr.response.errorCode, res);\n      this.deferred.reject(res);\n    }\n\n    return error;\n  }\n});\n\n/*****************************************************************************/\n/*****************************************************************************/\n/*****************************************************************************/\n\n// Include the `deprecated` jsDeployR for now.\nif (win) {\n  window.Revolution = window.Revolution || require('./lib/deprecated');\n}\n\n/*****************************************************************************/\n/*****************************************************************************/\n/*****************************************************************************/\n\n/**\n * Expose for a cleaner client api into DeployR\n */\nmodule.exports = {\n\n  /**\n   * Exposes the `DeployR` object for extending.\n   *\n   * ```var DeployR = require('deployr').DeployR;```\n   *\n   * @static\n   * @api public\n   * @return {DeployR} The `DeployR` object.\n   */   \n  DeployR: DeployR,\n\n  /**\n   * Exposes the supported DeployR APIs.\n   *\n   * @method apis\n   * @param {Boolean} flat (optional) if `true` will return an array of just the \n   * API's endpoint properties, for example: \n   * ```\n   * ['/r/user/login', '/r/user/logout', '/r/user/about', ...]\n   * ```\n   * @static\n   * @api public\n   * @return {Object|Array} The HTTP request to the DeployR server.      \n   */  \n  apis: function(flat) {\n    return flat ? Object.keys(apis) : apis;\n  },\n\n  /**\n   * Represents a static method for configuring all DeployR requests. Settings \n   * made here are applied globally across every request.\n   *\n   * @method configure\n   * @param {Object} options The object literal configuration hash. \n   * @static\n   * @chainable\n   * @api public\n   */\n  configure: function(options) {\n    options = options || {};\n\n    for (var i in options) { globalOptions.set(i, options[i]); }\n\n    // assert global cookies are empty if global `sticky` jsessionid is off\n    if (!globalOptions.sticky)  { globalOptions.set('cookies', null); }\n\n    // turn global logging on|off (off by default)\n    Logger.setLevel(globalOptions.logging ? Logger.DEBUG : Logger.OFF);\n\n    return this;\n  },\n\n  /**\n   * Factory for creating new IO requests to `DeployR`.\n   *\n   * Example:\n   * ```   \n   *    deployr.io('/r/user/about').end(callback);\n   * ```\n   *\n   * @method io\n   * @param {String} api One of the supported DeployR APIs.\n   * @static\n   * @return {DeployR} The HTTP request to the DeployR server.\n   * @api public   \n   */\n  io: function(api) {  \n    return DeployR.new(api);\n  },\n\n  /**\n   * Convenience function to sign the user in by authenticating the credentials \n   * with the DeployR server.   \n   *\n   * @method auth\n   * @param {String} username Specifies the username.\n   * @param {String} password Specifies the password.\n   * @static\n   * @return {DeployR} The HTTP request to the DeployR server.   \n   * @api public   \n   */   \n  auth: function(un, pw) {\n    var data = { username: un, password: pw };\n    return DeployR.new('/r/user/login').data(data).end();    \n  },\n\n  /**\n   * Convenience function to sign the user in by authenticating the credentials \n   * with the DeployR server.   \n   *\n   * Example:\n   * ```\n   *    deployr.script('/testuser/root/reduce.R')\n   *    deployr.script({ filename: 'reduce.R', author: 'testuser',\n   *                     directory: 'root'})\n   *    deployr.script('reduce.R', 'testuser', 'root')\n   *    deployr.script('/testuser/root/reduce.R', project)     \n   * ```   \n   *\n   * @method script\n   * @param {Arguments} arguments Arguments to define the fully qualified script \n   * for execution.\n   * @static\n   * @return {DeployR} The HTTP request to the DeployR server.   \n   * @api public   \n   */     \n  script: function() {\n    var args = utils.signature(arguments),\n        opts = args.opts,\n        api  = args.api;  \n\n    // convenience - if the project is a boolen `true` rather than a pid, first\n    // create a new project and then prepare the project api call to execute\n    if (args.create) {\n      return DeployR.new('/r/project/create')\n               .end(function(res) {\n                  return { project: res.get('project').project };\n                })\n               .io(api)\n               .data(opts);\n    } else {\n      return DeployR.new(api).data(opts);\n    }\n  },  \n\n  /**\n   * Run an series of chained DeployR requests in sequence and without overlap.       \n   *\n   * @method pipline\n   * @param {Array} tasks Specifies the list of `Function` tasks.\n   * @static\n   * @return {Promise} A promise wrapping the resolution of either \"resolve\" or\n   * \"reject\" callback.\n   * @api public   \n   */\n  pipeline: function(chains) {      \n    var deployr  = this,\n        deferred = D(),\n        q        = new Queue(),\n        results  = [],\n        errors   = [],\n        NOOP     = null, // NOOP errors|results for [a] batch request chain\n        orig     = {\n          sticky: globalOptions.sticky,\n          cookies: globalOptions.cookies\n        };\n\n    // make a copy\n    chains = chains.slice(0);\n\n    // turn sticky session for these request (hacky)\n    deployr.configure( { sticky: true });\n\n    function add() {\n      q.add(function() { \n        chains.shift().drain()\n        .then(function(chain) {\n          results.push(chain);  \n          errors.push(NOOP);           \n          if (q.isEmpty()) { \n            deployr.configure(orig); // reset\n            deferred.resolve({ results: results, errors: errors }); \n          }  \n\n          q.take();\n        }, function(err) {          \n          results.push(NOOP); \n          errors.push(err);\n          // rejections are only met when they [all] fail\n          if (q.isEmpty() && results.length === 0) { \n            deployr.configure(orig); // reset\n            deferred.reject(errors); \n          }  \n          q.take();\n        });       \n      }, null, true);\n    }\n\n    // convert to a seq queue for better handling\n    for(var i = 0; i < chains.length; i++) { add(); }\n\n    // start: dequeue first item and run it\n    q.take();\n\n    return deferred.promise;\n  },\n\n  /**\n   * The event stream API is unique within the DeployR API as it supports push \n   * notifications from the DeployR server to client applications. Notifications \n   * correspond to discrete events that occur within the DeployR server. There \n   * are four distinct event categories:\n   * \n   * - Stream Lifecycle events\n   * - Execution events\n   * - Job Lifecycle events\n   * - Management events\n   *\n   * Example:\n   * ```\n   * deployr.es({ username: 'testuser', password: 'secret' })\n   *    // -- connection choices for event types --\n   *    .management()  //.session() | .all() | .project(id) | .job(id)\n   *    .on('es:gridHeartbeat', function(data) {\n   *        console.log('===================');\n   *        console.log('es:gridHeartbeat');\n   *        console.log('===================');          \n   *     })\n   *     .open();\n   * ```\n   * \n   * @method es\n   * @param {Object} options The object literal configuration hash. \n   * @static\n   * @return {EventStream} a new `EventStream` for binding.\n   * @api public   \n   */  \n  es: function(options) {    \n    var stream = EventStream.new(globalOptions.host, options);\n\n    if (options && options.username && options.password) {\n      var ruser = this.auth(options.username, options.password);\n      ruser.ensure(function() { \n        stream.share(ruser.getCookies());\n        stream.flush(); \n      });\n    }\n\n    return stream;\n  },\n\n  /**\n   * Defines the factory for creating a DeployR-specific encoded R object to be \n   * sent as input parameters to an R script.\n   *\n   * Example:\n   * ```\n   *    var rinput = deployr.RInput.logical('logical_name', true);\n   *    var rinput = deployr.RInput.numeric('numeric_name', 10.5);\n   *    var rinput = deployr.RInput.integer('integer_name', 5);\n   *    var rinput = deployr.RInput.character('character_name', 'Hello');\n   *    // ect...\n   * ```\n   * @property RInput\n   * @static\n   * @api public\n   */\n  RInput: {\n    numeric: function (name, value) {\n      return RInput.new(name, value).numeric();\n    },\n\n    integer: function (name, value) {\n      return RInput.new(name, value).integer();\n    },\n\n    logical: function (name, value) {\n      return RInput.new(name, value).logical();\n    },\n\n    character: function (name, value) {\n      return RInput.new(name, value).character();\n    },\n\n    date: function (name, value) {\n      return RInput.new(name, value).date();\n    },\n\n    posixct: function (name, value) {\n      return RInput.new(name, value).posixct();\n    },  \n\n    numericVector: function(name, value) {\n      return RInput.new(name, value).numericVector();\n    }, \n\n    integerVector: function (name, value) {\n      return RInput.new(name, value).integerVector();\n    },\n\n    logicalVector: function (name, value) { \n      return RInput.new(name, value).logicalVector();\n    },\n\n    characterVector: function (name, value) { \n      return RInput.new(name, value).characterVector();\n    },  \n\n    dateVector: function (name, value) { \n      return RInput.new(name, value).dateVector();\n    },  \n\n    posixctVector: function (name, value) { \n      return RInput.new(name, value).posixctVector();\n    },\n\n    list: function (name, value) {\n      return RInput.new(name, value).list(); \n    },\n\n    dataframe: function (name, value) { \n      return RInput.new(name, value).dataframe();\n    },\n  \n    factor: function (name, value, levels, labels) {\n      var opts = { levels: levels, labels: labels };\n      return RInput.new(name, value, opts).factor();\n    },\n\n    ordered: function (name, value, levels, labels) {\n      var opts = { levels: levels, labels: labels };\n      return RInput.new(name, value, opts).ordered();\n    },\n\n    numericMatrix: function (name, value) { \n      return RInput.new(name, value).numericMatrix();\n    },\n\n    integerMatrix: function (name, value) { \n      return RInput.new(name, value).integerMatrix();\n    },\n\n    logicalMatrix: function (name, value) { \n      return RInput.new(name, value).logicalMatrix();\n    },\n\n    characterMatrix: function (name, value) {\n      return RInput.new(name, value).characterMatrix();\n    }\n  }\n};"]}","module.exports={\n    \"/r/user/login\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/user/logout\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/user/about\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/user/autosave\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/user/release\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/create\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/pool\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/recycle\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/ping\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/about\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/about/update\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/save\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/saveas\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/close\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/grant\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/import\": {\n        \"method\": \"POST\",\n        \"format\": \"json\",\n        \"upload\": true\n    },\n\n    \"/r/project/export\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/code\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/script\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/interrupt\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/console\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/history\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/flush\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/result/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/result/download\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/execute/result/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/get\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/upload\": {\n        \"method\": \"POST\",\n        \"format\": \"json\",\n        \"upload\": true\n    },\n\n    \"/r/project/workspace/transfer\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/push\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/save\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/store\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/load\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/workspace/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/upload\": {\n        \"method\": \"POST\",\n        \"format\": \"json\",\n        \"upload\": true\n    },\n\n    \"/r/project/directory/transfer\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/write\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/update\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/store\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/load\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/download\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/directory/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/package/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/package/attach\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/project/package/detach\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/job/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/job/submit\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/job/schedule\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/job/query\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/job/cancel\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/job/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/create\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/rename\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/copy\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/move\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/update\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/script/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/script/execute\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/script/render\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/script/interrupt\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/shell/execute\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/archive\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/upload\": {\n        \"method\": \"POST\",\n        \"format\": \"json\",\n        \"upload\": true\n    },\n\n    \"/r/repository/directory/download\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/directory/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/list\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/fetch\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/fetch\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/upload\": {\n        \"method\": \"POST\",\n        \"format\": \"json\",\n        \"upload\": true\n    },\n\n    \"/r/repository/file/transfer\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/write\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/update\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/diff\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/revert\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/grant\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/download\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/delete\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/copy\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/repository/file/move\": {\n        \"method\": \"POST\",\n        \"format\": \"json\"\n    },\n\n    \"/r/server/info\": {\n        \"method\": \"GET\",\n        \"format\": \"json\"\n    }\n}\n","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more\n * details.\n */\nvar Lang = require('./lang'),\n    Base = require('./selfish').Base,\n    RInput = require('./rinput');\n\nvar Deprecated,\n    emitter,\n    _config = {},\n    TOPLEVEL_ENTITIES = [\n        'user',\n        'project',\n        'workspace',\n        'execution',\n        'directory',\n        'repository',\n        'packages'\n    ];\n\n/**********************************************************************/\n/**********************************************************************/\n/**********************************************************************/\n\nvar SessionManager = {\n    ENDPOINT_WHITELIST: {\n        login: '/r/user/login',\n        logout: '/r/user/logout',\n        projectCreate: '/r/project/create',\n        projectClose: '/r/project/close',\n        projectAboutUpdate: '/r/project/about/update',\n        projectSave: '/r/project/save',\n        projectSaveAs: '/r/project/saveas',\n        // --- private APIS ---\n        clientProjectSave: '/r/client/project/save',\n        clientProjectClose: '/r/client/project/close'\n    },\n\n    session: {},\n\n    config: {},\n\n    setUnloadConfig: function(config) {\n        config = config || {};\n        this.config = {\n            disableautosave: config.disableautosave || true,\n            dropworkspace: config.dropworkspace || true,\n            dropdirectory: config.dropdirectory || true,\n            drophistory: config.drophistory || true,\n            flushhistory: config.flushhistory || true\n        };\n    },\n    setSession: function(session) {\n        this.session = session;\n    },\n    setProject: function(project) {\n        this.session.project = project;\n    },\n    clearSession: function() {\n        this.session = {};\n    },\n    clearProject: function() {\n        this.session.project = null;\n    },\n    unloadHandler: function() {\n        try {\n            var project = this.session.project;\n            if (project) {\n\n                var data = this._config;\n                data.project = project.id;\n                data.projectcookie = project.cookie;\n\n                deployr.io('/r/project/close')\n                    .data(data)\n                    .sync()\n                    .end();\n            }\n        } catch (e) {\n            throw new Error(e);\n        }\n    }\n};\n\n/**********************************************************************/\n/**********************************************************************/\n/**********************************************************************/\n\nfunction format(response, transEntity) {\n    // -- transaction entity formats override global entity formats --  \n    //var format = transEntity || _config.entity;\n    var format = transEntity || globalConfig.entity;\n\n    if (format) {\n        var resObj = response.deployr.response,\n            // -- top-level entities --\n            entities = TOPLEVEL_ENTITIES;\n\n        for (var index = 0; index < entities.length; index++) {\n            var entity = entities[index];\n\n            if (resObj[entity] && format[entity]) { // response entity hit\n                // -- user-defined parse for top-level entity --                \n                if (format[entity].parser) {\n                    var formatScope = format[entity].scope || this;\n                    resObj[entity] = format[entity].parser.call(formatScope, resObj[entity]);\n                }\n            }\n        }\n    }\n\n    return response;\n}\n\nfunction changeEndpoint(response, endpoint, args) {\n\n    var resObj = response.deployr.response,\n        ENDPOINT = SessionManager.ENDPOINT_WHITELIST;\n\n    switch (endpoint) {\n\n        case ENDPOINT.login:\n\n            SessionManager.setSession({\n                httpcookie: resObj.httpcookie,\n                user: resObj.user,\n                limits: resObj.limits,\n                project: null\n            });\n            break;\n\n        case ENDPOINT.logout:\n            SessionManager.clearSession();\n            break;\n\n        case ENDPOINT.projectClose:\n        case ENDPOINT.clientProjectClose:\n            SessionManager.clearProject();\n            break;\n\n        case ENDPOINT.projectCreate:\n        case ENDPOINT.projectAboutUpdate:\n        case ENDPOINT.projectSave:\n        case ENDPOINT.projectSaveAs:\n        case ENDPOINT.clientProjectSave:\n            var project = resObj.project;\n            SessionManager.setProject({\n                id: project.project,\n                cookie: project.cookie\n            });\n            break;\n\n    } // end switch\n\n    Deprecated.Event.fire('DeployR:endpointChange', {\n        response: response,\n        endpoint: endpoint,\n        args: args\n    });\n}\n\n\nfunction camelCase(input) {\n    // convert format: '/r/user/login' --> 'userLogin'\n    input = input.replace('\\/r\\/', '');\n    return input.toLowerCase().replace(/\\/(.)/g, function(match, segment) {\n        return segment.toUpperCase();\n    });\n}\n\n// turn the old deprecated inputs into new inputs\nfunction normalizeInputs(inputs) {\n    var rinputs = [];\n\n    for (var i = 0; i < inputs.length; i++) {\n        rinputs.push(inputs[i].normalize());\n    }\n\n    return rinputs;\n}\n\n/**********************************************************************/\n/**********************************************************************/\n/**********************************************************************/\n\n/**\n * The Deprecated interface.\n */\nvar RData = Base.extend({\n    initialize: function(type, rclass, rinput) {\n        this.type = type;\n        this.rclass = rclass;\n        this.rinput = rinput;\n    },\n\n    getType: function() {\n        return this.type;\n    },\n\n    getRClass: function() {\n        return this.rclass;\n    },\n\n    getName: function() {\n        return this.rinput.name;\n    },\n\n    getValue: function() {\n        return this.rinput.value;\n    },\n\n    getLevels: function() {\n        return this.rinput.levels;\n    },\n\n    getLabels: function() {\n        return this.rinput.labels;\n    },\n\n    getOrdered: function() {\n        return this.rinput.ordered;\n    },\n\n    normalize: function() {\n        return this.rinput;\n    }\n});\n\n/**********************************************************************/\n/**********************************************************************/\n/**********************************************************************/\n\nfunction Emitter(obj) {  \n  \n}\n\nfunction debug(msg) {  \n}\n\nEmitter.prototype = {\n\n  events: {},\n\n  scope: null,\n\n  /**\n   * Adds a listener.  Multiple can be added per name.  Aliased as `on`.\n   *\n   * @param {String} name The name of the event\n   * @param {Function} handler A callback\n   */\n  on: function(name, handler) {\n    if (name in this.events === false) { this.events[name] = []; }        \n\n    this.events[name].push(handler);\n    debug('Emitter.on(\"' + name + '\")');\n\n    return this;\n  },\n\n  /**\n   * Triggers all matching listeners.\n   *\n   * @param {String} name The name of the event\n   * @returns {Boolean} `true` if an event fired\n   */\n  emit: function(name) {\n    if (name in this.events === false) { return this; }\n\n    for (var i = 0; i < this.events[name].length; i++) {\n      debug('Fired event: \"' + name + '\"');\n      this.events[name][i].apply(this.scope || this, Array.prototype.slice.call(arguments, 1));       \n    }\n\n    return this;\n  },\n\n  /**\n   * Removes all matching listeners.\n   *\n   * @param {String} name The name of the event\n   * @returns {Boolean} `true` if an event was removed\n   */\n  removeAllListeners: function(name) {\n    if (!name) {\n      for (var e in this.events) {\n        delete this.events[e];\n      }\n    } else {\n      if (name in this.events === false) { return this; }\n      delete this.events[name];        \n    }\n\n    return this;\n  },\n\n  removeListenerAt: function(name, index) {\n    var array = this.events[name],\n        rest = array.slice(index + 1);\n\n    array.length = index;\n    array.push.apply(array, rest);\n    this.events[name] = array;\n  },\n\n  /**\n   * Removes a listener based on the handler function.\n   *\n   * @param {String} name The name of the event\n   * @param {Function} handler The handler function to remove\n   * @returns {Boolean} `true` if an event was removed\n   */\n  off: function(name, handler) {\n    if (name in this.events === false) { return this; }\n\n    // remove all events handlers by this name\n    if (!handler) {\n      return this.removeAllListeners(name);\n    } else { // remove all events handlers == 'handler' by this name\n      for (var i = 0; i < this.events[name].length; i++) {\n        if (this.events[name][i] == handler) {\n          this.removeListenerAt(name, i);\n          return this;\n        }\n      }\n    } \n\n    return this;\n  }\n};\n\n\nemitter = new Emitter();\n\n/**\n * Provides simple adapter methods which wrap the raw <code>Revolution.DeployR.io(...)</code>\n * remote DeployR API AJAX transactions. These methods are an opt-in feature to\n * complement the low level DeployR IO communication.\n *\n * @class Revolution.DeployR.PublicAdapter\n * @extensionfor Revolution.DeployR\n */\n\nDeprecated = {\n    version: require('../package').version,\n\n    Event: {\n        on: function(type, fn, scope) {\n            emitter.on(type, fn, scope);\n        },\n\n        detach: function(type, fn, obj) {\n            emitter.off(type, fn);            \n        }\n    },\n\n    RDataFactory: {\n        createNumeric: function(name, value) {\n            return RData.new('primitive', 'numeric', RInput.new(name, value).numeric());\n        },\n\n        createInteger: function(name, value) {\n            return RData.new('primitive', 'integer', RInput.new(name, value).integer());\n        },\n\n        createBoolean: function(name, value) {\n            return RData.new('primitive', 'numeric', RInput.new(name, value).logical());\n        },\n\n        createString: function(name, value) {\n            return RData.new('primitive', 'character', RInput.new(name, value).character());\n        },\n\n        createDate: function(name, value) {\n            return RData.new('date', 'Date', RInput.new(name, value).date());\n        },\n\n        createPOSIXDate: function(name, value) {\n            return RData.new('date', 'POSIXct', RInput.new(name, value).posixct());\n        },\n\n        createNumericVector: function(name, value) {\n            return RData.new('vector', 'numeric', RInput.new(name, value).numericVector());\n        },\n\n        createIntegerVector: function(name, value) {\n            return RData.new('vector', 'integer', RInput.new(name, value).integerVector());\n        },\n\n        createBooleanVector: function(name, value) {\n            return RData.new('vector', 'logical', RInput.new(name, value).logicalVector());\n        },\n\n        createStringVector: function(name, value) {\n            return RData.new('vector', 'character', RInput.new(name, value).characterVector());\n        },\n\n        createDateVector: function(name, value) {\n            return RData.new('type', 'Date', RInput.new(name, value).dateVector());\n        },\n\n        createPOSIXDateVector: function(name, value) {\n            return RData.new('vector', 'POSIXct', RInput.new(name, value).posixctVector());\n        },\n\n        createList: function(name, value) {\n            return RData.new('list', 'list', RInput.new(name, value).list());\n        },\n\n        createDataframe: function(name, value) {\n            return RData.new('dataframe', 'data.frame', RInput.new(name, value).dataframe());\n        },\n\n        createFactor: function(name, value, ordered, levels, labels) {\n            var opts = {\n                levels: levels,\n                labels: labels\n            };\n\n            if (ordered) {\n                return RData.new('factor', 'factor', RInput.new(name, value, opts).ordered());\n            } else {\n                return RData.new('factor', 'factor', RInput.new(name, value, opts).factor());\n            }\n        },\n\n        createNumericMatrix: function(name, value) {\n            return RData.new('matrix', 'matrix', RInput.new(name, value).numericMatrix());\n        },\n\n        createIntegerMatrix: function(name, value) {\n            return RData.new('matrix', 'matrix', RInput.new(name, value).integerMatrix());\n        },\n\n        createBooleanMatrix: function(name, value) {\n            return RData.new('matrix', 'matrix', RInput.new(name, value).logicalMatrix());\n        },\n\n        createStringMatrix: function(name, value) {\n            return RData.new('matrix', 'matrix', RInput.new(name, value).characterMatrix());\n        }\n    }, // RDataFactory\n\n    DeployR: {\n\n        init: function(config) {\n            config = config || {};\n\n            // --- Assert JSDeploy compatability against the connected DeployR version ---\n            if (config.compatibility) {\n                //compatibilityCheck();\n            }\n\n            // --- Event registration ---\n            if (config.events) {\n                var events = config.events;\n\n                // -- Manage cleanup on browser close (close project, logout, ect...)--\n                if (events.unload) {\n                    SessionManager.setUnloadConfig(events.unload);\n                    Deprecated.Event.on('deployR:unload', SessionManager.unloadHandler, SessionManager);\n                }\n\n                // -- IO Global Events --\n                if (events.globalIO) {\n                    var scope = events.globalIO.scope || window,\n                        lifecycle = events.globalIO.lifecycle,\n                        statusCode = events.globalIO.statusCode;\n\n                    if (lifecycle) {\n                        for (var eventName in lifecycle) {\n                            Deprecated.Event.on('deployR-io:' + eventName, lifecycle[eventName], scope);\n                        }\n                    }\n\n                    if (statusCode) {\n                        for (var eventName in statusCode) {\n                            Deprecated.Event.on('deployR-io:' + eventName, statusCode[eventName], scope);\n                        }\n                    }\n                }\n            }\n\n            // New API\n            deployr.configure({\n                host: config.deployrURI,\n                cors: config.deployrURI ? true : false,\n                logging: config.logging,\n                sticky: true\n            });\n        },\n\n        io: function(api, config, cb) {\n            if (console) {\n                console.warn('\"' + camelCase(api) + '()\" API is now deprecated.');\n            }\n\n            cb = cb || {};\n            config = config || {};\n\n            var transaction = config.transaction || {},\n                transArgs = transaction['arguments'],\n                statusCode = transaction.statusCode || {},\n                scope = cb.scope || window,\n                routputs = config.robjects,\n                rinputs = config.inputs; // config.inputs = R.DeployR.parseInputs(config.inputs);\n\n            // --- omit deprecated props ---\n            if (config.transaction) {\n                delete config.transaction;\n            }\n            if (config.method) {\n                delete config.method;\n            }\n            if (config.on) {\n                delete config.on;\n            }\n            if (config.format) {\n                delete config.format;\n            }\n            if (config.inputs) {\n                delete config.inputs;\n            }\n            if (config.robjects) {\n                delete config.robjects;\n            }\n\n            // --- make the new request ---\n            var io = deployr.io(api)\n                .data(config || {})\n                .error(function(response) {\n                    // global-failure\n                    emitter.emit('deployR-io:failure', [response, api, transArgs]);\n\n                    // transaction-failure\n                    if (cb.failure) {\n                        cb.failure.apply(scope, [response, api, transArgs]);                        \n                    }\n\n                    // global-statusError\n                    emitter.emit(('deployR-io:' + code), [response, api, transArgs]);\n                });\n\n            if (rinputs) {\n                io.rinputs(normalizeInputs(rinputs));\n            }\n            if (routputs) {\n                io.routputs(routputs);\n            }\n            if (transaction.sync) {\n                io.sync();\n            }\n            if (transaction.timeout) {\n                io.timeout(transaction.timeout);\n            }\n\n            // --- Error status code --- //\n            if (statusCode) {\n\n                for (var eventName in statusCode) {                    \n                    io.on('deployr-io:' + eventName, function(response) {\n                        var cb = statusCode;\n                        var statusText = response.deployr.response.error;\n                        var status = response.deployr.response.errorCode;\n                        cb[status].apply(scope, [response, status, statusText, api, transArgs]);\n                    });\n                }                \n\n                // @@@@TODO @@@@@@\n            }\n\n            // global-start\n            emitter.emit('deployR-io:start');\n\n            /// transaction-start\n            if (cb.start) {\n                cb.start.apply(scope, [api, transArgs]); \n            }\n\n            io.end(function(response) {\n                // global-complete\n                emitter.emit('deployR-io:complete');\n\n                // transaction-complete\n                if (cb.complete) {\n                    cb.complete.apply(scope, [response, api, transArgs]); \n                }\n\n                // entity manipulation of the response\n                if (transaction.entity) {\n                    response = format(response, transaction.entity);\n                }\n\n                // global-success\n                emitter.emit('deployR-io:success', [response, api]);\n\n                // transaction-success\n                if (cb.success) {\n                    cb.success.apply(scope, [response, api, transArgs]);                    \n                }\n\n                // global-end\n                emitter.emit('deployR-io:end', [response, api]);\n\n                // transaction-end\n                if (cb.end) {\n                    cb.end.apply(scope, [response, api, transArgs]); \n                }                \n            });\n\n            return io;\n        },\n\n        /**\n         * Flattens a given <code>Revolution.RData</code> type into a JSON\n         * string representing the expected DeployR input format.\n         *\n         * @method parseInputs\n         * @public\n         * @param {Array} rdata An Array of RData Objects to be flattened.\n         * @return {String} The flattend RData JSON string representing the\n         * DeployR input format.\n         */\n        parseInputs: function(rdata) {\n            return rdata;\n        },\n\n        /////////////////////////////////////\n        // Project Workspace APIs\n        //////////////////////////////////////\n\n        /**\n         * This call lists the objects in the workspace for the project indicated.\n         *\n         * @method projectWorkspaceList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>root</dt>\n         *    <dd>(optional) specifies object graph root</dd>\n         *\n         *    <dt>clazz</dt>\n         *    <dd>(optional) specifies R class based filter</dd>\n         *\n         *    <dt>filter</dt>\n         *    <dd>(optional) specifies R object name based filter</dd>\n         *\n         *    <dt>restrict</dt>\n         *    <dd>\n         *       (optional) if <code>true</code, limits returned objects to object\n         *       types with supported RevoDeployR-encoding\n         *    </dd>\n         *\n         *    <dt>pagesize</dt>\n         *    <dd>\n         *       (optional) specifies the page size for paging results in response\n         *       markup\n         *    </dd>\n         *\n         *    <dt>pageoffset</dt>\n         *    <dd>\n         *       (optional) specifies the page offset for paging results in response\n         *       markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceList: function(config, callback) {\n            return this.io('/r/project/workspace/list', config, callback);\n        },\n\n        /**\n         * This call retrieves RevoDeployR-encoded objects from the workspace for the\n         * specified project.\n         *\n         * @method projectWorkspaceGet\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies a comma-separated list of object names</dd>\n         *\n         *    <dt>root</dt>\n         *    <dd>optional) specifies object graph root</dd>\n         *\n         *    <dt>start</dt>\n         *    <dd>optional) specifies the offset into object data</dd>\n         *\n         *    <dt>length</dt>\n         *    <dd>optional) specifies the segment of object data to retrieve</dd>\n         *\n         *      <dt>infinity</dt>\n         *    <dd>\n         *       (optional) specifies a custom value for Infinity appearing in R\n         *       object data returned on the call, otherwise Infinity is represented\n         *       by 0x7ff0000000000000L\n         *    </dd>\n         *\n         *      <dt>nan</dt>\n         *    <dd>\n         *       (optional) specifies custom value for NaN appearing in R object data\n         *       returned on the call, otherwise NaN is represented by null\n         *    </dd>\n         *\n         *    <dt>encodeDataFramePrimitiveAsVector</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, data.frame primitives are encoded\n         *       vectors in R object data returned on call\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceGet: function(config, callback) {\n            return this.io('/r/project/workspace/get', config, callback);\n        },\n\n        /**\n         * This call uploads a binary object from file into the workspace for the\n         * specified project.\n         *\n         * @method projectWorkspaceUpload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies the name of the object file</dd>\n         *\n         *    <dt>file</dt>\n         *    <dd>file content</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceUpload: function(config, callback) {\n            config.format = \"text\";\n            var ioConfig = {\n                data: config,\n                method: \"POST\",\n                form: {\n                    id: config.formId\n                },\n                on: callback\n            };\n            return this.io('/r/project/workspace/upload', config, callback);\n        },\n\n        /**\n         * This call transfers a binary object from a URL into the workspace for the\n         * specified project.\n         *\n         * @method projectWorkspaceTransfer\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies the name of the object file found on the URL</dd>\n         *\n         *    <dt>url</dt>\n         *    <dd>specifies the URL</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceTransfer: function(config, callback) {\n            return this.io('/r/project/workspace/transfer', config, callback);\n        },\n\n        /**\n         * This call pushes a RevoDeployR-encoded object into the workspace for the\n         * specified project.\n         *\n         * @method projectWorkspacePush\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded object inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspacePush: function(config, callback) {            \n            return this.io('/r/project/workspace/push', config, callback);\n        },\n\n        /**\n         * This call saves the workspace to a file in the working directory for the\n         * specified project.\n         *\n         * If the name parameter is specified on the call then only the named object\n         * is saved as a binary object file to the working directory. Otherwise the\n         * entire contents of the workspace are saved.\n         *\n         * @method projectWorkspaceSave\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>(optional) specifies a named object for saving</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies a description to accompany the saved file</dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>\n         *       (optional) if true, the new file will be renamed to avoid\n         *       overwriting\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceSave: function(config, callback) {            \n            return this.io('/r/project/workspace/save', config, callback);\n        },\n\n        /**\n         * This call stores the workspace as a binary object to the repository.\n         *\n         * If the name parameter is specified on the call, then only the named object\n         * is stored as a binary object in the repository. Otherwise the entire\n         * contents of the workspace are stored.\n         *\n         * @method projectWorkspaceStore\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *      <dt>name</dt>\n         *      <dd>(optional) specifies a named object for storing</dd>\n         *\n         *      <dt>descr</dt>\n         *      <dd>(optional) specifies a description to accompany the saved file</dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>\n         *       (optional) specifies tag words to associate with the repository file\n         *    </dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *       (optional) comma-separated list of role names, which makes the file\n         *       visible to authenticated users with these roles\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, the file will be shared, which\n         *       makes the file visible to authenticated users\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, the file will be published, which\n         *       makes the file visible to authenticated and anonymous users\n         *    </dd>\n         *\n         *      <dt>newversion</dt>\n         *      <dd>\n         *       (optional) if <code>true</code>, the new file will be renamed to\n         *       avoid overwriting\n         *    </dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceStore: function(config, callback) {\n            return this.io('/r/project/workspace/store', config, callback);\n        },\n\n        /**\n         * This call loads a binary object from a file in the repository into the\n         * workspace for the specified project.\n         *\n         * @method projectWorkspaceLoad\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>repo</dt>\n         *    <dd>specifies the repository name</dd>\n         *\n         *      <dt>filename</dt>\n         *      <dd>specifies the repository file name</dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>specifies the repository file author</dd>\n         *\n         *      <dt>version</dt>\n         *      <dd>(optional) specifies the repository file version</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceLoad: function(config, callback) {\n            return this.io('/r/project/workspace/load', config, callback);\n        },\n\n        /**\n         * This call deletes an object from the workspace for the specified project.\n         *\n         * @method projectWorkspaceDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies the object name</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectWorkspaceDelete: function(config, callback) {            \n            return this.io('/r/project/workspace/delete', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Project Management APIs\n        /////////////////////////////////////\n\n        /**\n         * This call creates a new project for the currently authenticated user.\n         * If the projectname parameter is specified on the call, then the newly\n         * created project will be a persistent project . If the projectname parameter\n         * is omitted on the call, then the newly created project will be a temporary\n         * project. The projectdescr parameter is ignored if the projectname parameter\n         * is omitted.\n         *\n         * The blackbox parameter ensures that calls on the temporary project are\n         * limited to the Blackbox API Controls .\n         *\n         * Using the inputs , preloadfile , preloadobject and adopt parameters the\n         * project can be pre-initialized with data in the workspace and/or working\n         * directory.\n         *\n         * The inputs parameter allows the caller to pass RevoDeployR-encoded R object\n         * values as inputs. These inputs are turned into R objects in the workspace\n         * of the new R session before the call returns.\n         *\n         * The preloadfile parameters allow the caller to load one or more files from\n         * the repository into the working directory of the new R session before the\n         * call returns.\n         *\n         * The preloadobject parameters allow the caller to load one or more binary R\n         * objects (.rData) from the repository into the workspace of the new R\n         * session before the call returns.\n         *\n         * The adopt parameters allow the caller to load a pre-existing project\n         * workspace, project working directory and/or project package dependencies\n         * into the new R session before the call returns.\n         *\n         * @method projectCreate\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>projectname</dt>\n         *    <dd>(optional) names a new persistent project</dd>\n         *\n         *    <dt>projectdescr</dt>\n         *    <dd>(optional) describes a new persistent project</dd>\n         *\n         *    <dt>blackbox</dt>\n         *    <dd>\n         *       (optional) when enabled, a temporary project is limited to blackbox\n         *       API controls\n         *    </dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>\n         *       (optional) comma-separated list of authors,\n         *       author-per-preloadfilename\n         *    </dd>\n         *\n         *    <dt>preloadfileversion</dt>\n         *    <dd>\n         *       (optional) comma-separated list of versions,\n         *       version-per-preloadfilename\n         *    </dd>\n         *\n         *    <dt>preloadobjectname</dt>\n         *    <dd>\n         *       (optional) comma-separated list of repository object (.rData)\n         *       filenames\n         *    </dd>\n         *\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>\n         *       (optional) comma-separated list of authors,\n         *       author-per-preloadobjectname\n         *    </dd>\n         *\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>\n         *       (optional) comma-separated list of versions,\n         *       version-per-object-preloadobjectname\n         *    </dd>\n         *\n         *    <dt>adoptworkspace</dt>\n         *    <dd>\n         *       (optional) identifies the project whose workspace is to be adopted\n         *    </dd>\n         *\n         *    <dt>adoptdirectory</dt>\n         *    <dd>\n         *       (optional) identifies the project whose directory is to be adopted\n         *    </dd>\n         *\n         *    <dt>adoptpackages</dt>\n         *    <dd>\n         *       (optional) identifies the project whose package dependencies are to\n         *       be adopted\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectCreate: function(config, callback) {\n            return this.io('/r/project/create', config, callback);            \n        },\n\n        /**\n         * This call creates a pool of temporary projects for the currently\n         * authenticated user. The caller can specify their preferred number of\n         * projects to create using the poolsize parameter. RevoDeployR will attempt\n         * to create up to poolsize number of projects. However, standard com\n         * policy contraints apply to individual users and on the grid so there is no\n         * guarantee that poolsize projects will be returned. If the number of\n         * projects returned on this call is less than poolsize the caller can inspect\n         * the error and errorCode properties in the response markup to determine\n         * exactly why their pool size was limited.\n         *\n         * The blackbox parameter ensures that calls on each project in the pool are\n         * limited to the Blackbox API Controls .\n         *\n         * Using the inputs, preloadfile, preloadobject and adopt parameters each\n         * project in the pool can be pre-initialized with data in the workspace\n         * and/or working directory.\n         *\n         * The inputs parameter allows the caller to pass RevoDeployR-encoded R object\n         * values as inputs. These inputs are turned into R objects in the workspace\n         * of the new R session before the call returns.\n         *\n         * The preloadfile parameters allow the caller to load one or more files from\n         * the repository into the working directory of the new R session before the\n         * call returns.\n         *\n         * The preloadobject parameters allow the caller to load one or more binary R\n         * objects (.rData) from the repository into the workspace of the new R\n         * session before the call returns.\n         *\n         * The adopt parameters allow the caller to load a pre-existing project\n         * workspace, project working directory and/or project package dependencies\n         * into the new R session before the call returns.\n         *\n         * @method projectPool\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>poolsize</dt>\n         *    <dd>the preferred size of the pool of temporary projects</dd>\n         *    <dt>blackbox</dd>\n         *    <dd>(optional) when enabled, each temporary project in the pool is limited to blackbox API controls</dd>\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded inputs</dd>\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *    <dt>preloadfileversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *    <dt>preloadobjectname</dt>\n         *    <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *    <dt>adoptworkspace</dt>\n         *    <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *    <dt>adoptdirectory</dt>\n         *    <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *    <dt>adoptpackages</dt>\n         *    <dd>(optional) identifies project from which package dependencies are to be adopted</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectPool: function(config, callback) {\n            return this.io('/r/project/pool', config, callback);\n        },\n\n        /**\n         * This call recycles the R session associated with the project by deleting\n         * all R objects from the workspace and all files from the working directory.\n         *\n         * Recycling a project is a convenient and efficient alternative to starting\n         * over by closing an existing project and then creating a new project.\n         *\n         * @method projectRecycle\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         * supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *    <dt>preserveworkspace</dt>\n         *    <dd>(optional) if true, the objects in the workspace are preserved on recycle</dd>\n         *    <dt>preservedirectory</dt>\n         *    <dd>(optional) if true, the files in the working directory are preserved on recycle</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectRecycle: function(config, callback) {\n            return this.io('/r/project/recycle', config, callback);\n        },\n\n        /**\n         * This call lists all projects owned by the currently authenticated user\n         * and/or all projects shared by other users.\n         *\n         * Shared projects are available as read-only projects to the caller. The\n         * shared or private nature of a project can be controlled using the\n         * <code>/r/project/about/update</code> call\n         * <a href=\"#method_projectAboutUpdate\">projectAboutUpdate</a>.\n         *\n         * @method projectList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>sharedprojectsalso</dt>\n         *    <dd>\n         *       (optional) when true, the project response list contains the caller's\n         *       projects plus projects shared by other users\n         *    </dd>\n         *\n         *    <dt>sharedprojectsonly</dt>\n         *    <dd>\n         *       (optional) when true, the project response list contains only\n         *       projects shared by other users and not the users's own projects\n         *    </dd>\n         *\n         *    <dt>isordered</dt>\n         *    <dd>\n         *       (optional) when true, the project response list is ordered in a\n         *       most-recently-modified first order. Otherwise the list is ordered\n         *       chronologically by creation date\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectList: function(config, callback) {\n            return this.io('/r/project/list', config, callback);\n        },\n        /**\n         * This call pings the specified project to determine if the project is live\n         * on the RevoDeployR grid.\n         *\n         * @method projectPing\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         *  <dl>\n         *      <dt>project</dt>\n         *      <dd>specifies the project identifier</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectPing: function(config, callback) {\n            return this.io('/r/project/ping', config, callback);\n        },\n\n        /**\n         * This call retrieves a set of properties that describe the specified\n         * project.\n         *\n         * @method projectAbout\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectAbout: function(config, callback) {\n            return this.io('/r/project/about', config, callback);\n        },\n\n        /**\n         * This call updates a set of properties that describe the specified project.\n         *\n         * @method projectAboutUpdate\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies the project name</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies the project description</dd>\n         *\n         *    <dt>longdescr</dt>\n         *    <dd>(optional) specifies the project long description</dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, specifies that the project is a\n         *       shared project\n         *    </dd>\n         *\n         *    <dt>projectcookie</dt>\n         *    <dd>\n         *       (optional) specifies a client-application specific project cookie\n         *    </dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectAboutUpdate: function(config, callback) {\n            return this.io('/r/project/about/update', config, callback);\n        },\n\n        /**\n         * This call saves the persistent state of the project indicated.\n         *\n         * The set of drop parameters allows the caller to selectively drop aspects,\n         * such as workspace, working directory, or execution history of the project\n         * state when saving. The flushhistory parameter allows the caller to preserve\n         * the project execution history itself while destroying all generated console\n         * output and results associated with that history.\n         *\n         * @method projectSave\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>(optional) specifies the project name</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies the project description</dd>\n         *\n         *    <dt>longdescr</dt>\n         *    <dd>(optional) specifies the project long description</dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>(optional) if true, specifies the project is a shared project</dd>\n         *\n         *    <dt>projectcookie</dt>\n         *    <dd>(optional) specifies a client-application specific project cookie</dd>\n         *\n         *    <dt>dropworkspace</dt>\n         *    <dd>(optional) if true, the content of the project's workspace is dropped on save</dd>\n         *\n         *    <dt>dropdirectory</dt>\n         *    <dd>(optional) if true, the content of the project's working directory is dropped on save</dd>\n         *\n         *    <dt>drophistory</dt>\n         *    <dd>(optional) if true, the project's execution history is dropped on save</dd>\n         *\n         *    <dt>flushhistory</dt>\n         *    <dd>(optional) if true, the project's execution history is flushed on save</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectSave: function(config, callback) {\n            return this.io('/r/project/save', config, callback);\n        },\n\n        /**\n         * This call saves the persistent state of the specified project to a new\n         * persistent project.\n         *\n         * The set of drop parameters allows the caller to selectively drop aspects,\n         * such as workspace, working directory, or execution history of the project\n         * state when saving to the new project. The flushhistory parameter allows the\n         * caller to preserve the project execution history itself for the new project\n         * while dropping all generated console output and results associated with the\n         * original history.\n         *\n         * @method projectSaveas\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies the new project name</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies the new project description</dd>\n         *\n         *    <dt>longdescr</dt>\n         *    <dd>(optional) specifies the new project long description</dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>(optional) if true, specifies the new project is a shared project</dd>\n         *\n         *    <dt>projectcookie</dt>\n         *    <dd>(optional) specifies a client-application specific cookie for the new project</dd>\n         *\n         *    <dt>dropworkspace</dt>\n         *    <dd>(optional) if true, the content of the original project's workspace is dropped when saving to the new project</dd>\n         *\n         *    <dt>dropdirectory</dt>\n         *    <dd>(optional) if true, the content of the project's working directory is dropped when saving to the new project</dd>\n         *\n         *    <dt>drophistory</dt>\n         *    <dd>(optional) if true, the project's execution history is dropped when saving to the new project</dd>\n         *\n         *    <dt>flushhistory</dt>\n         *    <dd>(optional) if true, the project's execution history is flushed when saving to the new project</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectSaveas: function(config, callback) {\n            return this.io('/r/project/saveas', config, callback);\n        },\n\n        /**\n         * This call closes the project indicated.\n         *\n         * Closing a live project releases all resources associated with the project\n         * on the RevoDeployR grid. If the specified project is a persistent project\n         * then the default autosave semantics will cause the project to be saved\n         * automatically. The caller can override that default behavior using the\n         * disableautosave parameter.\n         *\n         * The set of drop parameters allow the caller to selectively drop aspects,\n         * such as workspace, working directory, or execution history, of the project\n         * state when closing. The flushhistory parameter allows the caller to\n         * preserve the project execution history itself while destroying all\n         * generated console output and results associated with that history.\n         *\n         * @method projectClose\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies project identifier</dd>\n         *\n         *    <dt>disableautosave</dt>\n         *    <dd>(optional) if true, the default autosave semantics for persistent projects are disabled</dd>\n         *\n         *    <dt>projectcookie</dt>\n         *    <dd>(optional) specifies a client-application specific project cookie</dd>\n         *\n         *    <dt>dropworkspace</dt>\n         *    <dd>(optional) if true, the content of the project's workspace is dropped on close</dd>\n         *\n         *    <dt>dropdirectory</dt>\n         *    <dd>(optional) if true, the content of the project's working directory is dropped on close</dd>\n         *\n         *    <dt>drophistory</dt>\n         *    <dd>(optional) if true, the project's execution history is dropped on close</dd>\n         *\n         *    <dt>flushhistory</dt>\n         *    <dd>(optional) if true, the project's execution history is flushed on close</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectClose: function(config, callback) {\n            return this.io('/r/project/close', config, callback);\n        },\n\n        /**\n         * This call grants authorship of the specified project to other users.\n         *\n         * @method projectGrant\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>newauthor</dt>\n         *    <dd>\n         *       specifies a comma-separated list of usernames indicating the new\n         *       owners\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectGrant: function(config, callback) {\n            return this.io('/r/project/grant', config, callback);\n        },\n\n        /**\n         * This call imports the specified project archive as a new persistent\n         * project.\n         *\n         * @method projectImport\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>name</dt>\n         *    <dd>specifies the name of the project archive file</dd>\n         *\n         *    <dt>file</dt>\n         *    <dd>...file content...</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>\n         *       (optional) specifies a description for the newly imported project\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectImport: function(config, callback) {\n            config.format = \"text\";\n            var ioConfig = {\n                data: config,\n                method: \"POST\",\n                form: {\n                    id: config.formId\n                },\n                on: callback\n            };\n            return this.io('/r/project/import', config, callback);\n        },\n        /**\n         * This call exports a compressed archive file for the specified project.\n         *\n         * The set of drop parameters allow the caller to selectively drop aspects,\n         * such as workspace, working directory, or execution history of the project\n         * state when generating the archive. The flushhistory parameter allows the\n         * caller to preserve the project execution history itself while excluding all\n         * generated console output and results associated with that history.\n         *\n         * @method projectExport\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies project identifier</dd>\n         *\n         *    <dt>dropworkspace</dt>\n         *    <dd>(optional) if true, the content of the project's workspace is dropped on export</dd>\n         *\n         *    <dt>dropdirectory</dt>\n         *    <dd>(optional) if true, the content of the project's working directory is dropped on export</dd>\n         *\n         *    <dt>drophistory</dt>\n         *    <dd>(optional) if true, the project's execution history is dropped on export</dd>\n         *\n         *    <dt>flushhistory</dt>\n         *    <dd>(optional) if true, the project's execution history is flushed on export</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExport: function(config, callback) {\n            return this.io('/r/project/export', config, callback);\n        },\n\n        /**\n         * This call deletes the specified project.\n         * Deleting a project is a permanent operation that cannot be undone or\n         * recovered.\n         *\n         * @method projectDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies project identifier</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDelete: function(config, callback) {\n            return this.io('/r/project/delete', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Project Execution APIs\n        /////////////////////////////////////\n\n        /**\n         * This call executes a block of R code on the R session identified by the\n         * project parameter.\n         *\n         * Please note the following pre and post execution parameters:\n         *\n         * <strong>Pre-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The inputs parameter allows the caller to pass RevoDeployR-encoded\n         *       R object values as inputs. These inputs are turned into R objects\n         *       in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadfile parameters allows the caller to load one or more\n         *       files from the repository into the working directory before the\n         *       execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadobject parameters allow the caller to load one or more\n         *       binary R objects (.rData) from the repository into the workspace\n         *       before the execution begins.\n         *    </li>\n         *    <li>\n         *       The adopt parameters allow the caller to load a pre-existing\n         *       project workspace, project working directory and/or project package\n         *       dependencies before the execution begins.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Post-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The robjects parameter allows the caller to specify a comma-separated\n         *       list of object names that will be returned as RevoDeployR-encoded R\n         *       objects on the response markup after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storefile parameter allows the caller specify a comma-separated\n         *       list of working directory files to be stored in the repository after\n         *       the execution completes.\n         *    </li>\n         *    <li>\n         *       The storeobject parameter allows the caller specify a comma-separated\n         *       list of workspace objects to be stored in the repository after the\n         *       execution completes.\n         *    </li>\n         *    <li>\n         *       The storeworkspace parameter allows the caller to store the entire\n         *       workspace in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storedirectory parameter allows the caller to specify a target\n         *       repository directory for stored files and objects after the execution\n         *       completes.\n         *    </li>\n         *    <li>\n         *       The storenewversion parameter allows the caller to create new\n         *       versions of each stored file in the repository after the execution\n         *       completes. By default, stored files overwrite any pre-existing file\n         *       by the same name.\n         *    </li>\n         *    <li>\n         *       The storepublic parameter allows the caller to assign public access\n         *       to each stored file in the repository after the execution completes.\n         *    </li>\n         * </ol>\n         *\n         *  <strong>Some key data indicated in the response markup on this call:</strong>\n         *\n         * <ol>\n         *    <li>code - indicates the code that has been executed</li>\n         *    <li>\n         *       console - indicates the console output resulting from the code\n         *       execution\n         *    </li>\n         *    <li>\n         *       results - indicates the list of files generated by the R graphics\n         *       device\n         *    </li>\n         *    <li>\n         *       artifacts - indicates the list of files generated or modified in the\n         *       working directory\n         *    </li>\n         *    <li>\n         *       objects -  indicates the list of R objects returned from the\n         *       workspace\n         *    </li>\n         *    <li>\n         *       files - indicates the list of files and objects stored in the\n         *       repository after the execution completes\n         *    </li>\n         *    <li>\n         *       interrupted - indicates the interrupted status of execution\n         *    </li>\n         *    <li>\n         *       error - on failure, indicates the reason for failure\n         *    </li>\n         *    <li>\n         *       errorCode - on failure, indicates the error code for failure\n         *    </li>\n         * </ol>\n         *\n         * @method projectExecuteCode\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>code</dt>\n         *    <dd>specifies the block of R code</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded script inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *\n         *    <dt>preloadfileversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *\n         *    <dt>preloadobjectname</dt>\n         *    <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *\n         *    <dt>adoptworkspace</dt>\n         *    <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *\n         *    <dt>adoptdirectory</dt>\n         *    <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *\n         *    <dt>adoptpackages</dt>\n         *    <dd>(optional) identifies project from which package dependencies are to be adopted</dd>\n         *\n         *    <dt>tag</dt>\n         *    <dd>(optional) specifies a tag that labels the execution</dd>\n         *\n         *    <dt>echooff</dt>\n         *    <dd>(optional) if true R commands will not appear in the console output</dd>\n         *\n         *    <dt>consoleoff</dt>\n         *    <dd>(optional) if true console output is not returned in the response markup</dd>\n         *\n         *      <dt>graphics</dt>\n         *      <dd>(optional) specifies preferred R graphics device for execution: png or svg</dd>\n         *\n         *      <dt>graphicswidth</dt>\n         *      <dd>(optional) specifies preferred width for R graphics device images</dd>\n         *\n         *      <dt>graphicsheight</dt>\n         *      <dd>(optional) specifies preferred height for R graphics device images</dd>\n         *\n         *      <dt>robjects</dt>\n         *      <dd>(optional) specifies a comma-separated list of objects for retrieval following the execution</dd>\n         *\n         *      <dt>storefile</dt>\n         *      <dd>(optional) comma-separated list of working directory filenames</dd>\n         *\n         *      <dt>storeobject</dt>\n         *      <dd>(optional) comma-separated list of workspace object names</dd>\n         *\n         *      <dt>storeworkspace</dt>\n         *      <dd>(optional) filename (.rData) where workspace contents will be saved in the repository</dd>\n         *\n         *      <dt>storenewversion</dt>\n         *      <dd>(optional) if <code>true</code>, ensures each file stored in\n         *    repository results in new version being created if needed</dd>\n         *\n         *      <dt>storepublic</dt>\n         *      <dd>(optional) if <code>true</code>, publishes each file stored in the repository</dd>\n         *\n         *      <dt>infinity</dt>\n         *      <dd>(optional) specifies custom value for Infinity appearing in R object\n         *    data returned on call, otherwise Infinity is represented by <code>0x7ff0000000000000L</code>\n         *    </dd>\n         *\n         *      <dt>nan</dt>\n         *      <dd>(optional) specifies custom value for NaN appearing in R object data\n         *    returned on call, otherwise NaN is represented by <code>null</code></dd>\n         *\n         *      <dt>encodeDataFramePrimitiveAsVector</dt>\n         *      <dd>(optional) if <code>true</code>, data.frame primitives are encoded vectors in R object data returned on call</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteCode: function(config, callback) {           \n            return this.io('/r/project/execute/code', config, callback);\n        },\n        /**\n         * This call executes executes repository-managed scripts or external scripts\n         * on the R session identified by the project parameter.\n         *\n         * To execute a single repository-managed script the caller must provide\n         * parameter values for filename, author and optionally version. To execute\n         * a chain of repository-managed scripts the caller must provide a\n         * comma-separated list of values on the filename , author and optionally\n         * version parameters.\n         *\n         * To execute a single external script the caller must provide a valid URL or\n         * file path using the externalsource parameter. To execute a chain of\n         * external scripts the caller must provide a comma-separated list of values\n         * on the externalsource parameter. Note, to execute an external script the\n         * caller must have POWER_USER privileges.\n         *\n         * Note: A chained execution executes each of the scripts identified on the\n         * call in a sequential fashion on the R session, with execution occuring in\n         * the order specified on the parameter list.\n         *\n         * Please not the following pre and post execution parameters:\n         *\n         * <strong>Pre-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The inputs parameter allows the caller to pass RevoDeployR-encoded\n         *       R object values as inputs. These inputs are turned into R objects\n         *       in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadfile parameters allows the caller to load one or more\n         *       files from the repository into the working directory before the\n         *       execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadobject parameters allow the caller to load one or more\n         *       binary R objects (.rData) from the repository into the workspace\n         *       before the execution begins.\n         *    </li>\n         *    <li>\n         *       The adopt parameters allow the caller to load a pre-existing\n         *       project workspace, project working directory and/or project package\n         *       dependencies before the execution begins.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Post-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The robjects parameter allows the caller to specify a comma-separated\n         *       list of object names that will be returned as RevoDeployR-encoded R\n         *       objects on the response markup after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storefile parameter allows the caller specify a comma-separated\n         *       list of working directory files to be stored in the repository after\n         *       the execution completes.\n         *    </li>\n         *    <li>\n         *       The storeobject parameter allows the caller specify a comma-separated\n         *       list of workspace objects to be stored in the repository after the\n         *       execution completes.\n         *    </li>\n         *    <li>\n         *       The storeworkspace parameter allows the caller to store the entire\n         *       workspace in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storedirectory parameter allows the caller to specify a target\n         *       repository directory for stored files and objects after the execution\n         *       completes.\n         *    </li>\n         *    <li>\n         *       The storenewversion parameter allows the caller to create new\n         *       versions of each stored file in the repository after the execution\n         *       completes. By default, stored files overwrite any pre-existing file\n         *       by the same name.\n         *    </li>\n         *    <li>\n         *       The storepublic parameter allows the caller to assign public access\n         *       to each stored file in the repository after the execution completes.\n         *    </li>\n         * </ol>\n         *\n         * <strong>\n         *    Some of the key data indicated in the response markup on this call\n         *    include:\n         * </strong>\n         *\n         * <ol>\n         *    <li>\n         *       console - indicates the console output resulting from the script\n         *       execution\n         *    </li>\n         *    <li>\n         *       results - indicates the list of files generated by the R graphics\n         *       device\n         *    </li>\n         *    <li>\n         *       artifacts - indicates the list of files generated or modified in the\n         *       working directory\n         *    </li>\n         *    <li>\n         *       objects - indicates the list of R objects returned from the workspace\n         *    </li>\n         *    <li>\n         *       files - indicates the list of files and objects stored in the\n         *       repository after the execution completes\n         *    </li>\n         *    <li>interrupted - indicates the interrupted status of execution</li>\n         *    <li>error - on failure, indicates the reason for failure</li>\n         *    <li>errorCode - on failure, indicates the error code for failure</li>\n         * </ol>\n         *\n         * @method projectExecuteScript\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         *  <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>(optional) comma-separated list of repository-managed script filenames</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) comma-separated list of repository-managed directories for\n         *       scripts, defaults to root\n         *    </dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-filename</dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-filename</dd>\n         *\n         *    <dt>externalsource</dt>\n         *    <dd>(optional) comma-separated list of URLs or file paths to external scripts</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded script inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *\n         *    <dt>preloadfileversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *\n         *    <dt>preloadobjectname</dt>\n         *    <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *\n         *    <dt>adoptworkspace</dt>\n         *    <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *\n         *    <dt>adoptdirectory</dt>\n         *    <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *\n         *    <dd>adoptpackages</dd>\n         *    <dt>(optional) identifies project from which package dependencies are to be adopted</dt>\n         *\n         *    <dt>tag</dt>\n         *    <dd>(optional) specifies a tag that labels the execution</dd>\n         *\n         *    <dt>echooff</dt>\n         *    <dd>(optional) if true R commands will not appear in the console output</dd>\n         *\n         *    <dt>graphics</dt>\n         *    <dd>(optional) specifies preferred R graphics device for execution: png or svg</dd>\n         *\n         *    <dt>graphicswidth</dt>\n         *    <dd>(optional) specifies preferred width for R graphics device images</dd>\n         *\n         *    <dt>graphicsheight</dt>\n         *    <dd>(optional) specifies preferred height for R graphics device images</dd>\n         *\n         *    <dt>robjects</dt>\n         *    <dd>(optional) specifies a comma-separated list of objects for retrieval following the execution</dd>\n         *\n         *    <dt>storefile</dt>\n         *    <dd>(optional) comma-separated list of working directory filenames</dd>\n         *\n         *    <dt>storeobject</dt>\n         *    <dd>(optional) comma-separated list of workspace object names</dd>\n         *\n         *    <dt>storeworkspace</dt>\n         *    <dd>(optional) filename (.rData) where workspace contents will be saved in the repository</dd>\n         *\n         *    <dt>storenewversion</dt>\n         *    <dd>(optional) if <code>true</code>, ensures each file stored in repository results in new version being created if needed</dd>\n         *\n         *    <dt>storepublic</dt>\n         *    <dd>(optional) if <code>true</code>, publishes each file stored in the repository</dd>\n         *\n         *    <dt>infinity</dt>\n         *    <dd>(optional) specifies custom value for Infinity appearing in R object data returned on call, otherwise Infinity is represented by <code>0x7ff0000000000000L</code></dd>\n         *\n         *    <dt>nan</dt>\n         *    <dd>(optional) specifies custom value for NaN appearing in R object data returned on call, otherwise NaN is represented by <code>null</code></dd>\n         *\n         *    <dt>encodeDataFramePrimitiveAsVector</dt>\n         *    <dd>(optional) if <code>true</code>, data.frame primitives are encoded vectors in R object data returned on call</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteScript: function(config, callback) {            \n            return this.io('/r/project/execute/script', config, callback);\n        },\n\n        /**\n         * This call interrupts the current execution on specified project.\n         *\n         * @method projectExecuteInterrupt\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         *  <dl>\n         *      <dt>project</dt>\n         *      <dd>specifies the project identifier</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteInterrupt: function(config, callback) {\n            return this.io('/r/project/execute/interrupt', config, callback);\n        },\n\n        /**\n         * This call retrieves the R console output for the latest execution on\n         * specified project.\n         *\n         * @method projectExecuteConsole\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         *  <dl>\n         *    <dt>project</dt>\n         *      <dd>specifies the project identifier</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteConsole: function(config, callback) {\n            return this.io('/r/project/execute/console', config, callback);\n        },\n\n        /**\n         * This call retrieves the execution history for the specified project.\n         *\n         * Some of the key data indicated for each history item in the response markup\n         * on this call include:\n         *\n         * <ol>\n         *  <li>code - indicates the code that has been executed</li>\n         *  <li>console - indicates the console output resulting from the code execution</li>\n         *  <li>resultsGenerated - indicates the number of generated results on the execution</li>\n         *  <li>resultsAvailable - indicates the number of generated results still stored on the execution</li>\n         *  <li>resourceUsage - indicates the current storage byte count for results on the execution</li>\n         *  <li>execution - indicates the execution identifier, which can then be used on /r/project/execution/result calls to retrieve or manage results</li>\n         *  <li>interrupted - indicates the interrupted status of execution</li>\n         *  <li>error - on failure, indicates the reason for failure</li>\n         *  <li>errorCode - on failure, indicates the error code for failure</li>\n         * </ol>\n         * @method projectExecuteHistory\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filterdepth</dt>\n         *    <dd>specifies the max number of executions to be returned in the history</dd>\n         *\n         *    <dt>execution</dt>\n         *    <dd>(optional) specifies the comma-separated list of execution identifiers on which to filter history</dd>\n         *\n         *    <dt>filtertag</dt>\n         *    <dd>(optional) specifies the execution tag on which to filter history</dd>\n         *\n         *    <dt>reversed</dt>\n         *    <dd>\n         *       (optional) if true, the execution history is returned in a\n         *       reverse-chronological order\n         *    </dt>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteHistory: function(config, callback) {\n            return this.io('/r/project/execute/history', config, callback);\n        },\n\n        /**\n         * This call flushes executions in the history on the specified project.\n         * Flushing an execution deletes both the R console output and the generated\n         * results associated with that execution but does not remove the execution\n         * itself from the history. By omitting the execution parameter, the caller\n         * can flush every execution in the history on the specified project.\n         *\n         * This flushing facility is provided to help users manage the levels of\n         * resource usage associated with their persistent projects.\n         *\n         * @method projectExecuteFlush\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         *  <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>execution</dt>\n         *    <dd>(optional) comma-separated list of execution identifiers</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteFlush: function(config, callback) {\n            return this.io('/r/project/execute/flush', config, callback);\n        },\n\n        /**\n         * This call lists the execution results for the specified project.\n         *\n         * By specifying a value for the execution parameter the caller can limit the\n         * response to those results found on a specific execution or set of\n         * executions.\n         *\n         * <blockquote>\n         *    Important! The URLs indicated in the response markup on this call remain\n         *    valid for as long as the results remain part of the project.\n         * </blockquote>\n         *\n         * @method projectExecuteResultList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>execution</dt>\n         *    <dd>\n         *       (optional) specifies a comma-separated list of execution identifiers\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteResultList: function(config, callback) {\n            return this.io('/r/project/execute/result/list', config, callback);\n        },\n\n        /**\n         * This call downloads the execution results for the specified project.\n         *\n         * By specifying a value for the execution parameter the caller can download\n         * only results on the specified executions. By specifying a value for the\n         * filename parameter the caller can download a specific result on the\n         * specified execution.\n         *\n         * @method projectExecuteResultDownload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>execution</dt>\n         *    <dd>\n         *       (optional) specifies a comma-separated list of execution identifiers\n         *    </dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>(optional) specifies a result file name</dd>\n         *\n         *    <dt>inline</dt>\n         *    <dd>\n         *       (optional) if true, the Content-Disposition response header\n         *       indicating attachment is omitted\n         *    </dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteResultDownload: function(config, callback) {\n            return this.io('/r/project/execute/result/download', config, callback);\n        },\n\n        /**\n         * This call deletes the execution results for the specified project.\n         *\n         * By specifying a value for the execution parameter the caller can delete\n         * only those results on the specified executions. By specifying a value for\n         * the filename parameter the caller can delete a specific result on the\n         * specified executions.\n         *\n         * @method projectExecuteResultDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *   <dt>project</dt>\n         *   <dd>specifies the project identifier</dd>\n         *\n         *   <dt>execution</dt>\n         *   <dd>\n         *      (optional) specifies a comma-separated list of execution identifiers\n         *   </dd>\n         *\n         *   <dt>filename</dt>\n         *   <dd>(optional) specifies a result file name</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectExecuteResultDelete: function(config, callback) {\n            return this.io('/r/project/execute/result/delete', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Project Directory APIs\n        /////////////////////////////////////\n\n        /**\n         * This call lists working directory files for the specified project.\n         *\n         * The filter parameter can be specified on the call to filter, the types of\n         * files returned according to their category. The following filter values are\n         * supported:\n         *\n         * <ol>\n         *    <li>plot - files ending with a .png, .svg or .jpg extension</li>\n         *    <li>script - files ending with a .R or .r extension</li>\n         *    <li>R - files ending with a .rData or .rdata extension</li>\n         *    <li>data - files ending with a .csv or .xls extension</li>\n         *    <li>text - files ending with a .txt extension</li>\n         * </ol>\n         *\n         * @method projectDirectoryList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filter</dt>\n         *    <dd>(optional) specifies the filter by category value</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryList: function(config, callback) {\n            return this.io('/r/project/directory/list', config, callback);\n        },\n\n        /**\n         * This call uploads a file into the working directory for the specified\n         * project.\n         *\n         * @method projectDirectoryUpload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>specifies the name of the file</dd>\n         *\n         *    <dt>file</dt>\n         *    <dd>...file content...</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies the description to be associated with file</dd>\n         *\n         *    <dt>overwrite</dt>\n         *    <dd>(optional) if true, overwrites the existing file of same name</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryUpload: function(config, callback) {\n            config.format = \"text\";\n            var ioConfig = {\n                data: config,\n                method: \"POST\",\n                form: {\n                    id: config.formId\n                },\n                on: callback\n            };\n            return this.io('/r/project/directory/upload', config, callback);\n        },\n\n        /**\n         * This call transfers a file from a URL into the working directory for the\n         * specified project.\n         *\n         * @method projectDirectoryTransfer\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>specifies the name of the file</dd>\n         *\n         *    <dt>url</dt>\n         *    <dd>specifies the URL for the file</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies the description to be associated with file</dd>\n         *\n         *    <dt>overwrite</dt>\n         *    <dd>(optional) if true, overwrites the existing file of same name</dd>\n         *  </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryTransfer: function(config, callback) {\n            return this.io('/r/project/directory/transfer', config, callback);\n        },\n\n        /**\n         * This call writes a text file into the working directory for the specified\n         * project.\n         *\n         * @method projectDirectoryWrite\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>specifies the name of the file</dd>\n         *\n         *    <dt>text</dt>\n         *    <dd>specifies the text content for the file</dd>\n         *\n         *    <dt>delimiter</dt>\n         *    <dd>\n         *       (optional) specifies a custom delimiter for text when writing\n         *       multiple files, defaults to #,#\n         *    </dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies the description to be associated with file</dd>\n         *\n         *    <dt>overwrite</dt>\n         *    <dd>(optional) if true, overwrites the existing file of same name</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryWrite: function(config, callback) {\n            return this.io('/r/project/directory/write', config, callback);\n        },\n\n        /** \n         * This call updates a file name and/or description in the working directory\n         * for the specified project.\n         *\n         * @method projectDirectoryUpdate\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>specifies the name of the file</dd>\n         *\n         *    <dt>rename</dt>\n         *    <dd>(optional) specifies the new name for the file</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifices the new description for the file</dd>\n         *\n         *    <dt>overwrite</dt>\n         *    <dd>(optional) if true, overwrites the existing file of same name</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryUpdate: function(config, callback) {\n            return this.io('/r/project/directory/update', config, callback);\n        },\n\n        /**\n         * This call stores a file from the working directory to the repository.\n         *\n         * @method projectDirectoryStore\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>(optional) specifies the file for storing</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies a description to accompany the saved file</dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>\n         *       (optional) specifies tag words to associate with repository file\n         *    </dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *        (optional) comma-separated list of role names, which makes the file\n         *        visible to authenticated users with these roles\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if true, the file will be shared , which makes the file\n         *       visible to authenticated users\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if true, the file will be published , which makes the\n         *       file visible to authenticated and anonymous users\n         *    </dd>\n         *\n         *    <dt>newversion</dt>\n         *    <dd>\n         *       (optional) if true, the new file will be renamed to avoid overwriting\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryStore: function(config, callback) {\n            return this.io('/r/project/directory/store', config, callback);\n        },\n\n        /**\n         * This call loads a file from the repository into the working directory for\n         * the specified project.\n         *\n         * @method projectDirectoryLoad\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>specifies the repository file name</dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>specifies the author name</dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>(optional) specifies the repository file version</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryLoad: function(config, callback) {\n            return this.io('/r/project/directory/load', config, callback);\n        },\n\n        /**\n         * This call downloads the working directory contents for the specified\n         * project.\n         *\n         * By specifying a single value for the filename parameter, the caller can\n         * download a specific file. By specifying multiple values for the filename\n         * parameter, the caller can download a zip archive of those files. By\n         * omitting the filename parameter, then the caller can download a zip archive\n         * with all of the files in the working directory.\n         *\n         * @method projectDirectoryDownload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>(optional) specifies comma-separated file names for download</dd>\n         *\n         *    <dt>inline</dt>\n         *    <dd>\n         *       (optional) if true, the Content-Disposition response header\n         *       indicating attachment is omitted\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryDownload: function(config, callback) {\n            return this.io('/r/project/directory/download', config, callback);\n        },\n\n        /**\n         * This call deletes files from the working directory for the specified\n         * project.\n         *\n         * @method projectDirectoryDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>specifies a comma-separated list of file names for deletion</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectDirectoryDelete: function(config, callback) {\n            return this.io('/r/project/directory/delete', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Project Package APIs\n        /////////////////////////////////////\n\n        /**\n         * This call lists R package dependencies for the specified project.\n         *\n         * @method projectPackageList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>installed</dt>\n         *    <dd>\n         *       if true, response lists all packages installed in project environment\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectPackageList: function(config, callback) {\n            return this.io('/r/project/package/list', config, callback);\n        },\n\n        /**\n         * This call attaches R package dependencies for the specified project.\n         *\n         * @method projectPackageAttach\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies a comma-separated list of R package names to attach</dd>\n         *\n         *    <dt>repo</dt>\n         *    <dd>(optional) specifies R repository location for named packages</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectPackageAttach: function(config, callback) {\n            return this.io('/r/project/package/attach', config, callback);\n        },\n\n        /**\n         * This call detaches R package dependencies for the specified project.\n         *\n         * @method projectPackageDetach\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>name</dt>\n         *    <dd>specifies a comma-separated list of R package names to detach</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        projectPackageDetach: function(config, callback) {\n            return this.io('/r/project/package/detach', config, callback);\n        },\n\n        /////////////////////////////////////\n        // User APIs\n        /////////////////////////////////////\n\n        /**\n         * This call signs the user in by authenticating the credentials with the\n         * RevoDeployR server.\n         *\n         * @method userLogin\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>username</dt>\n         *    <dd>specifies the username</dd>\n         *\n         *    <dt>password</dt>\n         *    <dd>specifies the password</dd>\n         *\n         *    <dt>disableautosave</dt>\n         *    <dd>\n         *       (optional) when true, disables autosave semantics for persistent\n         *       projects\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        userLogin: function(config, callback) {\n            return this.io('/r/user/login', config, callback);            \n        },\n\n        /**\n         * This call signs out the currently authenticated user.\n         *\n         * @method userLogout\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>usercookie</dt>\n         *    <dd>\n         *       (optional) when specified, value sets application-specific persistent\n         *       user cookie, which is retrievable on response to\n         *       <a href=\"#method_userLogin\">userLogin</a> call.\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        userLogout: function(config, callback) {\n            return this.io('/r/user/logout', config, callback);            \n        },\n\n        /**\n         * This call retrieves details about the currently authenticated user. The\n         * details returned in the response markup on this call are exactly the same\n         * details as those returned in the response markup on the\n         * <a href=\"#method_userLogin\">userLogin</a> call.\n         *\n         * @method userAbout\n         * @static\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        userAbout: function(callback) {            \n            return this.io('/r/user/about', {}, callback);\n        },\n\n        /**\n         * This call enables or disables the autosave semantics on persistent projects\n         * for the duration of the current users HTTP session. By default, all live\n         * persistent projects are autosaved under the following conditions:\n         *\n         * <ul>\n         *    <li>\n         *       When a user closes a project using the\n         *       <a href=\"#method_projectClose\">projectClose</a> call.\n         *    </li>\n         *    <li>\n         *       When a user signs-out using the\n         *       <a href=\"#method_userLogout\">userLogout</a> call.\n         *    </li>\n         *    <li>\n         *       When a user is automatically signed-out by the system after a\n         *       prolonged period of inactivity.\n         *    </li>\n         * </ul>\n         *\n         * When the autosave feature is disabled a user must make an explicit call on\n         * <a href=\"#method_projectSave\">projectSave</a> in order to save a project.\n         *\n         * @method userAutosave\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>enable</dt>\n         *    <dd>(optional) toggles autosave semantics for persistent projects.</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        userAutosave: function(config, callback) {\n            return this.io('/r/user/autosave', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Repository Script APIs\n        /////////////////////////////////////\n\n        /**\n         * This call lists repository-managed scripts.\n         *\n         * This call is available to authenticated and anonymous users. However, if\n         * the caller is an anonymous user then only published scripts will be\n         * returned in the response markup.\n         *\n         * @method repositoryScriptList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) when specified, call returns list of script versions for\n         *       filename\n         *   </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files that are restricted but\n         *       visible or shared by other users are included in the response markup\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, scripts published by other users are\n         *       included in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryScriptList: function(callback) {            \n            return this.io('/r/repository/script/list', {}, callback);\n        },\n        /**\n         * This call executes repository-managed scripts or external scripts on an\n         * Anonymous Project.\n         *\n         * To execute a single repository-managed script the caller must provide\n         * parameter values for filename, author and optionally version. To execute a\n         * chain of repository-managed scripts the caller must provide a\n         * comma-separated list of values on the filename , author and optionally\n         * version parameters.\n         *\n         * To execute a single external script the caller must provide a valid URL\n         * or file path using the externalsource parameter. To execute a chain of\n         * external scripts the caller must provide a comma-separated list of\n         * values on the externalsource parameter. Note, to execute an external script\n         * the caller must have POWER_USER privileges so this feature is not available\n         * to anonymous users on this call.\n         *\n         * Note: A chained execution executes each of the scripts identified on the\n         * call in a sequential fashion on the R session, with execution occuring in\n         * the order specified on the parameter list.\n         *\n         * <strong>Pre-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The inputs parameter allows the caller to pass RevoDeployR-encoded\n         *       R object values as inputs. These inputs are turned into R objects\n         *       in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadfile parameters allows the caller to load one or more\n         *       files from the repository into the working directory before the\n         *       execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadobject parameters allow the caller to load one or more\n         *       binary R objects (.rData) from the repository into the workspace\n         *       before the execution begins.\n         *    </li>\n         *    <li>\n         *       The adopt parameters allow the caller to load a pre-existing\n         *       project workspace, project working directory and/or project package\n         *       dependencies before the execution begins.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Post-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The robjects parameter allows the caller to specify a comma-separated\n         *       list of object names that will be returned as RevoDeployR-encoded R\n         *       objects on the response markup after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storefile parameter allows the caller specify a comma-separated\n         *       list of working directory files to be stored in the repository after\n         *       the execution completes.\n         *    </li>\n         *    <li>\n         *       The storeobject parameter allows the caller specify a comma-separated\n         *       list of workspace objects to be stored in the repository after the\n         *       execution completes.\n         *    </li>\n         *    <li>\n         *       The storeworkspace parameter allows the caller to store the entire\n         *       workspace in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storedirectory parameter allows the caller to specify a target\n         *       repository directory for stored files and objects after the execution\n         *       completes.\n         *    </li>\n         *    <li>\n         *       The storenewversion parameter allows the caller to create new\n         *       versions of each stored file in the repository after the execution\n         *       completes. By default, stored files overwrite any pre-existing file\n         *       by the same name.\n         *    </li>\n         *    <li>\n         *       The storepublic parameter allows the caller to assign public access\n         *       to each stored file in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The infinity , nan and encodeDataFramePrimitiveAsVector parameters\n         *       allow the caller to control how RevoDeployR-encoded R object data is\n         *       encoded in the response markkup.\n         *    </li>\n         * </ol>\n         *\n         *  <strong>\n         *     Some key data indicated in the response markup on this call:\n         *  </strong>\n         *\n         *  <ol>\n         *    <li>\n         *       console - indicates the console output resulting from the code\n         *       execution\n         *    </li>\n         *    <li>\n         *       results - indicates the list of files generated by the R graphics\n         *       device\n         *    </li>\n         *    <li>\n         *       artifacts - indicates the list of files generated or modified in the\n         *       working directory\n         *    </li>\n         *    <li>\n         *       objects -  indicates the list of R objects returned from the\n         *       workspace\n         *    </li>\n         *    <li>\n         *       files - indicates the list of files and objects stored in the\n         *       repository after the execution completes\n         *    </li>\n         *    <li>interrupted - indicates the interrupted status of execution</li>\n         *    <li>error - on failure, indicates the reason for failure</li>\n         *    <li>errorCode - on failure, indicates the error code for failure</li>\n         * </ol>\n         * @method repositoryScriptExecute\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>comma-separated list of repository-managed script filenames</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) comma-separated list of repository-managed directories for\n         *       scripts, defaults to root\n         *    </dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-filename</dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-filename</dd>\n         *\n         *    <dt>externalsource</dt>\n         *    <dd>(optional) comma-separated list of URLs or file paths to external scripts</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded script inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *\n         *    <dt>preloadfileversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *\n         *    <dt>preloadobjectname</dt>\n         *    <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *\n         *    <dt>adoptworkspace</dt>\n         *    <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *\n         *    <dt>adoptdirectory</dt>\n         *    <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *\n         *    <dt>adoptpackages</dt>\n         *    <dd>(optional) identifies project from which package dependencies are to be adopted</dd>\n         *\n         *    <dt>blackbox</dt>\n         *      <dd>\n         *       (optional) if true, the execution will occur on the HTTP blackbox\n         *       project for the current HTTP session\n         *    </dd>\n         *\n         *      <dt>recycle</dt>\n         *      <dd>\n         *       (optional) if true, recycles the R session associated with the HTTP\n         *       blackbox project on the current HTTP session\n         *    </dd>\n         *\n         *    <dt>tag</dt>\n         *    <dd>(optional) specifies a tag that labels the execution</dd>\n         *\n         *    <dt>echooff</dt>\n         *    <dd>(optional) </dd>\n         *\n         *    <dt>graphics</dt>\n         *    <dd>(optional) specifies preferred R graphics device for execution: png or svg</dd>\n         *\n         *    <dt>graphicswidth</dt>\n         *    <dd>(optional) specifies preferred width for R graphics device images</dd>\n         *\n         *    <dt>graphicsheight</dt>\n         *    <dd>(optional) specifies preferred height for R graphics device images</dd>\n         *\n         *    <dt>robjects</dt>\n         *    <dd>(optional) specifies a comma-separated list of objects for retrieval following the execution</dd>\n         *\n         *    <dt>storefile</dt>\n         *    <dd>(optional) comma-separated list of working directory filenames</dd>\n         *\n         *    <dt>storeobject</dt>\n         *    <dd>(optional) comma-separated list of workspace object names</dd>\n         *\n         *    <dt>storeworkspace</dt>\n         *    <dd>(optional) filename (.rData) where workspace contents will be saved in the repository</dd>\n         *\n         *    <dt>storenewversion</dt>\n         *    <dd>(optional) if <code>true</code>, ensures each file stored in repository results in new version being created if needed</dd>\n         *\n         *    <dt>storepublic</dt>\n         *    <dd>(optional) if <code>true</code>, publishes each file stored in the repository</dd>\n         *\n         *    <dt>infinity</dt>\n         *    <dd>\n         *       (optional) specifies custom value for Infinity appearing in R object\n         *       data returned on call, otherwise Infinity is represented by\n         *       <code>0x7ff0000000000000L</code>\n         *    </dd>\n         *\n         *    <dt>nan</dt>\n         *    <dd>\n         *       (optional) specifies custom value for NaN appearing in R object data\n         *       returned on call, otherwise NaN is represented by <code>null</code>\n         *    </dd>\n         *\n         *    <dt>encodeDataFramePrimitiveAsVector</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, data.frame primitives are encoded\n         *       vectors in R object data returned on call\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryScriptExecute: function(config, callback) {            \n            return this.io('/r/repository/script/execute', config, callback);\n        },\n\n\n        /**\n         * This call executes repository-managed scripts or external scripts on an\n         * Anonymous Project and returns a simple HTML page that displays the results\n         * generated on the execution.\n         *\n         * On a successful execution, the HTML page will display the following data\n         * when available on the response:\n         *\n         * <ul>\n         *    <li>R console output</li>\n         *    <li>R workspace object data</li>\n         *    <li>R generated plots</li>\n         *    <li>Links to R working directory artifacts</li>\n         *    <li>Links to Repository stored artifacts</li>\n         * </ul>\n         *\n         * On a failed execution, the HTML page will display an error message\n         * indicating the cause of the failure and when available, R console output.\n         *\n         * The API call makes it very simple to integrate outputs generated by\n         * RevoDeployR-managed R scripts into any third-party application. It can also\n         * be used as a very simple test and debugging aid for R script and\n         * application developers.\n         *\n         * To execute a single repository-managed script the caller must provide\n         * parameter values for filename , author and optionally version . To execute\n         * a chain of repository-managed scripts the caller must provide a\n         * comma-separated list of values on the filename , author and optionally\n         * version parameters.\n         *\n         * To execute a single external script the caller must provide a valid URL or\n         * file path using the externalsource parameter. To execute a chain of\n         * external scripts the caller must provide a comma-separated list of values\n         * on the externalsource parameter. Note, to execute an external script the\n         * caller must have POWER_USER privileges so this feature is not available to\n         * anonymous users on this call.\n         *\n         * Note: A chained execution executes each of the scripts identified on the\n         * call in a sequential fashion on the R session, with execution occuring in\n         * the order specified on the parameter list.\n         *\n         * Please note the following pre and post execution parameters:\n         *\n         * <strong>Pre-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The inputs parameter allows the caller to pass RevoDeployR-encoded\n         *       R object values as inputs. These inputs are turned into R objects\n         *       in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The csvinputs parameter allows the caller to pass R object primitive\n         *       values as comma-separated name/value pairs. These inputs are turned\n         *       into R objects in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadfile parameters allows the caller to load one or more\n         *       files from the repository into the working directory before the\n         *       execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadobject parameters allow the caller to load one or more\n         *       binary R objects (.rData) from the repository into the workspace\n         *       before the execution begins.\n         *    </li>\n         *    <li>\n         *       The adopt parameters allow the caller to load a pre-existing\n         *       project workspace, project working directory and/or project package\n         *       dependencies before the execution begins.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Post-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The robjects parameter allows the caller to specify a comma-separated\n         *       list of object names that will be returned as RevoDeployR-encoded R\n         *       objects on the response markup after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storefile parameter allows the caller to specify a comma-separated\n         *       list of working directory files to be stored in the repository after\n         *       the execution completes.\n         *    </li>\n         *    <li>\n         *       The storeobject parameter allows the caller to specify a comma-separated\n         *       list of workspace objects to be stored in the repository after the\n         *       execution completes.\n         *    </li>\n         *    <li>\n         *       The storeworkspace parameter allows the caller to store the entire\n         *       workspace in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storedirectory parameter allows the caller to specify a target\n         *       repository directory for stored files and objects after the execution\n         *       completes.\n         *    </li>\n         *    <li>\n         *       The storenewversion parameter allows the caller to create new\n         *       versions of each stored file in the repository after the execution\n         *       completes. By default, stored files overwrite any pre-existing file\n         *       by the same name.\n         *    </li>\n         *    <li>\n         *       The storepublic parameter allows the caller to assign public access\n         *       to each stored file in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *      The infinity , nan and encodeDataFramePrimitiveAsVector parameters\n         *      allow the caller to control how RevoDeployR-encoded R object data is\n         *      encoded in the response markkup.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Some key data indicated in the response markup on this call:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       console - indicates the R console output resulting from the execution\n         *    </li>\n         *    <li>\n         *       results - indicates the list of files generated by the R graphics\n         *       device\n         *    </li>\n         *    <li>\n         *       artifacts - indicates the list of files generated or modified in the\n         *       working directory\n         *    </li>\n         *    <li>\n         *       objects -  indicates the list of R objects returned from the\n         *       workspace\n         *    </li>\n         *    <li>\n         *       files - indicates the list of files and objects stored in the\n         *       repository after the execution completes\n         *    </li>\n         *    <li>\n         *       interrupted - indicates the interrupted status of execution\n         *    </li>\n         *    <li>\n         *       error - on failure, indicates the reason for failure\n         *    </li>\n         *    <li>\n         *       errorCode - on failure, indicates the error code for failure\n         *    </li>\n         * </ol>\n         *\n         * @method repositoryScriptRender\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>project</dt>\n         *    <dd>specifies the project identifier</dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of repository-managed script\n         *       filenames\n         *    </dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) comma-separated list of repository-managed directories for\n         *       scripts, defaults to root\n         *    </dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>\n         *       (optional) comma-separated list of authors, one author per filename\n         *    </dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>\n         *       (optional) comma-separated list of versions, one version per filename\n         *    </dd>\n         *\n         *    <dt>externalsource</dt>\n         *    <dd>\n         *       (optional) comma-separated list of URLs or file paths to external\n         *       scripts\n         *    </dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded script inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *\n         *    <dt>preloadfileversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *\n         *    <dt>preloadobjectname</dt>\n         *    <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *\n         *    <dt>adoptworkspace</dt>\n         *    <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *\n         *    <dt>adoptdirectory</dt>\n         *    <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *\n         *    <dt>adoptpackages</dt>\n         *    <dd>(optional) identifies project from which package dependencies are to be adopted</dd>\n         *\n         *      <dt>blackbox</dt>\n         *      <dd>(optional) if true, the execution will occur on the HTTP blackbox project for the current HTTP session</dd>\n         *\n         *      <dt>recycle</dt>\n         *      <dd>(optional) if true, recycles the R session associated with the HTTP blackbox project on the current HTTP session</dd>\n         *\n         *    <dt>tag</dt>\n         *    <dd>(optional) specifies a tag that labels the execution</dd>\n         *\n         *    <dt>echooff</dt>\n         *    <dd>(optional) if true R commands will not appear in the console output</dd>\n         *\n         *    <dt>consoleoff</dt>\n         *    <dd>(optional) if true console output is not returned in the response markup</dd>\n         *\n         *    <dt>graphics</dt>\n         *    <dd>(optional) specifies preferred R graphics device for execution: png or svg</dd>\n         *\n         *    <dt>graphicswidth</dt>\n         *    <dd>(optional) specifies preferred width for R graphics device images</dd>\n         *\n         *    <dt>graphicsheight</dt>\n         *    <dd>(optional) specifies preferred height for R graphics device images</dd>\n         *\n         *    <dt>robjects</dt>\n         *    <dd>(optional) specifies a comma-separated list of objects for retrieval following the execution</dd>\n         *\n         *    <dt>storefile</dt>\n         *    <dd>(optional) comma-separated list of working directory filenames</dd>\n         *\n         *    <dt>storeobject</dt>\n         *    <dd>(optional) comma-separated list of workspace object names</dd>\n         *\n         *    <dt>storeworkspace</dt>\n         *    <dd>(optional) filename (.rData) where workspace contents will be saved in the repository</dd>\n         *\n         *    <dt>storenewversion</dt>\n         *    <dd>(optional) if <code>true</code>, ensures each file stored in repository results in new version being created if needed</dd>\n         *\n         *    <dt>storepublic</dt>\n         *    <dd>(optional) if <code>true</code>, publishes each file stored in the repository</dd>\n         *\n         *    <dt>infinity</dt>\n         *    <dd>\n         *       (optional) specifies custom value for Infinity appearing in R object\n         *       data returned on call, otherwise Infinity is represented by\n         *       0x7ff0000000000000L\n         *    </dd>\n         *\n         *    <dt>nan</dt>\n         *    <dd>\n         *       (optional) specifies custom value for NaN appearing in R object data\n         *       returned on call, otherwise NaN is represented by null\n         *    </dd>\n         *\n         *    <dt>encodeDataFramePrimitiveAsVector</dt>\n         *    <dd>\n         *       (optional) if true, data.frame primitives are encoded vectors in R\n         *       object data returned on call\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryScriptRender: function(config, callback) {\n            return this.io('/r/repository/script/render', config, callback);\n        },\n\n        /**\n         * This call interrupts the current execution on the HTTP Blackbox project\n         * associated with the current HTTP session.\n         *\n         * @method repositoryScriptInterrupt\n         * @static\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryScriptInterrupt: function(callback) {            \n            return this.io('/r/repository/script/interrupt', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Repository File APIs\n        /////////////////////////////////////\n\n        /**\n         * This call lists repository-managed files.\n         *\n         * @method repositoryFiletList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) when specified, call returns list of script versions for\n         *       filename\n         *   </dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files that are restricted but\n         *       visible or shared by other users are included in the response markup\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, scripts published by other users are\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>categoryFilter</dt>\n         *    <dd>\n         *       (optional) when specified list of files in response markup is limited\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileList: function(config, callback) {            \n            return this.io('/r/repository/file/list', config, callback);\n        },\n        /**\n         * This call uploads a file from the user's computer to the repository.\n         *\n         * @method repositoryFileUpload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies name of the file to upload</dd>\n         *\n         *    <dt>file</dt>\n         *    <dd>...file content...</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies a description to associate with the uploaded file</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>(optional) specifies tag words to associate with the repository file</dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>(optional) (optional) comma-separated list of role names, which makes the file visible to authenticated users with these roles</dd>\n         *\n         *     <dt>shared</dt>\n         *     <dd>(optional) if true, the file will be shared which makes the file visible to authenticated users</dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>(optional) if true, the file will be published which makes the file visible to authenticated and anonymous users</dd>\n         *\n         *    <dt>newversion</dt>\n         *    <dd>(optional) if true, the repository will create new version rather than overwrite</dd>\n         *\n         *    <dt>newversionmsg</dt>\n         *    <dd>(optional) if newversion is true, message to associate with new version</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) specifies the inputs property on a repository-managed script</dd>\n         *\n         *    <dt>outputs</dt>\n         *    <dd>(optional) specifies the outputs property on a repository-managed script</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileUpload: function(config, callback) {\n            config.format = \"text\";\n            var ioConfig = {\n                data: config,\n                method: \"POST\",\n                form: {\n                    id: config.formId\n                },\n                on: callback\n            };\n            return this.io('/r/repository/file/upload', config, callback);\n        },\n\n        /**\n         * This call transfers a file from a URL to the repository.\n         *\n         * @method repositoryFileTransfer\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies name of the file to upload</dd>\n         *\n         *    <dt>url</dt>\n         *    <dd>specifies a url of the file to upload</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies a description to associate with the uploaded file</dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>(optional) specifies tag words to associate with the repository file</dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>(optional) (optional) comma-separated list of role names, which makes the file visible to authenticated users with these roles</dd>\n         *\n         *     <dt>shared</dt>\n         *     <dd>(optional) if true, the file will be shared which makes the file visible to authenticated users</dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>(optional) if true, the file will be published which makes the file visible to authenticated and anonymous users</dd>\n         *\n         *    <dt>newversion</dt>\n         *    <dd>(optional) if true, the repository will create new version rather than overwrite</dd>\n         *\n         *    <dt>newversionmsg</dt>\n         *    <dd>(optional) if newversion is true, message to associate with new version</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) specifies the inputs property on a repository-managed script</dd>\n         *\n         *    <dt>outputs</dt>\n         *    <dd>(optional) specifies the outputs property on a repository-managed script</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileTransfer: function(config, callback) {\n            return this.io('/r/repository/file/transfer', config, callback);\n        },\n\n        /**\n         * This call writes a text file to the repository.\n         *\n         * @method repositoryFileWrite\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies name of the file to upload</dd>\n         *\n         *    <dt>text</dt>\n         *    <dd>specifies the text content of the file to upload</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>\n         *       (optional) specifies a description to associate with the uploaded\n         *       file\n         *    </dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>\n         *       (optional) specifies tag words to associate with the repository file\n         *    </dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *       (optional) (optional) comma-separated list of role names, which makes\n         *       the file visible to authenticated users with these roles\n         *    </dd>\n         *\n         *    <dt>share</dt>\n         *    <dd>\n         *       (optional) if true, ile is shared and visible to authenticated users\n         *    </dd>\n         *\n         *    <dt>publish</dt>\n         *    <dd>\n         *       (optional) if true, the file will be published which makes the file\n         *       visible to authenticated and anonymous users\n         *    </dd>\n         *\n         *    <dt>newversion</dt>\n         *    <dd>\n         *       (optional) if true, the repository will create new version rather\n         *       than overwrite\n         *    </dd>\n         *\n         *    <dt>newversionmsg</dt>\n         *    <dd>\n         *       (optional) if newversion is true, message to associate with new\n         *       version\n         *    </dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>\n         *       (optional) specifies the inputs property on a repository-managed\n         *       script\n         *    </dd>\n         *\n         *    <dt>outputs</dt>\n         *    <dd>\n         *       (optional) specifies the outputs property on a repository-managed\n         *       script\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileWrite: function(config, callback) {\n            return this.io('/r/repository/file/write', config, callback);\n        },\n\n        /**\n         * This call updates the properties on a repository-managed file.\n         *\n         * @method repositoryFileUpdate\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies name of the file to upload</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies a description to associate with the uploaded file</dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>(optional) specifies tag words to associate with the repository file</dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *       (optional) (optional) comma-separated list of role names, which makes\n         *       the file visible to authenticated users with these roles\n         *    </dd>\n         *\n         *     <dt>shared</dt>\n         *     <dd>(optional) if true, the file will be shared which makes the file visible to authenticated users</dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>(optional) if true, the file will be published which makes the file visible to authenticated and anonymous users</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) specifies the inputs property on a repository-managed script</dd>\n         *\n         *    <dt>outputs</dt>\n         *    <dd>(optional) specifies the outputs property on a repository-managed script</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileUpdate: function(config, callback) {\n            return this.io('/r/repository/file/update', config, callback);\n        },\n\n        /**\n         * This call reverts the current working copy of a file to a specific version\n         * found in the files version history.\n         *\n         * @method repositoryFileRevert\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies name of the file to upload</dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>specifies the repository file version to revert into the current working copy</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) specifies a description to associate with the uploaded file</dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>(optional) (optional) comma-separated list of role names, which makes the file visible to authenticated users with these roles</dd>\n         *\n         *     <dt>shared</dt>\n         *     <dd>(optional) if true, the file will be shared which makes the file visible to authenticated users</dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>(optional) if true, the file will be published which makes the file visible to authenticated and anonymous users</dd>\n         *\n         *    <dt>newversion</dt>\n         *    <dd>(optional) if true, the repository will create new version rather than overwrite</dd>\n         *\n         *    <dt>newversionmsg</dt>\n         *    <dd>(optional) if newversion is true, message to associate with new version</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) specifies the inputs property on a repository-managed script</dd>\n         *\n         *    <dt>outputs</dt>\n         *    <dd>(optional) specifies the outputs property on a repository-managed script</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileRevert: function(config, callback) {\n            return this.io('/r/repository/file/revert', config, callback);\n        },\n\n        /**\n         * This call generates a diff between the current working copy of a file and\n         * a specific version found in the files version history.\n         *\n         * @method repositoryFileDiff\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies the repository file name</dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>specifies the repository file author</dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>\n         *       specifies the repository file version to diff against the current\n         *       working copy\n         *    </dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileDiff: function(config, callback) {\n            return this.io('/r/repository/file/diff', config, callback);\n        },\n\n        /**\n         * This call grants ownership rights on a file to one or more authenticated\n         * users.\n         *\n         * Note, unlike most repository APIs that require both filename and author\n         * parameters, there is no explicit author parameter on this call. The author\n         * is understood to be the caller.\n         *\n         * @method repositoryFileGrant\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>filename</dt>\n         *    <dd>specifies the name of the repository file</dd>\n         *\n         *    <dt>newauthor</dt>\n         *    <dd> specifies a comma-separated list of grantee usernames</dd>\n         *\n         *    <dt>revokeauthor</dt>\n         *    <dd>\n         *       (optional) specifies a comma-separated list of revokee usernames\n         *    </dd>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileGrant: function(config, callback) {\n            return this.io('/r/repository/file/grant', config, callback);\n        },\n\n        /**\n         * This call downloads a repository-managed file.\n         *\n         * @method repositoryFileDownload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *      <dt>filename</dt>\n         *      <dd>specifies the repository file name</dd>\n         *\n         *      <dt>author</dt>\n         *      <dd>specifies the repository author</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *      <dt>version</dt>\n         *      <dd>(optional) specifies the repository file version</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileDownload: function(config, callback) {\n            return this.io('/r/repository/file/download', config, callback);\n        },\n\n        /**\n         * This call deletes a file from the repository.\n         *\n         * @method repositoryFileDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *      <dt>filename</dt>\n         *      <dd>specifies the repository file name</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileDelete: function(config, callback) {\n            return this.io('/r/repository/file/delete', config, callback);\n        },\n\n        /**\n         * This call fetches the latest meta-data on a file in the repository.\n         *\n         * @method repositoryFileFetch\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *      <dt>filename</dt>\n         *      <dd>specifies the repository file name</dd>\n         *\n         *    <dt>author</dt>\n         *    <dd>\n         *       (optional) specifies the repository file author\n         *    </dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>\n         *       (optional) specifies the repository file version\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileFetch: function(config, callback) {\n            return this.io('/r/repository/file/fetch', config, callback);\n        },\n\n        /**\n         * This call copies one or more repository-managed files to the destination\n         * directory.\n         *\n         * If the destination directory already contains a filename matching an\n         * incoming filename, then a new version of the file is automatically created.\n         *\n         * @method repositoryFileCopy\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *      <dt>filename</dt>\n         *      <dd>specifies the repository file name</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>destination</dt>\n         *    <dd>\n         *       (optional) specifies the name of the destination user directory in\n         *       the repository\n         *    </dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>\n         *       (optional) specifies the repository file version\n         *    </dd>\n         *\n         *    <dt>filerename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of new filenames for copied files\n         *       identified on filename parameter\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileCopy: function(config, callback) {            \n            return this.io('/r/repository/file/copy', config, callback);\n        },\n\n        /**\n         * This call moves one or more repository-managed files to the destination\n         * directory.\n         *\n         * If the destination directory already contains a filename matching an\n         * incoming filename, then a new version of the file is automatically created.\n         *\n         * @method repositoryFileMove\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *      <dt>filename</dt>\n         *      <dd>specifies the repository file name</dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>destination</dt>\n         *    <dd>\n         *       (optional) specifies the name of the destination user directory in\n         *       the repository\n         *    </dd>\n         *\n         *    <dt>version</dt>\n         *    <dd>\n         *       (optional) specifies the repository file version\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryFileMove: function(config, callback) {            \n            return this.io('/r/repository/file/move', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Repository Directory APIs\n        /////////////////////////////////////\n\n        /**\n         * This call lists repository-managed directories.\n         * By default, a list of the caller's user directories ( root and custom ) are\n         * returned in the response markup.\n         *\n         * If the userfiles parameter is specified, the files in all of the caller's\n         * user directories are listed in the response markup. Note, depending on the\n         * number of files owned by the caller, when this parameter is enabled the\n         * response markup returned on this call can be a verbose.\n         *\n         * If the directory parameter is specified then only the files in the\n         * directory indicated are returned in the response markup.\n         *\n         * Additional parameters are provided to return files in the caller's archived\n         * directories and/or files in the Restricted , Shared and Public system\n         * directories.\n         *\n         * Note: The metadata property in the response markup on this call is provided\n         * as a convenience for client application developers. It provides a complete\n         * list fo the user directories available to the current caller.\n         *\n         * @method repositoryDirectoryList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>userfiles</dt>\n         *    <dd>\n         *       (optional) if specified, files in all user directories are listed in\n         *       the response markup\n         *    </dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>archived</dt>\n         *    <dd>\n         *       (optional) if true, files found in archived directories are included\n         *       in the response markup\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if true, files that are restricted but visible or shared\n         *       by other users are included in the response markup\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if true, files that are published by other users are\n         *       included in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryList: function(config, callback) {            \n            return this.io('/r/repository/directory/list', config, callback);\n        },\n\n        /**\n         * This call creates a repository-managed custom directory.\n         *\n         * If the name of the new custom directory is already in use by the caller the\n         * response markup will indicate an appropriate error.\n         *\n         * @method repositoryDirectoryList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryCreate: function(config, callback) {            \n            return this.io('/r/repository/directory/create', config, callback);\n        },\n\n        /**\n         * This call renames an existing repository-managed user directory\n         * ( custom or archived ). When renaming a user directory, all files in the\n         * source directory are automatically moved to the destination directory. If\n         * the destination directory already exists the call will be rejected and the\n         * response markup will indicate an appropriate error.\n         *\n         * You can use this call to convert an archived directory back into a custom\n         * directory, essentially unarchiving the archived directory.\n         *\n         * Note: You can not rename the root directory. To move files from the root\n         * directory use the /r/repository/directory/move call.\n         *\n         * <strong>Important:</strong>\n         *\n         * This call will only move files that are owned by a single author to the\n         * destination directory. If a repository-managed file in the source directory\n         * has multiple authors, as a result of collaboration using the\n         * /r/repository/file/grant call, the file will not be moved to the\n         * destination directory and a warning to that affect will be indicated in the\n         * response markup.\n         *\n         * @method repositoryDirectoryRename\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>destination</dt>\n         *    <dd>\n         *       (optional) specifies the new name for the destination custom directory\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryRename: function(config, callback) {           \n            return this.io('/r/repository/directory/rename', config, callback);\n        },\n\n        /** \n         * This call copies one or more repository-managed files from a source user\n         * directory to a destination user directory.\n         *\n         * If the filename parameter is specified, only those files indicated on that\n         * parameter are copied. Otherwise, all files in the source directory are\n         * copied.\n         *\n         * To ensure copying files does not accidentally overwrite any existing files\n         * in the destination directory, all copied files are created as new versions\n         * in the destination directory.\n         *\n         * @method repositoryDirectoryCopy\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>destination</dt>\n         *    <dd>\n         *       (optional) specifies the new name for the destination custom directory\n         *    </dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of filenames to be copied. If omitted,\n         *       all files in the source directory are copied\n         *    </dd>\n         *\n         *    <dt>filerename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of new filenames for copied files\n         *       identified on filename parameter\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryCopy: function(config, callback) {            \n            return this.io('/r/repository/directory/copy', config, callback);\n        },\n\n        /**\n         * This call moves one or more repository-managed files from a source user\n         * directory to a destination user directory.\n         *\n         * If the filename parameter is specified, only those files indicated on that\n         * parameter are moved. Otherwise, all files in the source directory are moved.\n         *\n         * To ensure moving files does not accidentally overwrite any existing files\n         * in the destination directory, all moved files are created as new versions\n         * in the destination directory.\n         *\n         * <strong>Important:</strong>\n         *\n         * This call will only move files that are owned by a single author to the\n         * destination directory. If a repository-managed file in the source directory\n         * has multiple authors, as result of collaboration using the\n         * /r/repository/file/grant call, the file will not be moved to the\n         * destination directory and a warning to that affect will be indicated in the\n         * response markup.\n         *\n         * @method repositoryDirectoryMove\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>destination</dt>\n         *    <dd>\n         *       (optional) specifies the new name for the destination custom directory\n         *    </dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of filenames to be copied. If omitted,\n         *       all files in the source directory are copied\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryMove: function(config, callback) {            \n            return this.io('/r/repository/directory/move', config, callback);\n        },\n\n        /**\n         * This call updates repository-managed file access controls by directory.\n         *\n         * If the filename parameter is specified, only those files indicated on that\n         * parameter are updated. Otherwise, all files in the source directory are\n         * updated.\n         *\n         * @method repositoryDirectoryUpdate\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of filenames to be copied. If omitted,\n         *       all files in the source directory are copied\n         *    </dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *       (optional) specifies the new name for the destination custom directory\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files are shared and visible to\n         *       authenticated users\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files are published and visible to\n         *       authenticated and anonymous users\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryUpdate: function(config, callback) {\n            return this.io('/r/repository/directory/update', config, callback);\n        },\n\n        /**\n         * This call archives one or more repository-managed files from a source user\n         * directory ( root or custom ) to an archive directory.\n         *\n         * If the value of the archive parameter indicates an existing archive\n         * directory then the files in the source directory are added to the existing\n         * archive. Otherwise, a new archive directory is automatically created on\n         * behalf of the caller. Archived directories automatically have a .archive\n         * postfix appended to their name if it is not supplied on the archive\n         * parameter value.\n         *\n         * If all of the files in the source directory are successfully archived, the\n         * source directory is automatically deleted from the repository. If the\n         * source directory was root , an empty root directory is preserved. If any of\n         * the files in the source directory are skipped or can not be archived (see\n         * following note), those files and the source directory are preserved.\n         *\n         * <strong>Important:</strong>\n         *\n         * This call will only archive files that are owned by a single author to the\n         * destination directory. If a repository-managed file in the source directory\n         * has multiple authors, as a result of collaboration using the\n         * /r/repository/file/grant call, the file will not be archived to the\n         * destination directory and a warning to that affect will be indicated in the\n         * response markup.\n         *\n         * @method repositoryDirectoryArchive\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of filenames to be copied. If omitted,\n         *       all files in the source directory are copied\n         *    </dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *       (optional) specifies the new name for the destination custom directory\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files are shared and visible to\n         *       authenticated users\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files are published and visible to\n         *       authenticated and anonymous users\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryArchive: function(config, callback) {\n\n            return this.io('/r/repository/directory/archive', config, callback);\n        },\n\n        /**\n         * This call uploads a set of files in a zip archive into an existing\n         * repository-managed user directory ( root , custom or archived ).\n         *\n         * @method repositoryDirectoryUpload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>file</dt>\n         *    <dd>\n         *       ...zip archive file content...\n         *    </dd>\n         *\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>\n         *       (optional) specifies a description to associate with the uploaded file\n         *    </dd>\n         *\n         *    <dt>tags</dt>\n         *    <dd>\n         *       (optional) specifies tag words to associate with the repository file\n         *    </dd>\n         *\n         *    <dt>restricted</dt>\n         *    <dd>\n         *       (optional) specifies the new name for the destination custom directory\n         *    </dd>\n         *\n         *    <dt>shared</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files are shared and visible to\n         *       authenticated users\n         *    </dd>\n         *\n         *    <dt>published</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, files are published and visible to\n         *       authenticated and anonymous users\n         *    </dd>\n         *\n         *    <dt>newversion</dt>\n         *    <dd>\n         *       (optional) if <code>true</code>, the repository will create new\n         *       version rather than overwrite\n         *    </dd>\n         *\n         *    <dt>newversionmsg</dt>\n         *    <dd>\n         *       (optional) if newversion is true, message to associate with new\n         *       version\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryUpload: function(config, callback) {\n            config = config || {};\n            config.format = 'text';\n            var ioConfig = {\n                data: config,\n                method: 'POST',\n                form: {\n                    id: config.formId\n                },\n                on: callback\n            };\n            return this.io('/r/repository/directory/upload', config, callback);\n        },\n\n        /**\n         * This call downloads one or more repository-managed files from a directory\n         * in the repository. The response type on this call is a zip archive file.\n         *\n         * If the filename parameter is specified, only those files indicated on that\n         * parameter are downloaded. Otherwise, all files in the source directory are\n         * downloaded.\n         *\n         * @method repositoryDirectoryDownload\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         *\n         *    <dt>filename</dt>\n         *    <dd>\n         *       (optional) comma-separated list of filenames to be copied. If omitted,\n         *       all files in the source directory are copied\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryDownload: function(config, callback) {            \n            return this.io('/r/repository/directory/download', config, callback);\n        },\n\n        /**\n         * This call deletes a repository-managed user directory ( root , custom or\n         * archived ).\n         *\n         * When deleting a user directory, all files in the directory are\n         * automatically deleted along with the directory. If the target directory is\n         * root, an empty root directory is preserved.\n         *\n         * @method repositoryDirectoryDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>directory</dt>\n         *    <dd>\n         *       (optional) specifies the target repository directory, defaults to root\n         *       included in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        repositoryDirectoryDelete: function(config, callback) {\n            return this.io('/r/repository/directory/delete', config, callback);\n        },\n\n        /////////////////////////////////////\n        // Job APIs\n        /////////////////////////////////////\n\n        /**  \n         * This call lists jobs for the currently authenticated user.\n         *\n         * The openonly parameter allows the caller to see only those jobs in an open\n         * state. The set of job open states are shown here:\n         *\n         * <ul>\n         *  <li>Scheduled : job is scheduled but not yet queued for running.</li>\n         *  <li>Queued : job is queued for running.</li>\n         *  <li>Running : job is running.</li>\n         * </ul>\n         *\n         * <blockquote>\n         *    Important! Any open job can be cancelled using the\n         *    <a href=\"#method_jobCancel\">jobCancel</a> call.\n         * </blockquote>\n         *\n         * @method jobList\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>openonly</dt>\n         *    <dd>\n         *       (optional) if true, only jobs in an open-state are listed in the\n         *       response markup\n         *    </dd>\n         *\n         *    <dt>extended</dt>\n         *    <dd>\n         *       (optional) If true, additional data properties describing each job\n         *       are listed in the response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        jobList: function(config, callback) {\n            return this.io('/r/job/list', config, callback);\n        },\n\n        /**\n         * This call submits a job for background execution on behalf of the user.\n         *\n         * To submit the execution of an arbitrary block of R code the caller must\n         * provide a value on the code parameter.\n         *\n         *\n         * To submit the execution of a single repository-managed script the caller\n         * must provide parameter values for rscriptname , rscriptauthor and\n         * optionally rscriptversion . To submit the execution of a chain of\n         * repository-managed scripts the caller must provide a comma-separated list\n         * of values on the rscriptname,, _rscriptauthor and optionally rscriptversion\n         * parameters.\n         *\n         *\n         * To submit the execution of a single external script the caller must\n         * provide a valid URL or file path using the externalsource parameter. To\n         * submit the execution of a chain of external scripts the caller must\n         * provide a comma-separated list of values on the externalsource parameter.\n         * Note, to submit the execution of an external script the caller must have\n         * POWER_USER privileges.\n         *\n         * Note: A chained execution executes each of the scripts identified on the\n         * call in a sequential fashion on the R session for the job, with execution\n         * occuring in the order specified on the parameter list.\n         *\n         * Please not the following pre and post execution parameters:\n         *\n         * <strong>Pre-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The inputs parameter allows the caller to pass RevoDeployR-encoded\n         *       R object values as inputs. These inputs are turned into R objects\n         *       in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadfile parameters allows the caller to load one or more\n         *       files from the repository into the working directory before the\n         *       execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadobject parameters allow the caller to load one or more\n         *       binary R objects (.rData) from the repository into the workspace\n         *       before the execution begins.\n         *    </li>\n         *    <li>\n         *       The adopt parameters allow the caller to load a pre-existing\n         *       project workspace, project working directory and/or project package\n         *       dependencies before the execution begins.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Post-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The storefile parameter allows the caller specify a comma-separated\n         *       list of working directory files to be stored in the repository after\n         *       the execution completes.\n         *    </li>\n         *    <li>\n         *       The storeobject parameter allows the caller specify a comma-separated\n         *       list of workspace objects to be stored in the repository after the\n         *       execution completes.\n         *    </li>\n         *    <li>\n         *       The storeworkspace parameter allows the caller to store the entire\n         *       workspace in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storedirectory parameter allows the caller to specify a target\n         *       repository directory for stored files and objects after the execution\n         *       completes.\n         *    </li>\n         *    <li>\n         *       The storenewversion parameter allows the caller to create new\n         *       versions of each stored file in the repository after the execution\n         *       completes. By default, stored files overwrite any pre-existing file\n         *       by the same name.\n         *    </li>\n         *    <li>\n         *       The storepublic parameter allows the caller to assign public access\n         *       to each stored file in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storenoproject parameter allows the caller to skip the\n         *       persistence-to-project step after the execution.\n         *    </li>\n         * </ol>\n         *\n         * @method jobSubmit\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>name</dt>\n         *    <dd>job name</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) job description</dd>\n         *\n         *    <dt>code</dt>\n         *    <dd>(optional) R code to execute on job</dd>\n         *\n         *      <dt>rscriptname</dt>\n         *      <dd>(optional) comma-separated list of repository-managed script filenames</dd>\n         *\n         *    <dt>rscriptdirectory</dt>\n         *    <dd>(optional) comma-separated list of repository-managed directories for scripts, defaults to root</dd>\n         *\n         *      <dt>rscriptauthor</dt>\n         *      <dd>(optional) comma-separated list of authors, author-per-rscriptname</dd>\n         *\n         *      <dt>rscriptversion</dt>\n         *      <dd>(optional) comma-separated list of versions, version-per-rscriptname</dd>\n         *\n         *      <dt>externalsource</dt>\n         *      <dd>(optional) comma-separated list of URLs or file paths to external scripts</dd>\n         *\n         *      <dt>inputs</dt>\n         *      <dd>(optional) RevoDeployR-encoded script inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *      <dt>preloadfilename</dt>\n         *      <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *      <dt>preloadfileauthor</dt>\n         *      <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *\n         *      <dt>preloadfileversion</dt>\n         *      <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *\n         *      <dt>preloadobjectname</dt>\n         *      <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *\n         *      <dt>preloadobjectauthor</dt>\n         *      <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *\n         *      <dt>preloadobjectversion</dt>\n         *      <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *\n         *      <dt>adoptworkspace</dt>\n         *      <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *\n         *      <dt>adoptdirectory</dt>\n         *      <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *\n         *      <dt>adoptpackages</dt>\n         *      <dd>(optional) identifies project from which package dependencies are to be adopted</dd>\n         *\n         *      <dt>priority</dt>\n         *      <dd>(optional) specifies the scheduling priority for the job: low (default), medium or high</dd>\n         *\n         *      <dt>tag</dt>\n         *      <dd>(optional) specifies a tag that labels the execution</dd>\n         *\n         *      <dt>echooff</dt>\n         *      <dd>\n         *       (optional) if true R commands will not appear in the console output\n         *       saved on the project execution history for the job\n         *    </dd>\n         *\n         *      <dt>graphics</dt>\n         *      <dd>(optional) specifies preferred R graphics device for execution: png or svg</dd>\n         *\n         *      <dt>graphicswidth</dt>\n         *      <dd>(optional) specifies preferred width for R graphics device images</dd>\n         *\n         *      <dt>graphicsheight</dt>\n         *      <dd>(optional) specifies preferred height for R graphics device images</dd>\n         *\n         *      <dt>storefile</dt>\n         *      <dd>(optional) comma-separated list of working directory filenames</dd>\n         *\n         *      <dt>storeobject</dt>\n         *      <dd>(optional) comma-separated list of workspace object names</dd>\n         *\n         *      <dt>storeworkspace</dt>\n         *      <dd>(optional) filename (.rData) where workspace contents will be saved in the repository</dd>\n         *\n         *      <dt>storenewversion</dt>\n         *      <dd>(optional) if <code>true</code>, ensures each file stored in repository results in new version being created if needed</dd>\n         *\n         *      <dt>storepublic</dt>\n         *      <dd>(optional) if <code>true</code>, publishes each file stored in the repository</dd>\n         *\n         *      <dt>storenoproject</dt>\n         *      <dd>(optional) if <code>true</code>, no project persistence following job execution</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        jobSubmit: function(config, callback) {            \n            return this.io('/r/job/submit', config, callback);\n        },\n\n        /**\n         * This call schedules a job for background execution on behalf of the user.\n         *\n         * The schedstart parameter identifies the start time for the job. This\n         * parameter value is specified as UTC in milliseconds. The schedrepeat\n         * parameter indicates the number of times the job is to be repeated, and if\n         * omitted the job is executed just once. The schedinterval parameter\n         * indicates the interval, measured in milliseconds, between repeat\n         * executions.\n         *\n         * To schedule the execution of an arbitrary block of R code the caller\n         * must provide a value on the code parameter.\n         *\n         * To schedule the execution of a single repository-managed script the\n         * caller must provide parameter values for rscriptname , rscriptauthor and\n         * optionally rscriptversion . To schedule the execution of a chain of\n         * repository-managed scripts the caller must provide a comma-separated list\n         * of values on the rscriptname,, _rscriptauthor and optionally rscriptversion\n         * parameters.\n         *\n         * To schedule the execution of a single external script the caller must\n         * provide a valid URL or file path using the externalsource parameter. To\n         * schedule the execution of a chain of external scripts the caller must\n         * provide a comma-separated list of values on the externalsource parameter.\n         * Note, to schedule the execution of an external script the caller must\n         * have POWER_USER privileges.\n         *\n         * Note: A chained execution executes each of the scripts identified on the\n         * call in a sequential fashion on the R session for the job, with\n         * execution occuring in the order specified on the parameter list.\n         *\n         * Please not the following pre and post execution parameters:\n         *\n         * <strong>Pre-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The inputs parameter allows the caller to pass RevoDeployR-encoded\n         *       R object values as inputs. These inputs are turned into R objects\n         *       in the workspace before the execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadfile parameters allows the caller to load one or more\n         *       files from the repository into the working directory before the\n         *       execution begins.\n         *    </li>\n         *    <li>\n         *       The preloadobject parameters allow the caller to load one or more\n         *       binary R objects (.rData) from the repository into the workspace\n         *       before the execution begins.\n         *    </li>\n         *    <li>\n         *       The adopt parameters allow the caller to load a pre-existing\n         *       project workspace, project working directory and/or project package\n         *       dependencies before the execution begins.\n         *    </li>\n         * </ol>\n         *\n         * <strong>Post-execution parameters:</strong>\n         *\n         * <ol>\n         *    <li>\n         *       The storefile parameter allows the caller specify a comma-separated\n         *       list of working directory files to be stored in the repository after\n         *       the execution completes.\n         *    </li>\n         *    <li>\n         *       The storeobject parameter allows the caller specify a comma-separated\n         *       list of workspace objects to be stored in the repository after the\n         *       execution completes.\n         *    </li>\n         *    <li>\n         *       The storeworkspace parameter allows the caller to store the entire\n         *       workspace in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storedirectory parameter allows the caller to specify a target\n         *       repository directory for stored files and objects after the execution\n         *       completes.\n         *    </li>\n         *    <li>\n         *       The storenewversion parameter allows the caller to create new\n         *       versions of each stored file in the repository after the execution\n         *       completes. By default, stored files overwrite any pre-existing file\n         *       by the same name.\n         *    </li>\n         *    <li>\n         *       The storepublic parameter allows the caller to assign public access\n         *       to each stored file in the repository after the execution completes.\n         *    </li>\n         *    <li>\n         *       The storenoproject parameter allows the caller to skip the\n         *       persistence-to-project step after the execution.\n         *    </li>\n         * </ol>\n         *\n         * @method jobSchedule\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>name</dt>\n         *    <dd>job name</dd>\n         *\n         *    <dt>descr</dt>\n         *    <dd>(optional) job description</dd>\n         *\n         *    <dt>schedstart</dt>\n         *    <dd>(optional) specifies the start time for job</dd>\n         *\n         *    <dt>schedrepeat</dt>\n         *    <dd>(optional) specifies the number of times job is to be repeated</dd>\n         *\n         *    <dt>schedinterval</dt>\n         *    <dd>(optional) specifies the interval (ms) on which job is to be repeated</dd>\n         *\n         *    <dt>code</dt>\n         *    <dd>(optional) R code to execute on job</dd>\n         *\n         *    <dt>rscriptname</dt>\n         *    <dd>(optional) comma-separated list of repository-managed script filenames</dd>\n         *\n         *    <dt>rscriptdirectory</dt>\n         *    <dd>(optional) comma-separated list of repository-managed directories for scripts, defaults to root</dd>\n         *\n         *    <dt>rscriptauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-rscriptname</dd>\n         *\n         *    <dt>rscriptversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-rscriptname</dd>\n         *\n         *    <dt>externalsource</dt>\n         *    <dd>(optional) comma-separated list of URLs or file paths to external scripts</dd>\n         *\n         *    <dt>inputs</dt>\n         *    <dd>(optional) RevoDeployR-encoded script inputs</dd>\n         *\n         *    <dt>csvinputs</dt>\n         *    <dd>(optional) comma-separated list of primitive name/value inputs</dd>\n         *\n         *    <dt>preloadfilename</dt>\n         *    <dd>(optional) comma-separated list of repository filenames</dd>\n         *\n         *    <dt>preloadfileauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadfilename</dd>\n         *\n         *    <dt>preloadfileversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-preloadfilename</dd>\n         *\n         *    <dt>preloadobjectname</dt>\n         *    <dd>(optional) comma-separated list of repository object (.rData) filenames</dd>\n         *\n         *    <dt>preloadobjectauthor</dt>\n         *    <dd>(optional) comma-separated list of authors, author-per-preloadobjectname</dd>\n         *\n         *    <dt>preloadobjectversion</dt>\n         *    <dd>(optional) comma-separated list of versions, version-per-object-preloadobjectname</dd>\n         *\n         *    <dt>adoptworkspace</dt>\n         *    <dd>(optional) identifies project from which workspace is to be adopted</dd>\n         *\n         *    <dt>adoptdirectory</dt>\n         *    <dd>(optional) identifies project from which directory is to be adopted</dd>\n         *\n         *    <dt>adoptpackages</dt>\n         *    <dd>(optional) identifies project from which package dependencies are to be adopted</dd>\n         *\n         *      <dt>priority</dt>\n         *      <dd>(optional) specifies the scheduling priority for the job: low (default), medium or high</dd>\n         *\n         *    <dt>tag</dt>\n         *    <dd>(optional) specifies a tag that labels the execution</dd>\n         *\n         *    <dt>echooff</dt>\n         *    <dd>\n         *       (optional) if true R commands will not appear in the console output\n         *       saved on the project execution history for the job\n         *    </dd>\n         *\n         *    <dt>consoleoff</dt>\n         *    <dd>\n         *       (optional) if true console output is not saved on the project\n         *       execution history for the job\n         *    </dd>\n         *\n         *    <dt>graphics</dt>\n         *    <dd>(optional) specifies preferred R graphics device for execution: png or svg</dd>\n         *\n         *    <dt>graphicswidth</dt>\n         *    <dd>(optional) specifies preferred width for R graphics device images</dd>\n         *\n         *    <dt>graphicsheight</dt>\n         *    <dd>(optional) specifies preferred height for R graphics device images</dd>\n         *\n         *    <dt>storefile</dt>\n         *    <dd>(optional) comma-separated list of working directory filenames</dd>\n         *\n         *    <dt>storeobject</dt>\n         *    <dd>(optional) comma-separated list of workspace object names</dd>\n         *\n         *    <dt>storeworkspace</dt>\n         *    <dd>(optional) filename (.rData) where workspace contents will be saved in the repository</dd>\n         *\n         *    <dt>storenewversion</dt>\n         *    <dd>(optional) if <code>true</code>, ensures each file stored in repository results in new version being created if needed</dd>\n         *\n         *    <dt>storepublic</dt>\n         *    <dd>(optional) if <code>true</code>, publishes each file stored in the repository</dd>\n         *\n         *    <dt>storenoproject</dt>\n         *    <dd>(optional) if <code>true</code>, no project persistence following job execution</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        jobSchedule: function(config, callback) {           \n            return this.io('/r/job/schedule', config, callback);\n        },\n\n        /**\n         * This call queries the job status. The status property will indicate one of\n         * the following values:\n         *\n         * Scheduled, Queued, Running, Completed, Cancelling, Cancelled, Interrupted,\n         * Aborted, Failed.\n         *\n         * @method jobQuery\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         * supports the following properties:\n         * <dl>\n         *    <dt>job</dt>\n         *    <dd>specifies a comma-separated list of job identifiers</dd>\n         *\n         *    <dt>extended</dt>\n         *    <dd>\n         *       (optional) if true, only jobs in an extended-state are listed in the\n         *       response markup\n         *    </dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        jobQuery: function(config, callback) {\n            return this.io('/r/job/query', config, callback);\n        },\n\n        /**\n         * This call cancels the specified job.\n         *\n         * Only jobs in an open-state can be cancelled. The set of job open-states are\n         * shown here:\n         *\n         * <ul>\n         *    <li>Scheduled : job is scheduled but not yet queued for running.</li>\n         *    <li>Queued : job is queued for running.</li>\n         *    <li>Running : job is running.</li>\n         * </ul>\n         * @method jobCancel\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *    <dt>job</dt>\n         *    <dd>specifies a comma-separated list of job identifiers</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        jobCancel: function(config, callback) {\n            return this.io('/r/job/list', config, callback);\n        },\n\n        /**\n         * This call deletes the specified job.\n         *\n         * Only jobs in one of the completed-states can be deleted. The set of job\n         * compelted-states are shown here:\n         *\n         * <ul>\n         *    <li>Completed : job execution has run to successful completion.</li>\n         *    <li>Interrupted : job execution has been interrupted.</li>\n         *    <li>Cancelled : job has been cancelled.</li>\n         *    <li>Aborted : job execution has been aborted.</li>\n         *    <li>Failed : job execution has resulted in failure.</li>\n         * </ul>\n         *\n         * Jobs in an open-state must first run to completion or be cancelled before\n         * they are eligible for deletion.\n         *\n         * <blockquote>\n         *    Important! Deleting jobs will not delete the projects that resulted from\n         *    those jobs.\n         * </blockquote>\n         *\n         * @method jobDelete\n         * @static\n         * @param {Object} config the call configuration. The configuration object\n         *        supports the following properties:\n         * <dl>\n         *  <dt>job</dt>\n         *  <dd>specifies a comma-separated list of job identifiers</dd>\n         * </dl>\n         * @param {Object} callback the callback configuration.\n         * @return {Object} the io transaction object.\n         */\n        jobDelete: function(config, callback) {\n            return this.io('/r/job/delete', config, callback);\n        }\n    } // DeployR\n\n};\n\nmodule.exports = Deprecated;","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nvar Base = require('./selfish').Base;\n\nfunction debug(msg) { }\n\nmodule.exports = Base.extend({\n\n  initialize: function() {\n    this.events = {};\n    this.scope  = null;\n  },\n\n  /**\n   * Adds a listener.  Multiple can be added per name.  Aliased as `on`.\n   *\n   * @param {String} name The name of the event\n   * @param {Function} handler A callback\n   * @return {Emitter} `this` for chaining      \n   */\n  on: function(name, handler) {\n    if (name in this.events === false) { this.events[name] = []; }        \n\n    this.events[name].push(handler);\n    debug('Emitter.on(\"' + name + '\")');\n\n    return this;\n  },\n\n  /**\n   * Triggers all matching listeners.\n   *\n   * @param {String} name The name of the event\n   * @return {Emitter} `this` for chaining   \n   */\n  emit: function(name) {\n    if (name in this.events === false) { return this; }\n\n    for (var i = 0; i < this.events[name].length; i++) {\n      debug('Fired event: \"' + name + '\"');\n      this.events[name][i].apply(this.scope || this, Array.prototype.slice.call(arguments, 1));       \n    }\n\n    return this;\n  },\n\n  /**\n   * Removes all matching listeners.\n   *\n   * @param {String} name The name of the event\n   * @return {Emitter} `this` for chaining\n   */\n  offAll: function(name) {\n    if (!name) {\n      for (var e in this.events) {\n        delete this.events[e];\n      }\n    } else {\n      if (name in this.events === false) { return this; }\n      delete this.events[name];        \n    }\n\n    return this;\n  },\n\n  /**\n   * Removes a listener based on an index.\n   *\n   * @private\n   * @param {String} name The name of the event\n   * @param {Number} index The index of the event \n   */\n  offAt: function(name, index) {\n    var array = this.events[name],\n        rest  = array.slice(index + 1);\n\n    array.length = index;\n    array.push.apply(array, rest);\n    this.events[name] = array;\n  },\n\n  /**\n   * Removes a listener based on the handler function.\n   *\n   * @param {String} name The name of the event\n   * @param {Function} handler The handler function to remove\n   * @return {Emitter} `this` for chaining\n   */\n  off: function(name, handler) {\n    if (name in this.events === false) { return this; }\n\n    // remove all events handlers by this name\n    if (!handler) {\n      return this.offAll(name);\n    } else { // remove all events handlers == 'handler' by this name\n      for (var i = 0; i < this.events[name].length; i++) {\n        if (this.events[name][i] == handler) {\n          this.offAt(name, i);\n          return this;\n        }\n      }\n    } \n\n    return this;\n  }\n\n}); ","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more\n * details.\n */\nvar Lang = require('./lang'),\n    RTypes = require('./rtypes'),\n    R = RTypes.r,\n    DeployR = RTypes.deployr;\n\nfunction formatDates(dates, type) {\n    var formats = [];\n\n    for (var i = 0; i < dates.length; i++) {\n        formats.push(formatDate(dates[i], type));\n    }\n\n    return formats;\n}\n\nfunction formatDate(date, type) {    \n   var year   = date.getFullYear(),\n       month  = (date.getMonth() + 1),\n       day    = date.getDate(),    \n       hour   = date.getHours(),\n       min    = date.getMinutes(),\n       sec    = date.getSeconds(),\n       zone   = date.getTimezoneOffset(),\n       format = '';\n\n       month  = (month < 10 ? '0' + month : month);\n       hour   = (hour < 10 ? '0' + hour : hour);\n       min    = (min < 10 ? '0' + min : min);\n       sec    = (sec < 10 ? '0' + sec : sec);       \n       format = year + '-' + month + '-' + day;\n\n    function leftZeroFill(number, targetLength, forceSign) {\n        var output = '' + Math.abs(number),\n            sign = number >= 0;\n\n        while (output.length < targetLength) {\n            output = '0' + output;\n        }\n        return (sign ? (forceSign ? '+' : '') : '-') + output;\n    }\n   \n    if (type === DeployR.RPOSIX_DATE || type === DeployR.RPOSIX_DATE_VECTOR) {\n        var time  = hour + ':' + min + ':' + sec,\n            a = -zone,\n            b = \"+\";\n\n        if (a < 0) {\n            a = -a;\n            b = \"-\";\n        }\n\n        zone = b + leftZeroFill((a / 60), 2) + '' + leftZeroFill(a % 60, 2);\n        format += (' ' + time + ' ' + zone);\n    }\n\n    return format;\n}\n\nfunction encodeEmbeddedDataframe(obj, rdf) {\n    var dfValue = obj.value;\n    for (var index = 0; index < dfValue.length; index++) {\n        var dfObj = dfValue[index];\n        if (dfObj.type === DeployR.RDATAFRAME) {\n            rdf = encodeEmbeddedDataframe(dfObj, rdf);\n        } else {\n            // format dates\n            if (RTypes.isDate(dfObj.type)) {\n                if (Lang.isArray(dfObj.value)) {\n                    dfObj.value = formatDates(dfObj.value, dfObj.type);\n                } else {\n                    dfObj.value = formatDate(dfObj.value, dfObj.type);\n                }\n            }\n\n            dfObj.type = RTypes.deployrToR(dfObj.type);\n            rdf.value.push(dfObj);            \n        }\n\n    }\n    return rdf;\n};\n\nfunction encodeDataframe(obj) {\n    var rdf = {\n            type: R.DATAFRAME,\n            value: [],\n            name: obj.name\n        },\n        dfValue = obj.value;\n\n    for (var index = 0; index < dfValue.length; index++) {\n        var dfObj = dfValue[index];\n\n        if (dfObj.type === DeployR.RDATAFRAME) {\n            rdf = encodeEmbeddedDataframe(dfObj, rdf);\n        } else {\n            // format dates\n            if (RTypes.isDate(dfObj.type)) {\n                if (Lang.isArray(dfObj.value)) {\n                    dfObj.value = formatDates(dfObj.value, dfObj.type);\n                } else {\n                    dfObj.value = formatDate(dfObj.value, dfObj.type);\n                }\n            }\n\n            dfObj.type = RTypes.deployrToR(dfObj.type);\n            rdf.value.push(dfObj);\n        }\n\n    }\n    return rdf;\n};\n\nfunction encodeList(obj) {\n    var rlist = {\n            type: R.LIST,\n            value: [],\n            name: obj.name\n        },\n        dfValue = obj.value,\n        r;\n\n    for (var index = 0; index < dfValue.length; index++) {\n        var dfObj = dfValue[index];\n\n        switch (dfObj.type) {\n            case DeployR.RDATAFRAME:\n                r = encodeDataframe(dfObj);\n                break;\n\n            case DeployR.RLIST:\n                r = encodeList(dfObj);\n                break;\n\n            case DeployR.RNUMERIC_MATRIX:\n            case DeployR.RINTEGER_MATRIX:\n            case DeployR.RBOOLEAN_MATRIX:\n            case DeployR.RSTRING_MATRIX:\n                r = {\n                    name: dfObj.name,\n                    type: R.MATRIX,\n                    value: dfObj.value\n                };\n                break;\n\n            case DeployR.RDATE:\n            case DeployR.RPOSIX_DATE:\n                r = {\n                    name: dfObj.name,\n                    type: R.DATE,\n                    format: dfObj.format,\n                    value: formatDate(dfObj.value, dfObj.type)\n                };\n                break;\n\n            case DeployR.RFACTOR:\n            case DeployR.RORDERED:\n                r = {\n                    name: dfObj.name,\n                    type: R.FACTOR,\n                    ordered: dfObj.ordered,\n                    labels: dfObj.labels,\n                    levels: dfObj.levels,\n                    value: dfObj.value\n                };\n                break;\n\n            case DeployR.RSTRING:\n            case DeployR.RBOOLEAN:\n            case DeployR.RNUMERIC:\n            case DeployR.RINTEGER:\n                r = {\n                    name: dfObj.name,\n                    type: R.PRIMITIVE,\n                    value: dfObj.value\n                };\n                break;\n\n            case DeployR.RNUMERIC_VECTOR:\n            case DeployR.RINTEGER_VECTOR:\n            case DeployR.RBOOLEAN_VECTOR:\n            case DeployR.RSTRING_VECTOR:\n                r = {\n                    name: dfObj.name,\n                    type: R.VECTOR,\n                    value: dfObj.value\n                };\n                break;\n\n            case DeployR.RDATE_VECTOR:\n            case DeployR.RPOSIX_DATE_VECTOR:\n                r = {\n                    name: dfObj.name,\n                    type: R.VECTOR,                    \n                    value: formatDates(dfObj.value, dfObj.type),\n                    format: dfObj.format\n                };\n                break;\n\n            default:\n                throw new Error('No RDataType found for \"' + dfObj.type + '\"');\n                break;\n        }\n\n        rlist.value.push(r);\n    }\n    return rlist;\n};\n\nmodule.exports = {\n\n    /**\n     * Flattens a given <code>Revolution.RData</code> type into a JSON string\n     * representing the\n     * expected DeployR input format.\n     *\n     * @method parseInputs\n     * @public\n     * @param {Array} rdata An Array of RData Objects to be flattened.\n     * @return {String} The flattend RData JSON string representing the DeployR\n     *                  input format.\n     */\n    encode: function(rdata) {\n        var r = {};\n\n        for (var index = 0; index < rdata.length; index++) {\n            var obj = rdata[index];\n\n            switch (obj.type) { // -- DeployR Type -- //\n\n                case DeployR.RDATAFRAME:\n                    r[obj.name] = encodeDataframe(obj);\n                    break;\n\n                case DeployR.RLIST:\n                    r[obj.name] = encodeList(obj);\n                    break;\n\n                case DeployR.RNUMERIC_MATRIX:\n                case DeployR.RINTEGER_MATRIX:\n                case DeployR.RBOOLEAN_MATRIX:\n                case DeployR.RSTRING_MATRIX:\n                    r[obj.name] = {\n                        type: R.MATRIX,\n                        value: obj.value\n                    };\n                    break;\n\n                case DeployR.RDATE:\n                case DeployR.RPOSIX_DATE:\n                    r[obj.name] = {\n                        type: R.DATE,\n                        format: obj.format,                        \n                        value: formatDate(obj.value, obj.type)\n                    };\n                    break;\n\n                case DeployR.RFACTOR:\n                case DeployR.RORDERED:                \n                    r[obj.name] = {\n                        type: R.FACTOR,\n                        ordered: obj.ordered,\n                        labels: obj.labels,\n                        levels: obj.levels,\n                        value: obj.value\n                    };\n                    break;\n\n                case DeployR.RSTRING:\n                case DeployR.RBOOLEAN:\n                case DeployR.RNUMERIC:\n                case DeployR.RINTEGER:\n                    r[obj.name] = {\n                        type: R.PRIMITIVE,\n                        value: obj.value\n                    };\n                    break;\n\n                case DeployR.RNUMERIC_VECTOR:\n                case DeployR.RINTEGER_VECTOR:\n                case DeployR.RBOOLEAN_VECTOR:\n                case DeployR.RSTRING_VECTOR:\n                    r[obj.name] = {\n                        type: R.VECTOR,\n                        value: obj.value\n                    };\n                    break;\n\n                case DeployR.RDATE_VECTOR:\n                case DeployR.RPOSIX_DATE_VECTOR:\n                    r[obj.name] = {\n                        type: R.VECTOR,            \n                        value: formatDates(obj.value, obj.type),\n                        format: obj.format\n                    };\n                    break;\n\n                default:\n                    throw new Error('No RDataType found for \"' + obj.type + '\"');\n                    break;\n            }\n        }\n\n        return (JSON.stringify(r));\n    }\n};"," var optional = require('./optional'),\n     WS       = optional('ws'),\n     Queue    = require('./queue'),     \n     Emitter  = require('./emitter'),\n     Base     = require('./selfish').Base,\n     merge    = require('./utils').merge;\n\n/**\n * Initialize a new `EventStream` with the given set of `options`.\n *\n * @param {Object} options\n * @api private\n */\nvar EventStream = Base.extend(Emitter, {   \n\n  initialize: function initialize(host, options) {\n    Emitter.initialize.call(this, {});\n\n    this.host        = host;\n    this.options     = options || {};\n    this.options.log = this.options.log || this.LOG.error;\n    this.ws          = null;\n    this.q           = new Queue();\n    this.channel     = {};     \n  },  \n\n  LOG: { \n    info: 'info', \n    debug: 'debug', \n    error: 'error' \n  },\n  \n  open: function(options) {    \n    var self   = this,\n        uri    = (this.host || '') + '/deployr/r/event/stream?',\n        params = [];\n\n    options = options || {};\n    options.headers = options.headers || {};\n    options = this.options = merge(options, this.channel);    \n\n    this.cookies = !this.cookies ? options.headers.Cookie : this.cookies;\n\n    // -- append option parameters --\n    if (options.project) {\n      params.push('project=' + options.project);\n    } else {\n      if (options.job) {\n        params.push('job=' + options.job);\n      }\n    }\n\n    if (options.management) {\n      params.push('managementEventOnly=true');\n    } else {\n      if (options.httponly) {\n        params.push('httpEventOnly=true');\n      } else {\n        if (options.revoonly) {\n          params.push('revoEventOnly=true');\n        }\n      }\n    }\n\n    uri += params.join('&').substr(0);\n    uri = uri.replace(/^http/,'ws');\n\n    this.q.yield(true);\n    this.q.add(function() {\n\n      var headers = this.cookies ? { 'Cookie': this.cookies } : {};\n      this.emit('es:connecting', { uri: uri, headers: headers });\n\n      var ws = new WS(uri, 'http', { headers: headers });\n\n      ws.onopen = function (message) {\n        self.emit('es:open', message);\n      };\n\n      var _message = '';\n      ws.onmessage = function (message) {\n        try {          \n          if (message.data.split('!|!')[1]) {\n            _message = _message + message.data.split('!|!')[1];\n            message = JSON.parse(_message);\n            _message = '';\n            var type = message.deployr.response.event.type;\n            self.emit('es:' + type.replace('Event', ''), message);\n          }\n        } catch (e) {} \n      };\n\n      ws.onerror = function (err) { self.emit('es:error', err); };\n      ws.onclose = function (message) { self.emit('es:disconnect', message); };\n\n      this.ws = ws;\n    }, this);\n\n    if (options.force) { this.flush(); }\n\n    return this;    \n  },\n\n  close: function() {\n    if (this.ws) { this.ws.close(); }\n\n    return this;\n  },\n\n  error: function(fn) {\n    this.on('es:error', fn);\n\n    return this;\n  },  \n\n  all: function() {\n    this.channel = { revoonly: true };  // revoEventOnly=true\n\n    return this;\n  },\n\n  session: function() {\n    this.channel = { httponly: true }; //httpEventOnly=true\n\n    return this;\n  },\n\n  project: function(project) {\n    this.channel = { project: project }; // project=12345\n\n    return this;\n  },\n\n  job: function(job) {\n    this.channel = { job: job }; //job=12345\n\n    return this;\n  },\n\n  management: function() {\n    this.channel = { management: true }; //managementEventOnly=true\n\n    return this;\n  },\n\n  flush: function() {\n    this.q.yield(false);\n    this.q.flush();\n  },\n\n  share: function(cookies) {\n    this.cookies = cookies;\n  }\n\n});\n\nmodule.exports = EventStream;\n","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n *\n * This component is a DeployR port of yui-lang.js by Yahoo!\n *\n * Software License Agreement (BSD License)\n * Copyright (c) 2013, Yahoo! Inc. All rights reserved.\n *\n * Redistribution and use of this software in source and binary forms, with or \n * without modification, are permitted provided that the following conditions \n * are met:\n *\n * Redistributions of source code must retain the above copyright notice, this \n * list of conditions and the following disclaimer. Redistributions in binary \n * form must reproduce the above copyright notice, this list of conditions and \n * the following disclaimer in the documentation and/or other materials provided \n * with the distribution.\n *\n * Neither the name of Yahoo! Inc. nor the names of YUI's contributors may be \n * used to endorse or promote products derived from this software without \n * specific prior written permission of Yahoo! Inc.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" \n * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE \n * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE \n * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE \n * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR \n * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF \n * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS \n * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN \n * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) \n * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE  \n * POS SIBILITY OF SUCH DAMAGE.\n */\n\n/**\n * Provides core language utilites and extensions used throughout DeployR.\n *\n * @class Lang\n * @static\n */\nvar L = {}, \n\tTOSTRING = Object.prototype.toString, \n\tTYPES = {\t\n\t\t'undefined' : 'undefined',\n\t\t'number' : 'number',\n\t\t'boolean' : 'boolean',\n\t\t'string' : 'string',\n\t\t'[object Function]' : 'function',\n\t\t'[object RegExp]' : 'regexp',\n\t\t'[object Array]' : 'array',\n\t\t'[object Date]' : 'date',\n\t\t'[object Error]' : 'error'\n\t}, unsafeNatives = false;\n\n/**\n * Determines whether or not the provided item is null.\n * @method isNull\n * @static\n * @param o The object to test.\n * @return {boolean} true if o is null.\n */\nL.isNull = function(o) {\n\treturn o === null;\n};\n\n/**\n * Determines whether or not the provided item is undefined.\n * @method isUndefined\n * @static\n * @param o The object to test.\n * @return {boolean} true if o is undefined.\n */\nL.isUndefined = function(o) {\n\treturn typeof o === 'undefined';\n};\n\n/**\n * Determines whether or not the provided item is of type object\n * or function. Note that arrays are also objects, so\n * <code>Y.Lang.isObject([]) === true</code>.\n * @method isObject\n * @static\n * @param o The object to test.\n * @param failfn {boolean} fail if the input is a function.\n * @return {boolean} true if o is an object.\n * @see isPlainObject\n */\nL.isObject = function(o, failfn) {\n\tvar t = typeof o;\n\treturn (o && (t === 'object' || (!failfn && (t === 'function' || L.isFunction(o))))) || false;\n};\n/**\n * Determines whether or not the provided item is an array.\n *\n * Returns `false` for array-like collections such as the function `arguments`\n * collection or `HTMLElement` collections.\n *\n * @method isArray\n * @param o The object to test.\n * @return {boolean} true if o is an array.\n * @static\n */\nL.isArray = (!unsafeNatives && Array.isArray) ||\nfunction(o) {\n\treturn L.type(o) === 'array';\n};\n\nL.isFunction = function isFunctionA(o) {\n\treturn (typeof(o) === \"function\");\n};\n\n/**\n * Determines whether or not the provided item is a boolean.\n * @method isBoolean\n * @static\n * @param o The object to test.\n * @return {boolean} true if o is a boolean.\n */\nL.isBoolean = function(o) {\n\treturn typeof o === 'boolean';\n};\n\n/**\n * Determines whether or not the supplied item is a date instance.\n * @method isDate\n * @static\n * @param o The object to test.\n * @return {boolean} true if o is a date.\n */\nL.isDate = function(o) {\n\treturn L.type(o) === 'date' && o.toString() !== 'Invalid Date' && !isNaN(o);\n};\n\n/**\n * Determines whether or not the provided item is a legal number.\n * @method isNumber\n * @static\n * @param o The object to test.\n * @return {boolean} true if o is a number.\n */\nL.isNumber = function(o) {\n\treturn typeof o === 'number' && isFinite(o);\n};\n\n/**\n * Determines whether or not the provided item is a string.\n * @method isString\n * @static\n * @param o The object to test.\n * @return {boolean} true if o is a string.\n */\nL.isString = function(o) {\n\treturn typeof o === 'string';\n};\n\n/**\n * Returns a string representing the type of the item passed in.\n *\n * @method type\n * @param o the item to test.\n * @return {string} the detected type.\n * @static\n */\nL.type = function(o) {\n\treturn TYPES[ typeof o] || TYPES[TOSTRING.call(o)] || ( o ? 'object' : 'null');\n};\n\nmodule.exports = L;","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n \nvar Logger = {},\n    loggerMap = {},\n    globalLogger;\n\n/**\n * Universal stdout|stderr printer\n */\nfunction log(messages, context) {\t\n\tif (!console) { return; }\n\n\tfunction sep(level) {\n\t\tvar sep = '=========================================================' +\n\t\t          '=========================================================\\n',\n\t\t    offset = 0;\n\n\t\tif (level === Logger.DEBUG || level === Logger.ERROR) offset = 8;\n\t\telse if (level === Logger.INFO || level === Logger.WARN) offset = 8;\n\t\telse offset = 7;\n\n\t\treturn { start: sep.substring(offset), end: sep };\n\t}\n\n\tvar hdlr,\n\t    args = Array.prototype.slice.call(messages, 0),\n\t    name = context.name,\n\t    error = context.level === Logger.ERROR,\n  \t    delim = sep(context.level);\n\n  \tif (context.level === Logger.WARN && console.warn) {\n  \t\thdlr = 'warn';\n  \t} else if (context.level === Logger.ERROR && console.error) {\n  \t\thdlr = 'error';\n  \t} else if (context.level === Logger.INFO && console.info) {\n  \t\thdlr = 'info';\n  \t} else {\n  \t\thdlr = 'log';\n  \t}\n\n  \t// -- custom format logging statement for deployr request/response/error --\n  \targs.unshift('[' + (error ? Logger.ERROR.name : name) + '] ' + delim.start);\n  \targs.push(delim.end);\n\n  \tconsole[hdlr](args[0], [args[1] + ' ---> ' + args[2]['call']]);\n\n    for (var i = 2; i < args.length; i++) { console.log(args[i]); }  \n}\n\n/**\n * Logging category by id.\n */\nfunction Category(id, level, fn) {\n\tthis.id = id;\n\tthis.context = level || Logger.DEBUG;\n}\n\nCategory.prototype = {\t\n\tlog: function(level, msgArgs) {\n\t\tif (level.value >= this.context.value) {\t\t\t\n\t\t\tlog(msgArgs, { \n\t\t\t\tlevel: level,\n\t\t\t\tname: this.context.name,\n\t\t\t\tvalue: this.context.value\n\t\t\t});\t\t\n\t\t}\n\t},\n\n\tdebug: function () {\t\t\n\t\tthis.log(Logger.DEBUG, arguments);\n\t},\n\n\terror: function () {\n\t\tthis.log(Logger.ERROR, arguments);\n\t},\n\n\tinfo: function () {\t\t\n\t\tthis.log(Logger.INFO, arguments);\n\t},\n\n\twarn: function () {\n\t\tthis.log(Logger.WARN, arguments);\n\t},\n\n\tsetLevel: function(level) {\n\t\tif (level && 'value' in level) {\n\t\t\tthis.context = level;\n\t\t}\n\t}\n};\n\nLogger.DEBUG = { value: 1, name: 'DEBUG' };\nLogger.INFO  = { value: 2, name: 'INFO' };\nLogger.WARN  = { value: 4, name: 'WARN' };\nLogger.ERROR = { value: 8, name: 'ERROR' };\nLogger.OFF   = { value: 99, name: 'OFF' };   \t\t\n\nLogger.setLevel = function(newLevel) {\n\tglobalLogger.setLevel(newLevel);\n};\n\nLogger.debug = function () {\n\tglobalLogger.debug.apply(globalLogger, arguments);\n};\n\nLogger.info = function () {\n\tglobalLogger.info.apply(globalLogger, arguments);\n};\n\nLogger.warn = function () {\n\tglobalLogger.warn.apply(globalLogger, arguments);\n};\n\nLogger.error = function () {\n\tglobalLogger.error.apply(globalLogger, arguments);\n};\n\nLogger.get = function (id, level, fn) {\t\n\treturn (loggerMap[id] || (function() {\n\t\tloggerMap[id] = new Category(id, level, fn);\n\t\treturn loggerMap[id];\n\t})());\n};\n\n// --- setup the global logger ---\nglobalLogger = Logger.get('global');\n\nmodule.exports \t= Logger;\n","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n \nmodule.exports = function(module) {\n  try {\n    return require(module);\n  } catch (e) {}\n};","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nfunction Queue() {\n  this.emptyCallback = null;\n  this.callbacks = [];\n  this.yielded = false;\n  this.response = null;\n  this.responseChain = [];  \n}\n\nQueue.prototype = {\n\n  add: function(fn, ctx, defer) {\n    // currently not waiting and there is no defer delay just make call\n    if (!this.yielded && !defer) {      \n      fn.apply(ctx || this, [this.response]);\n    } else { // add to queue\n      this.callbacks.push({ fn: fn, ctx: ctx });\n    }\n  },\n\n  size: function() {\n    return this.callbacks.length;\n  },\n\n  isEmpty: function() {\n    return this.callbacks.length === 0;\n  },\n\n  empty: function(fn, ctx) {\n    this.emptyCallback = { fn: fn, ctx: ctx };\n  },\n\n  yield: function(yield) {\n    this.yielded = yield;\n  },\n\n  take: function(response, error, args) { \n    var cb;\n\n    if (response) {\n      this.response = response;\n      this.responseChain.push(response);\n    }\n\n\n    if (!this.yielded && this.callbacks[0]) {\n      cb = this.callbacks.shift();\n      cb.fn.apply(cb.ctx || this, [this.responseChain, error, args]);\n\n      // notify that the queue is now empty   \n      if (this.callbacks[0] && this.emptyCallback) {\n        this.emptyCallback.fn.call(this.emptyCallback.ctx || this);         \n      }\n    }\n  },\n  \n  flush: function(response, error, args) {        \n    if (response) {\n      this.response = response;\n      this.responseChain.push(response);\n    }\n\n    // pop and call next inline\n    while (this.callbacks[0]) {\n      if (this.yielded) { break; }\n      var cb = this.callbacks.shift();\n      cb.fn.apply(cb.ctx || this, [this.responseChain, error, args]);\n\n      // notify that the queue is now empty\n      if (this.callbacks[0] && this.emptyCallback) {\n        this.emptyCallback.fn.call(this.emptyCallback.ctx || this);         \n      }\n    }\n  }\n};\n\nmodule.exports = Queue;","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nvar Base   = require('./selfish').Base,\n    RTypes = require('./rtypes');\n\nmodule.exports = Base.extend(RTypes, {\n\tinitialize: function initialize(name, value, options) {  \t\n\t\tthis.name  = name;\n\t\tthis.value = value;\n\t\tthis.options = options || {};\n\t},\n\n\tnumeric: function () {\n\t\t// support `String` numbers (e.g. \"1.2\")\n\t\tthis.value = parseFloat(this.value);\n\n\t\treturn this.assert({\n\t\t\ttype: this.deployr.RNUMERIC,\n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t});\n\t},\t\n\n\tinteger: function () {\n\t\t// support `String` integer (e.g. \"15\")\n\t\tthis.value = parseInt(this.value, 10);\n\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RINTEGER,\n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tlogical: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RBOOLEAN, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tcharacter: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RSTRING, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tdate: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RDATE,\n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\tformat: 'yyyy-MM-dd',\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\tposixct: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RPOSIX_DATE, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\tformat: 'yyyy-MM-dd HH:mm:ss Z',\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\t\n\t\n\tnumericVector: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RNUMERIC_VECTOR,\n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tintegerVector: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RINTEGER_VECTOR, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tlogicalVector: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RBOOLEAN_VECTOR, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tcharacterVector: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RSTRING_VECTOR, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},  \n\t\n\tdateVector: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RDATE_VECTOR, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\tformat: 'yyyy-MM-dd',\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\t\n\t\n\tposixctVector: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RPOSIX_DATE_VECTOR, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\tformat: 'yyyy-MM-dd HH:mm:ss Z',\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tlist: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RLIST, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\t\n\tdataframe: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RDATAFRAME, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\tfactor: function () {\n\t\tvar opts = this.options;\n\n\t\treturn this.assert( { \n\t\t\ttype: this.deployr.RFACTOR, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\tordered: false,\n\t\t\tlevels: opts.levels,\n\t\t\tlabels: opts.labels,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\tordered: function () {\n\t\tvar opts = this.options;\n\n\t\treturn this.assert( { \n\t\t\ttype: this.deployr.RORDERED, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\tordered: true,\n\t\t\tlevels: opts.levels,\n\t\t\tlabels: opts.labels,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\t\t\n\n\tnumericMatrix: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RNUMERIC_MATRIX, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\tintegerMatrix: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RINTEGER_MATRIX, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\tlogicalMatrix: function () { \n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RBOOLEAN_MATRIX, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\tcharacterMatrix: function () {\n\t\treturn this.assert({ \n\t\t\ttype: this.deployr.RSTRING_MATRIX, \n\t\t\tname: this.name, \n\t\t\tvalue: this.value,\n\t\t\ttoString: this.toString\n\t\t}); \n\t},\n\n\ttoString: function() {\n\t\tvar opts   = this.options || {},\n\t\t    levels = opts.levels ? '[ levels = ' + opts.levels + ']' : '',\n\t\t    labels = opts.labels ? '[ labels = ' + opts.labels + ']' : '';\n\n\t\treturn '[ name = '  + this.name + ' ] ' +\n\t\t       '[ value = ' + this.value + ' ] ' +\n\t\t       '[ type = '  + this.type + ' ] ' +\n\t\t       levels + labels;\t\t       \n\t}\n});","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nvar Base   = require('./selfish').Base,\n    RTypes = require('./rtypes'),\n    Lang   = require('./lang'),\n    RInput = require('./rinput'); \n\nfunction create(type, name, value, options) {\n\tvar rinput;\n\n\tif (Lang.isObject(name)) {\n\t\trinput = name;\n\t\tif (!rinput.type !== type) {\n\t\t\tthrow new Error('IllegalArgumentError:' + \n\t\t\t\t'Expecting \"' + type + '\" but found \"' + rinput.type + '\"');\n\t\t}\n\t} else {\n\t    rinput = RInput.new(name, value, options)[type]();\n\t} \n\n\treturn rinput;\n}\n\nmodule.exports = Base.extend(RTypes, {\t\n\tnumeric: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RNUMERIC, name, value));\n\t\treturn this;\n\t},\n\t\n\tinteger: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RINTEGER, name, value));\n\t\treturn this; \n\t},\n\t\n\tlogical: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RBOOLEAN, name, value));\n\t\treturn this; \n\t},\n\t\n\tcharacter: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RSTRING, name, value));\n\t\treturn this; \n\t},\n\t\n\tdate: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RDATE, name, value));\n\t\treturn this; \n\t},\n\n\tposixct: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RPOSIX_DATE, name, value));\n\t\treturn this; \n\t},\t\n\t\n\tnumericVector: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RNUMERIC_VECTOR, name, value));\n\t\treturn this; \n\t},\n\t\n\tintegerVector: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RINTEGER_VECTOR, name, value));\n\t\treturn this; \n\t},\n\t\n\tlogicalVector: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RBOOLEAN_VECTOR, name, value));\n\t\treturn this; \n\t},\n\t\n\tcharacterVector: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RSTRING_VECTOR, name, value));\n\t\treturn this; \n\t},  \n\t\n\tdateVector: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RDATE_VECTOR, name, value));\n\t\treturn this; \n\t},\t\n\t\n\tposixctVector: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RPOSIX_DATE_VECTOR, name, value));\n\t\treturn this; \n\t},\n\t\n\tlist: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RLIST, name, value));\n\t\treturn this; \n\t},\n\t\n\tdataframe: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RDATAFRAME, name, value));\n\t\treturn this; \n\t},\t\n\n\tfactor: function (name, value, levels, labels) {\n\t\tvar opts = { levels: levels, labels: labels };\n\t\tthis.inputs.push(create(this.deployr.RFACTOR, name, value, opts));\n\t\treturn this;\n\t},\n\n\tordered: function (name, value, levels, labels) {\n\t\tvar opts = { levels: levels, labels: labels };\n\t\tthis.inputs.push(create(this.deployr.RORDERED, name, value, opts));\n\t\treturn this;\n\t},\t\t\n\n\tnumericMatrix: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RNUMERIC_MATRIX, name, value));\n\t\treturn this; \n\t},\n\n\tintegerMatrix: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RINTEGER_MATRIX, name, value));\n\t\treturn this; \n\t},\n\n\tlogicalMatrix: function (name, value) { \n\t\tthis.inputs.push(create(this.deployr.RBOOLEAN_MATRIX, name, value));\n\t\treturn this; \n\t},\n\n\tcharacterMatrix: function (name, value) {\n\t\tthis.inputs.push(create(this.deployr.RSTRING_MATRIX, name, value));\n\t\treturn this;\n\t}\n});","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more \n * details.\n */\n\nvar Base = require('./selfish').Base,\n    Lang = require('./lang'),\n    map  = {}; // deployr->To->R catalog\n\nmodule.exports = Base.extend({\n\tr: {\n\t\tPRIMITIVE: 'primitive',\n\t\tDATAFRAME: 'dataframe',\n\t\tLIST: 'list',\n\t\tMATRIX: 'matrix',\n\t\tDATE: 'date',\n\t\tFACTOR: 'factor',\n\t\tVECTOR: 'vector'\n\t},\n\n\tdeployr: {\n\t\tRBOOLEAN: 'logical',\n\t\tRNUMERIC: 'numeric',\n\t\tRINTEGER: 'integer',\n\t\tRSTRING: 'character',\n\t\tRDATE: 'date',\n\t\tRPOSIX_DATE: 'posixct',\n\t\tRBOOLEAN_VECTOR: 'logicalVector',\n\t\tRNUMERIC_VECTOR:'numericVector',\n\t\tRINTEGER_VECTOR: 'integerVector',\t\n\t\tRSTRING_VECTOR: 'characterVector',\n\t\tRDATE_VECTOR: 'dateVector',\n\t\tRPOSIX_DATE_VECTOR: 'posixctVector',\n\t\tRLIST: 'list',\n\t\tRDATAFRAME: 'dataframe',\n\t\tRFACTOR: 'factor',\n\t\tRORDERED: 'ordered',\t\t\n\t\tRBOOLEAN_MATRIX: 'logicalMatrix',\n\t\tRNUMERIC_MATRIX: 'numericMatrix',\n\t\tRINTEGER_MATRIX: 'integerMatrix',\t\t\n\t\tRSTRING_MATRIX: 'characterMatrix'\n\t},\n\n\tisDate: function(type) {\n\t\treturn (type === this.deployr.RDATE || \n\t\t        type === this.deployr.RPOSIX_DATE || \n\t\t        type === this.deployr.RDATE_VECTOR ||\n\t\t        type === this.deployr.RPOSIX_DATE_VECTOR ||\n\t\t        type === this.r.DATE);\n\t},\n\n\tdeployrToR: function(type) {\t\n\t\tvar deployr = this.deployr,\n\t\t    r       = this.r;\n\n\t\tif (!map[type]) { // build catalog only once\t\n\t\t\tmap[deployr.RBOOLEAN]           = r.PRIMITIVE;\n\t\t\tmap[deployr.RNUMERIC]           = r.PRIMITIVE;\n\t\t\tmap[deployr.RINTEGER]           = r.PRIMITIVE;\n\t\t\tmap[deployr.RSTRING]            = r.PRIMITIVE;\n\t\t\tmap[deployr.RDATE]              = r.DATE;\n\t\t\tmap[deployr.RPOSIX_DATE]        = r.DATE;\n\t\t\tmap[deployr.RBOOLEAN_VECTOR]    = r.VECTOR;\n\t\t\tmap[deployr.RNUMERIC_VECTOR]    = r.VECTOR;\n\t\t\tmap[deployr.RINTEGER_VECTOR]    = r.VECTOR;\n\t\t\tmap[deployr.RSTRING_VECTOR]     = r.VECTOR;\n\t\t\tmap[deployr.RDATE_VECTOR]       = r.VECTOR;\n\t\t\tmap[deployr.RPOSIX_DATE_VECTOR] = r.VECTOR;\n\t\t\tmap[deployr.RLIST]              = r.LIST;\n\t\t\tmap[deployr.RDATAFRAME]         = r.DATAFRAME;\n\t\t\tmap[deployr.RFACTOR]            = r.FACTOR;\n\t\t\tmap[deployr.RORDERED]           = r.FACTOR;\n\t\t\tmap[deployr.RBOOLEAN_MATRIX]    = r.MATRIX;\n\t\t\tmap[deployr.RNUMERIC_MATRIX]    = r.MATRIX;\n\t\t\tmap[deployr.RINTEGER_MATRIX]    = r.MATRIX;\n\t\t\tmap[deployr.RSTRING_MATRIX]     = r.MATRIX;\n\t\t}\n\n\t\treturn map[type];\t\t\n\t},\n\n\t/**\n\t * Assert that the `rinput` value is the correct JavaScript Data Type.\n\t */\n\tassert: function (rinput) {\n\t\tvar deployr = this.deployr,\n    \t\tNOOP    = null,\n\t\t    values  = rinput.value,\n\t\t    fn;\n\n\t\tvalues = !Lang.isArray(values) ? [values] : values;\n\n\t\tfor (var i = 0; i < values.length; i++) {\n\t\t\tvar value = values[i];\n\n\t\t\tswitch (rinput.type) {\n\t\t\t\tcase deployr.RNUMERIC :\n\t\t\t\tcase deployr.RNUMERIC_VECTOR :\n\t\t\t    case deployr.RINTEGER :\n\t\t\t    case deployr.RINTEGER_VECTOR :\n\t\t\t    fn = Lang.isNumber;\n\t\t\t    break;\n\n\t\t\t    case deployr.RBOOLEAN :\n\t\t\t    case deployr.RBOOLEAN_VECTOR :\n\t\t\t    fn = Lang.isBoolean;\n\t\t\t    break;\n\t\t\t    \n\t\t\t    case deployr.RSTRING :\n\t\t\t    case deployr.RSTRING_VECTOR :\t\n\t\t\t    fn = Lang.isString;\n\t\t\t    break;\n\n\t\t\t    case deployr.RDATE :\n\t\t\t    case deployr.RPOSIX_DATE :\n\t\t\t    case deployr.RDATE_VECTOR :\n\t\t\t    case deployr.RPOSIX_DATE_VECTOR :\n\t\t\t    fn = Lang.isDate;\n\t\t\t    break;\n\n\t\t\t    case deployr.RFACTOR :\n\t\t\t    case deployr.RORDERED :\t\t\t    \n\t\t\t    case deployr.RDATAFRAME :\n\t\t\t    case deployr.RINTEGER_MATRIX :\n\t\t\t    case deployr.RBOOLEAN_MATRIX :\n\t\t\t    case deployr.RSTRING_MATRIX :\t    \n\t\t\t    fn = NOOP;\n\t\t\t    break\n\t\t\t}\n\n\t\t\tif (fn && !fn(value)) {\n\t\t\t\tthrow new Error('RInputFormatError: ' + '\"' + value + \n\t\t\t\t\t'\" is not a valid \"' + rinput.type + '\" type for input ' +\n\t\t\t\t\t'\"' + rinput.name + '\"');\t\t\t\t\t\n\t\t\t}\n\t\t}\n\n\t\treturn rinput;\n\t}\n});","/*!\n * https://github.com/Gozala/selfish\n */\n\n/* vim:set ts=2 sw=2 sts=2 expandtab */\n/*jshint undef: true es5: true node: true devel: true evil: true\n         forin: true latedef: false supernew: true */\n/*global define: true */\n\n!(typeof define !== \"function\" ? function($){ $(null, typeof exports !== 'undefined' ? exports : window); } : define)(function(require, exports) {\n\n\"use strict\";\n\nexports.Base = Object.freeze(Object.create(Object.prototype, {\n  /**\n   * Creates an object that inherits from `this` object (Analog of\n   * `new Object()`).\n   * @examples\n   *\n   *    var Dog = Base.extend({\n   *      bark: function bark() {\n   *        return 'Ruff! Ruff!'\n   *      }\n   *    });\n   *    var dog = Dog.new();\n   */\n  'new': { value: function create() {\n    var object = Object.create(this);\n    object.initialize.apply(object, arguments);\n    return object;\n  }},\n  /**\n   * When new instance of the this prototype is created it's `initialize`\n   * method is called with all the arguments passed to the `new`. You can\n   * override `initialize` to set up an instance.\n   */\n  initialize: { value: function initialize() {\n  }},\n  /**\n   * Merges all the properties of the passed objects into `this` instance (This\n   * method can be used on instances only as prototype objects are frozen).\n   *\n   * If two or more argument objects have own properties with the same name,\n   * the property is overridden, with precedence from right to left, implying,\n   * that properties of the object on the left are overridden by a same named\n   * property of the object on the right.\n   *\n   * @examples\n   *\n   *    var Pet = Dog.extend({\n   *      initialize: function initialize(options) {\n   *        // this.name = options.name -> would have thrown (frozen prototype)\n   *        this.merge(options) // will override all properties.\n   *      },\n   *      call: function(name) {\n   *        return this.name === name ? this.bark() : ''\n   *      },\n   *      name: null\n   *    })\n   *    var pet = Pet.new({ name: 'Benzy', breed: 'Labrador' })\n   *    pet.call('Benzy')   // 'Ruff! Ruff!'\n   */\n  merge: { value: function merge() {\n    var descriptor = {};\n    Array.prototype.forEach.call(arguments, function (properties) {\n      Object.getOwnPropertyNames(properties).forEach(function(name) {\n        descriptor[name] = Object.getOwnPropertyDescriptor(properties, name);\n      });\n    });\n    Object.defineProperties(this, descriptor);\n    return this;\n  }},\n  /**\n   * Takes any number of argument objects and returns frozen, composite object\n   * that inherits from `this` object and combines all of the own properties of\n   * the argument objects. (Objects returned by this function are frozen as\n   * they are intended to be used as types).\n   *\n   * If two or more argument objects have own properties with the same name,\n   * the property is overridden, with precedence from right to left, implying,\n   * that properties of the object on the left are overridden by a same named\n   * property of the object on the right.\n   * @examples\n   *\n   *    // ## Object composition ##\n   *\n   *    var HEX = Base.extend({\n   *      hex: function hex() {\n   *        return '#' + this.color;\n   *      }\n   *    })\n   *\n   *    var RGB = Base.extend({\n   *      red: function red() {\n   *        return parseInt(this.color.substr(0, 2), 16);\n   *      },\n   *      green: function green() {\n   *        return parseInt(this.color.substr(2, 2), 16);\n   *      },\n   *      blue: function blue() {\n   *        return parseInt(this.color.substr(4, 2), 16);\n   *      }\n   *    })\n   *\n   *    var CMYK = Base.extend(RGB, {\n   *      black: function black() {\n   *        var color = Math.max(Math.max(this.red(), this.green()), this.blue());\n   *        return (1 - color / 255).toFixed(4);\n   *      },\n   *      cyan: function cyan() {\n   *        var K = this.black();\n   *        return (((1 - this.red() / 255).toFixed(4) - K) / (1 - K)).toFixed(4);\n   *      },\n   *      magenta: function magenta() {\n   *        var K = this.black();\n   *        return (((1 - this.green() / 255).toFixed(4) - K) / (1 - K)).toFixed(4);\n   *      },\n   *      yellow: function yellow() {\n   *        var K = this.black();\n   *        return (((1 - this.blue() / 255).toFixed(4) - K) / (1 - K)).toFixed(4);\n   *      }\n   *    })\n   *\n   *    var Color = Base.extend(HEX, RGB, CMYK, {\n   *      initialize: function Color(color) {\n   *        this.color = color;\n   *      }\n   *    });\n   *\n   *    // ## Prototypal inheritance ##\n   *\n   *    var Pixel = Color.extend({\n   *      initialize: function Pixel(x, y, hex) {\n   *        Color.initialize.call(this, hex);\n   *        this.x = x;\n   *        this.y = y;\n   *      },\n   *      toString: function toString() {\n   *        return this.x + ':' + this.y + '@' + this.hex();\n   *      }\n   *    });\n   *\n   *    var pixel = Pixel.new(11, 23, 'CC3399')\n   *    pixel.toString(); // 11:23@#CC3399\n   *\n   *    pixel.red();      // 204\n   *    pixel.green();    // 51\n   *    pixel.blue();     // 153\n   *\n   *    pixel.cyan();     // 0.0000\n   *    pixel.magenta();  // 0.7500\n   *    pixel.yellow();   // 0.2500\n   *\n   */\n   extend: { value: function extend() {\n    return Object.freeze(this.merge.apply(Object.create(this), arguments));\n  }}\n}));\n\n});","/*!\n * Copyright (C) 2010-2014 by Revolution Analytics Inc.\n *\n * This program is licensed to you under the terms of Version 2.0 of the\n * Apache License. This program is distributed WITHOUT\n * ANY EXPRESS OR IMPLIED WARRANTY, INCLUDING THOSE OF NON-INFRINGEMENT,\n * MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Please refer to the\n * Apache License 2.0 (http://www.apache.org/licenses/LICENSE-2.0) for more\n * details.\n */\n\nvar Lang = require('./lang');\n\nvar get = exports.get = function(s, key) {\n    function traverse(obj, fn, parent) {\n        for (var i in obj) {\n            var result = fn.apply(this, [i, obj[i], parent]);\n            if (result) {\n                return result;\n            } else {\n                if (obj[i] instanceof Object && !(obj[i] instanceof Array)) {                \n                   traverse(obj[i], fn, i);\n               }\n            }\n        }\n    }\n\n    function getProperty(obj, property) {\n        var acc = {};\n        traverse(obj, function(key, value, parent) {\n            if (key === property) {  \n                acc = value;\n                return acc;\n            } else {\n                return null;\n            }\n        });\n        return acc;\n    }\n\n    function empty(obj) {\n        for (var prop in obj) { if (obj.hasOwnProperty(prop)) return obj; }\n        return !Lang.isObject(obj) ? obj : null;\n    }\n\n    return empty(getProperty(s, key));\n};\n\nvar inArray = exports.inArray = function(haystack, needle, key) {\n    var i, max = haystack.length;\n\n    for (i = 0; i < max; i++) {\n        if (key) {\n            if (haystack[i][key] === needle) { return haystack[i]; }\n        } else {\n            if (haystack[i] === needle) { return haystack[i]; }\n        }   \n    }\n    return null;\n};\n\nexports.merge = function(to, from) {        \n    if (!to || typeof(to) !== 'object') { to = {}; }\n    if (!from || typeof(from) !== 'object') { from = {}; }\n\n    for (var k in from) { to[k] = from[k]; }\n\n    return to;\n};\n\nexports.workspace = function(obj, name) {\n    var ws = get(obj, 'workspace');\n    return (ws ? name ? inArray(ws.objects, name, 'name') : ws.objects || ws.object: null);\n};\n\nexports.signature = function() {\n    var args   = Array.prototype.slice.call(arguments['0'], 0),\n        len    = args.length,\n        create = false,\n        opts   = {},\n        api;\n\n    if (len === 1 && Lang.isObject(args[0])) {\n        opts = args[0];\n        api  = opts.project ? '/r/project/execute/script' :\n            '/r/repository/script/execute';\n    } else if (len === 1 && Lang.isString(args[0])) {\n        args = args[0].split('\\/');\n        api  = '/r/repository/script/execute'\n        opts = {\n            author: args[1],\n            directory: args[2],\n            filename: args[3]\n        };\n    } else if (len === 2) {\n        // ex: .script('/testuser/root/DeployR - Hello World.R', project)\n        var project = args[1];\n        api = project ? '/r/project/execute/script' : '/r/repository/script/execute';\n\n        args = args[0].split('\\/');\n        opts = {\n            project: project,\n            author: args[1],\n            directory: args[2],\n            filename: args[3]\n        };\n    } else if (len > 2) {\n        // ex: .script('DeployR - Hello World.R', 'testuser', 'root')\n        opts = {\n            author: args[2],\n            directory: args[1],\n            filename: args[0]\n        };\n    }\n\n    // indicate a new project should be created\n    if (opts.project && Lang.isBoolean(opts.project)) {\n      delete opts['project'];\n      create = true;\n    }\n\n    return {\n        api: api,\n        opts: opts,\n        create: create\n    };\n};",null,"// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    draining = true;\n    var currentQueue;\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        var i = -1;\n        while (++i < len) {\n            currentQueue[i]();\n        }\n        len = queue.length;\n    }\n    draining = false;\n}\nprocess.nextTick = function (fun) {\n    queue.push(fun);\n    if (!draining) {\n        setTimeout(drainQueue, 0);\n    }\n};\n\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\n// TODO(shtylman)\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","(function (process){\n/**\n* attempt of a simple defer/promise library for mobile development\n* @author Jonathan Gotti < jgotti at jgotti dot net>\n* @since 2012-10\n* @version 0.6.0\n* @changelog\n*           - 2013-12-07 - last promise 1.1 specs test passings (thx to wizardwerdna)\n *                       - reduce promises footprint by unscoping methods that could be\n*           - 2013-10-23 - make it workig across node-webkit contexts\n*           - 2013-07-03 - bug correction in promixify method (thx to adrien gibrat )\n*           - 2013-06-22 - bug correction in nodeCapsule method\n*           - 2013-06-17 - remove unnecessary Array.indexOf method dependency\n*           - 2013-04-18 - add try/catch block around nodeCapsuled methods\n*           - 2013-04-13 - check promises/A+ conformity\n*                        - make some minication optimisations\n*           - 2013-03-26 - add resolved, fulfilled and rejected methods\n*           - 2013-03-21 - browser/node compatible\n*                        - new method nodeCapsule\n*                        - simpler promixify with full api support\n*           - 2013-01-25 - add rethrow method\n*                        - nextTick optimisation -> add support for process.nextTick + MessageChannel where available\n*           - 2012-12-28 - add apply method to promise\n*           - 2012-12-20 - add alwaysAsync parameters and property for default setting\n*/\n(function(undef){\n\t\"use strict\";\n\n\tvar nextTick\n\t\t, isFunc = function(f){ return ( typeof f === 'function' ); }\n\t\t, isArray = function(a){ return Array.isArray ? Array.isArray(a) : (a instanceof Array); }\n\t\t, isObjOrFunc = function(o){ return !!(o && (typeof o).match(/function|object/)); }\n\t\t, isNotVal = function(v){ return (v === false || v === undef || v === null); }\n\t\t, slice = function(a, offset){ return [].slice.call(a, offset); }\n\t\t, undefStr = 'undefined'\n\t\t, tErr = typeof TypeError === undefStr ? Error : TypeError\n\t;\n\tif ( (typeof process !== undefStr) && process.nextTick ) {\n\t\tnextTick = process.nextTick;\n\t} else if ( typeof MessageChannel !== undefStr ) {\n\t\tvar ntickChannel = new MessageChannel(), queue = [];\n\t\tntickChannel.port1.onmessage = function(){ queue.length && (queue.shift())(); };\n\t\tnextTick = function(cb){\n\t\t\tqueue.push(cb);\n\t\t\tntickChannel.port2.postMessage(0);\n\t\t};\n\t} else {\n\t\tnextTick = function(cb){ setTimeout(cb, 0); };\n\t}\n\tfunction rethrow(e){ nextTick(function(){ throw e;}); }\n\n\t/**\n\t * @typedef deferred\n\t * @property {promise} promise\n\t * @method resolve\n\t * @method fulfill\n\t * @method reject\n\t */\n\n\t/**\n\t * @typedef {function} fulfilled\n\t * @param {*} value promise resolved value\n\t * @returns {*} next promise resolution value\n\t */\n\n\t/**\n\t * @typedef {function} failed\n\t * @param {*} reason promise rejection reason\n\t * @returns {*} next promise resolution value or rethrow the reason\n\t */\n\n\t//-- defining unenclosed promise methods --//\n\t/**\n\t * same as then without failed callback\n\t * @param {fulfilled} fulfilled callback\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_success(fulfilled){ return this.then(fulfilled, undef); }\n\n\t/**\n\t * same as then with only a failed callback\n\t * @param {failed} failed callback\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_error(failed){ return this.then(undef, failed); }\n\n\n\t/**\n\t * same as then but fulfilled callback will receive multiple parameters when promise is fulfilled with an Array\n\t * @param {fulfilled} fulfilled callback\n\t * @param {failed} failed callback\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_apply(fulfilled, failed){\n\t\treturn this.then(\n\t\t\tfunction(a){\n\t\t\t\treturn isFunc(fulfilled) ? fulfilled.apply(null, isArray(a) ? a : [a]) : (defer.onlyFuncs ? a : fulfilled);\n\t\t\t}\n\t\t\t, failed || undef\n\t\t);\n\t}\n\n\t/**\n\t * cleanup method which will be always executed regardless fulfillment or rejection\n\t * @param {function} cb a callback called regardless of the fulfillment or rejection of the promise which will be called\n\t *                      when the promise is not pending anymore\n\t * @returns {promise} the same promise untouched\n\t */\n\tfunction promise_ensure(cb){\n\t\tfunction _cb(){ cb(); }\n\t\tthis.then(_cb, _cb);\n\t\treturn this;\n\t}\n\n\t/**\n\t * take a single callback which wait for an error as first parameter. other resolution values are passed as with the apply/spread method\n\t * @param {function} cb a callback called regardless of the fulfillment or rejection of the promise which will be called\n\t *                      when the promise is not pending anymore with error as first parameter if any as in node style\n\t *                      callback. Rest of parameters will be applied as with the apply method.\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_nodify(cb){\n\t\treturn this.then(\n\t\t\tfunction(a){\n\t\t\t\treturn isFunc(cb) ? cb.apply(null, isArray(a) ? a.splice(0,0,undefined) && a : [undefined,a]) : (defer.onlyFuncs ? a : cb);\n\t\t\t}\n\t\t\t, function(e){\n\t\t\t\treturn cb(e);\n\t\t\t}\n\t\t);\n\t}\n\n\t/**\n\t *\n\t * @param {function} [failed] without parameter will only rethrow promise rejection reason outside of the promise library on next tick\n\t *                            if passed a failed method then will call failed on rejection and throw the error again if failed didn't\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_rethrow(failed){\n\t\treturn this.then(\n\t\t\tundef\n\t\t\t, failed ? function(e){ failed(e); throw e; } : rethrow\n\t\t);\n\t}\n\n\t/**\n\t* @param {boolean} [alwaysAsync] if set force the async resolution for this promise independantly of the D.alwaysAsync option\n\t* @returns {deferred} defered object with property 'promise' and methods reject,fulfill,resolve (fulfill being an alias for resolve)\n\t*/\n\tvar defer = function (alwaysAsync){\n\t\tvar alwaysAsyncFn = (undef !== alwaysAsync ? alwaysAsync : defer.alwaysAsync) ? nextTick : function(fn){fn();}\n\t\t\t, status = 0 // -1 failed | 1 fulfilled\n\t\t\t, pendings = []\n\t\t\t, value\n\t\t\t/**\n\t\t\t * @typedef promise\n\t\t\t */\n\t\t\t, _promise  = {\n\t\t\t\t/**\n\t\t\t\t * @param {fulfilled|function} fulfilled callback\n\t\t\t\t * @param {failed|function} failed callback\n\t\t\t\t * @returns {promise} a new promise\n\t\t\t\t */\n\t\t\t\tthen: function(fulfilled, failed){\n\t\t\t\t\tvar d = defer();\n\t\t\t\t\tpendings.push([\n\t\t\t\t\t\tfunction(value){\n\t\t\t\t\t\t\ttry{\n\t\t\t\t\t\t\t\tif( isNotVal(fulfilled)){\n\t\t\t\t\t\t\t\t\td.resolve(value);\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\td.resolve(isFunc(fulfilled) ? fulfilled(value) : (defer.onlyFuncs ? value : fulfilled));\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}catch(e){\n\t\t\t\t\t\t\t\td.reject(e);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\t, function(err){\n\t\t\t\t\t\t\tif ( isNotVal(failed) || ((!isFunc(failed)) && defer.onlyFuncs) ) {\n\t\t\t\t\t\t\t\td.reject(err);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tif ( failed ) {\n\t\t\t\t\t\t\t\ttry{ d.resolve(isFunc(failed) ? failed(err) : failed); }catch(e){ d.reject(e);}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t]);\n\t\t\t\t\tstatus !== 0 && alwaysAsyncFn(execCallbacks);\n\t\t\t\t\treturn d.promise;\n\t\t\t\t}\n\n\t\t\t\t, success: promise_success\n\n\t\t\t\t, error: promise_error\n\t\t\t\t, otherwise: promise_error\n\n\t\t\t\t, apply: promise_apply\n\t\t\t\t, spread: promise_apply\n\n\t\t\t\t, ensure: promise_ensure\n\n\t\t\t\t, nodify: promise_nodify\n\n\t\t\t\t, rethrow: promise_rethrow\n\n\t\t\t\t, isPending: function(){ return !!(status === 0); }\n\n\t\t\t\t, getStatus: function(){ return status; }\n\t\t\t}\n\t\t;\n\t\t_promise.toSource = _promise.toString = _promise.valueOf = function(){return value === undef ? this : value; };\n\n\n\t\tfunction execCallbacks(){\n\t\t\tif ( status === 0 ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tvar cbs = pendings, i = 0, l = cbs.length, cbIndex = ~status ? 0 : 1, cb;\n\t\t\tpendings = [];\n\t\t\tfor( ; i < l; i++ ){\n\t\t\t\t(cb = cbs[i][cbIndex]) && cb(value);\n\t\t\t}\n\t\t}\n\n\t\t/**\n\t\t * fulfill deferred with given value\n\t\t * @param {*} val\n\t\t * @returns {deferred} this for method chaining\n\t\t */\n\t\tfunction _resolve(val){\n\t\t\tvar done = false;\n\t\t\tfunction once(f){\n\t\t\t\treturn function(x){\n\t\t\t\t\tif (done) {\n\t\t\t\t\t\treturn undefined;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdone = true;\n\t\t\t\t\t\treturn f(x);\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t}\n\t\t\tif ( status ) {\n\t\t\t\treturn this;\n\t\t\t}\n\t\t\ttry {\n\t\t\t\tvar then = isObjOrFunc(val) && val.then;\n\t\t\t\tif ( isFunc(then) ) { // managing a promise\n\t\t\t\t\tif( val === _promise ){\n\t\t\t\t\t\tthrow new tErr(\"Promise can't resolve itself\");\n\t\t\t\t\t}\n\t\t\t\t\tthen.call(val, once(_resolve), once(_reject));\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tonce(_reject)(e);\n\t\t\t\treturn this;\n\t\t\t}\n\t\t\talwaysAsyncFn(function(){\n\t\t\t\tvalue = val;\n\t\t\t\tstatus = 1;\n\t\t\t\texecCallbacks();\n\t\t\t});\n\t\t\treturn this;\n\t\t}\n\n\t\t/**\n\t\t * reject deferred with given reason\n\t\t * @param {*} Err\n\t\t * @returns {deferred} this for method chaining\n\t\t */\n\t\tfunction _reject(Err){\n\t\t\tstatus || alwaysAsyncFn(function(){\n\t\t\t\ttry{ throw(Err); }catch(e){ value = e; }\n\t\t\t\tstatus = -1;\n\t\t\t\texecCallbacks();\n\t\t\t});\n\t\t\treturn this;\n\t\t}\n\t\treturn /**@type deferred */ {\n\t\t\tpromise:_promise\n\t\t\t,resolve:_resolve\n\t\t\t,fulfill:_resolve // alias\n\t\t\t,reject:_reject\n\t\t};\n\t};\n\n\tdefer.deferred = defer.defer = defer;\n\tdefer.nextTick = nextTick;\n\tdefer.alwaysAsync = true; // setting this will change default behaviour. use it only if necessary as asynchronicity will force some delay between your promise resolutions and is not always what you want.\n\t/**\n\t* setting onlyFuncs to false will break promises/A+ conformity by allowing you to pass non undefined/null values instead of callbacks\n\t* instead of just ignoring any non function parameters to then,success,error... it will accept non null|undefined values.\n\t* this will allow you shortcuts like promise.then('val','handled error'')\n\t* to be equivalent of promise.then(function(){ return 'val';},function(){ return 'handled error'})\n\t*/\n\tdefer.onlyFuncs = true;\n\n\t/**\n\t * return a fulfilled promise of given value (always async resolution)\n\t * @param {*} value\n\t * @returns {promise}\n\t */\n\tdefer.resolved = defer.fulfilled = function(value){ return defer(true).resolve(value).promise; };\n\n\t/**\n\t * return a rejected promise with given reason of rejection (always async rejection)\n\t * @param {*} reason\n\t * @returns {promise}\n\t */\n\tdefer.rejected = function(reason){ return defer(true).reject(reason).promise; };\n\n\t/**\n\t * return a promise with no resolution value which will be resolved in time ms (using setTimeout)\n\t * @param {int} [time] in ms default to 0\n\t * @returns {promise}\n\t */\n\tdefer.wait = function(time){\n\t\tvar d = defer();\n\t\tsetTimeout(d.resolve, time || 0);\n\t\treturn d.promise;\n\t};\n\n\t/**\n\t * return a promise for the return value of function call which will be fulfilled in delay ms or rejected if given fn throw an error\n\t * @param {function} fn\n\t * @param {int} [delay] in ms default to 0\n\t * @returns {promise}\n\t */\n\tdefer.delay = function(fn, delay){\n\t\tvar d = defer();\n\t\tsetTimeout(function(){ try{ d.resolve(fn.apply(null)); }catch(e){ d.reject(e); } }, delay || 0);\n\t\treturn d.promise;\n\t};\n\n\t/**\n\t * if given value is not a promise return a fulfilled promise resolved to given value\n\t * @param {*} promise a value or a promise\n\t * @returns {promise}\n\t */\n\tdefer.promisify = function(promise){\n\t\tif ( promise && isFunc(promise.then) ) { return promise;}\n\t\treturn defer.resolved(promise);\n\t};\n\n\tfunction multiPromiseResolver(callerArguments, returnPromises){\n\t\tvar promises = slice(callerArguments);\n\t\tif ( promises.length === 1 && isArray(promises[0]) ) {\n\t\t\tif(! promises[0].length ){\n\t\t\t\treturn defer.fulfilled([]);\n\t\t\t}\n\t\t\tpromises = promises[0];\n\t\t}\n\t\tvar args = []\n\t\t\t, d = defer()\n\t\t\t, c = promises.length\n\t\t;\n\t\tif ( !c ) {\n\t\t\td.resolve(args);\n\t\t} else {\n\t\t\tvar resolver = function(i){\n\t\t\t\tpromises[i] = defer.promisify(promises[i]);\n\t\t\t\tpromises[i].then(\n\t\t\t\t\tfunction(v){\n\t\t\t\t\t\tif (! (i in args) ) { //@todo check this is still required as promises can't be resolve more than once\n\t\t\t\t\t\t\targs[i] = returnPromises ? promises[i] : v;\n\t\t\t\t\t\t\t(--c) || d.resolve(args);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\t, function(e){\n\t\t\t\t\t\tif(! (i in args) ){\n\t\t\t\t\t\t\tif( ! returnPromises ){\n\t\t\t\t\t\t\t\td.reject(e);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\targs[i] = promises[i];\n\t\t\t\t\t\t\t\t(--c) || d.resolve(args);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t};\n\t\t\tfor( var i = 0, l = c; i < l; i++ ){\n\t\t\t\tresolver(i);\n\t\t\t}\n\t\t}\n\t\treturn d.promise;\n\t}\n\n\t/**\n\t * return a promise for all given promises / values.\n\t * the returned promises will be fulfilled with a list of resolved value.\n\t * if any given promise is rejected then on the first rejection the returned promised will be rejected with the same reason\n\t * @param {array|...*} [promise] can be a single array of promise/values as first parameter or a list of direct parameters promise/value\n\t * @returns {promise} of a list of given promise resolution value\n\t */\n\tdefer.all = function(){ return multiPromiseResolver(arguments,false); };\n\n\t/**\n\t * return an always fulfilled promise of array<promise> list of promises/values regardless they resolve fulfilled or rejected\n\t * @param {array|...*} [promise] can be a single array of promise/values as first parameter or a list of direct parameters promise/value\n\t *                     (non promise values will be promisified)\n\t * @returns {promise} of the list of given promises\n\t */\n\tdefer.resolveAll = function(){ return multiPromiseResolver(arguments,true); };\n\n\t/**\n\t * transform a typical nodejs async method awaiting a callback as last parameter, receiving error as first parameter to a function that\n\t * will return a promise instead. the returned promise will resolve with normal callback value minus the first error parameter on\n\t * fulfill and will be rejected with that error as reason in case of error.\n\t * @param {object} [subject] optional subject of the method to encapsulate\n\t * @param {function} fn the function to encapsulate if the normal callback should receive more than a single parameter (minus the error)\n\t *                      the promise will resolve with the list or parameters as fulfillment value. If only one parameter is sent to the\n\t *                      callback then it will be used as the resolution value.\n\t * @returns {Function}\n\t */\n\tdefer.nodeCapsule = function(subject, fn){\n\t\tif ( !fn ) {\n\t\t\tfn = subject;\n\t\t\tsubject = void(0);\n\t\t}\n\t\treturn function(){\n\t\t\tvar d = defer(), args = slice(arguments);\n\t\t\targs.push(function(err, res){\n\t\t\t\terr ? d.reject(err) : d.resolve(arguments.length > 2 ? slice(arguments, 1) : res);\n\t\t\t});\n\t\t\ttry{\n\t\t\t\tfn.apply(subject, args);\n\t\t\t}catch(e){\n\t\t\t\td.reject(e);\n\t\t\t}\n\t\t\treturn d.promise;\n\t\t};\n\t};\n\n\ttypeof window !== undefStr && (window.D = defer);\n\ttypeof module !== undefStr && module.exports && (module.exports = defer);\n\n})();\n\n}).call(this,require('_process'))\n//# sourceMappingURL=data:application/json;charset:utf-8;base64,{"version":3,"sources":["node_modules/d.js/lib/D.js"],"names":[],"mappings":";AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["/**\n* attempt of a simple defer/promise library for mobile development\n* @author Jonathan Gotti < jgotti at jgotti dot net>\n* @since 2012-10\n* @version 0.6.0\n* @changelog\n*           - 2013-12-07 - last promise 1.1 specs test passings (thx to wizardwerdna)\n *                       - reduce promises footprint by unscoping methods that could be\n*           - 2013-10-23 - make it workig across node-webkit contexts\n*           - 2013-07-03 - bug correction in promixify method (thx to adrien gibrat )\n*           - 2013-06-22 - bug correction in nodeCapsule method\n*           - 2013-06-17 - remove unnecessary Array.indexOf method dependency\n*           - 2013-04-18 - add try/catch block around nodeCapsuled methods\n*           - 2013-04-13 - check promises/A+ conformity\n*                        - make some minication optimisations\n*           - 2013-03-26 - add resolved, fulfilled and rejected methods\n*           - 2013-03-21 - browser/node compatible\n*                        - new method nodeCapsule\n*                        - simpler promixify with full api support\n*           - 2013-01-25 - add rethrow method\n*                        - nextTick optimisation -> add support for process.nextTick + MessageChannel where available\n*           - 2012-12-28 - add apply method to promise\n*           - 2012-12-20 - add alwaysAsync parameters and property for default setting\n*/\n(function(undef){\n\t\"use strict\";\n\n\tvar nextTick\n\t\t, isFunc = function(f){ return ( typeof f === 'function' ); }\n\t\t, isArray = function(a){ return Array.isArray ? Array.isArray(a) : (a instanceof Array); }\n\t\t, isObjOrFunc = function(o){ return !!(o && (typeof o).match(/function|object/)); }\n\t\t, isNotVal = function(v){ return (v === false || v === undef || v === null); }\n\t\t, slice = function(a, offset){ return [].slice.call(a, offset); }\n\t\t, undefStr = 'undefined'\n\t\t, tErr = typeof TypeError === undefStr ? Error : TypeError\n\t;\n\tif ( (typeof process !== undefStr) && process.nextTick ) {\n\t\tnextTick = process.nextTick;\n\t} else if ( typeof MessageChannel !== undefStr ) {\n\t\tvar ntickChannel = new MessageChannel(), queue = [];\n\t\tntickChannel.port1.onmessage = function(){ queue.length && (queue.shift())(); };\n\t\tnextTick = function(cb){\n\t\t\tqueue.push(cb);\n\t\t\tntickChannel.port2.postMessage(0);\n\t\t};\n\t} else {\n\t\tnextTick = function(cb){ setTimeout(cb, 0); };\n\t}\n\tfunction rethrow(e){ nextTick(function(){ throw e;}); }\n\n\t/**\n\t * @typedef deferred\n\t * @property {promise} promise\n\t * @method resolve\n\t * @method fulfill\n\t * @method reject\n\t */\n\n\t/**\n\t * @typedef {function} fulfilled\n\t * @param {*} value promise resolved value\n\t * @returns {*} next promise resolution value\n\t */\n\n\t/**\n\t * @typedef {function} failed\n\t * @param {*} reason promise rejection reason\n\t * @returns {*} next promise resolution value or rethrow the reason\n\t */\n\n\t//-- defining unenclosed promise methods --//\n\t/**\n\t * same as then without failed callback\n\t * @param {fulfilled} fulfilled callback\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_success(fulfilled){ return this.then(fulfilled, undef); }\n\n\t/**\n\t * same as then with only a failed callback\n\t * @param {failed} failed callback\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_error(failed){ return this.then(undef, failed); }\n\n\n\t/**\n\t * same as then but fulfilled callback will receive multiple parameters when promise is fulfilled with an Array\n\t * @param {fulfilled} fulfilled callback\n\t * @param {failed} failed callback\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_apply(fulfilled, failed){\n\t\treturn this.then(\n\t\t\tfunction(a){\n\t\t\t\treturn isFunc(fulfilled) ? fulfilled.apply(null, isArray(a) ? a : [a]) : (defer.onlyFuncs ? a : fulfilled);\n\t\t\t}\n\t\t\t, failed || undef\n\t\t);\n\t}\n\n\t/**\n\t * cleanup method which will be always executed regardless fulfillment or rejection\n\t * @param {function} cb a callback called regardless of the fulfillment or rejection of the promise which will be called\n\t *                      when the promise is not pending anymore\n\t * @returns {promise} the same promise untouched\n\t */\n\tfunction promise_ensure(cb){\n\t\tfunction _cb(){ cb(); }\n\t\tthis.then(_cb, _cb);\n\t\treturn this;\n\t}\n\n\t/**\n\t * take a single callback which wait for an error as first parameter. other resolution values are passed as with the apply/spread method\n\t * @param {function} cb a callback called regardless of the fulfillment or rejection of the promise which will be called\n\t *                      when the promise is not pending anymore with error as first parameter if any as in node style\n\t *                      callback. Rest of parameters will be applied as with the apply method.\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_nodify(cb){\n\t\treturn this.then(\n\t\t\tfunction(a){\n\t\t\t\treturn isFunc(cb) ? cb.apply(null, isArray(a) ? a.splice(0,0,undefined) && a : [undefined,a]) : (defer.onlyFuncs ? a : cb);\n\t\t\t}\n\t\t\t, function(e){\n\t\t\t\treturn cb(e);\n\t\t\t}\n\t\t);\n\t}\n\n\t/**\n\t *\n\t * @param {function} [failed] without parameter will only rethrow promise rejection reason outside of the promise library on next tick\n\t *                            if passed a failed method then will call failed on rejection and throw the error again if failed didn't\n\t * @returns {promise} a new promise\n\t */\n\tfunction promise_rethrow(failed){\n\t\treturn this.then(\n\t\t\tundef\n\t\t\t, failed ? function(e){ failed(e); throw e; } : rethrow\n\t\t);\n\t}\n\n\t/**\n\t* @param {boolean} [alwaysAsync] if set force the async resolution for this promise independantly of the D.alwaysAsync option\n\t* @returns {deferred} defered object with property 'promise' and methods reject,fulfill,resolve (fulfill being an alias for resolve)\n\t*/\n\tvar defer = function (alwaysAsync){\n\t\tvar alwaysAsyncFn = (undef !== alwaysAsync ? alwaysAsync : defer.alwaysAsync) ? nextTick : function(fn){fn();}\n\t\t\t, status = 0 // -1 failed | 1 fulfilled\n\t\t\t, pendings = []\n\t\t\t, value\n\t\t\t/**\n\t\t\t * @typedef promise\n\t\t\t */\n\t\t\t, _promise  = {\n\t\t\t\t/**\n\t\t\t\t * @param {fulfilled|function} fulfilled callback\n\t\t\t\t * @param {failed|function} failed callback\n\t\t\t\t * @returns {promise} a new promise\n\t\t\t\t */\n\t\t\t\tthen: function(fulfilled, failed){\n\t\t\t\t\tvar d = defer();\n\t\t\t\t\tpendings.push([\n\t\t\t\t\t\tfunction(value){\n\t\t\t\t\t\t\ttry{\n\t\t\t\t\t\t\t\tif( isNotVal(fulfilled)){\n\t\t\t\t\t\t\t\t\td.resolve(value);\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\td.resolve(isFunc(fulfilled) ? fulfilled(value) : (defer.onlyFuncs ? value : fulfilled));\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t}catch(e){\n\t\t\t\t\t\t\t\td.reject(e);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t\t, function(err){\n\t\t\t\t\t\t\tif ( isNotVal(failed) || ((!isFunc(failed)) && defer.onlyFuncs) ) {\n\t\t\t\t\t\t\t\td.reject(err);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tif ( failed ) {\n\t\t\t\t\t\t\t\ttry{ d.resolve(isFunc(failed) ? failed(err) : failed); }catch(e){ d.reject(e);}\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t]);\n\t\t\t\t\tstatus !== 0 && alwaysAsyncFn(execCallbacks);\n\t\t\t\t\treturn d.promise;\n\t\t\t\t}\n\n\t\t\t\t, success: promise_success\n\n\t\t\t\t, error: promise_error\n\t\t\t\t, otherwise: promise_error\n\n\t\t\t\t, apply: promise_apply\n\t\t\t\t, spread: promise_apply\n\n\t\t\t\t, ensure: promise_ensure\n\n\t\t\t\t, nodify: promise_nodify\n\n\t\t\t\t, rethrow: promise_rethrow\n\n\t\t\t\t, isPending: function(){ return !!(status === 0); }\n\n\t\t\t\t, getStatus: function(){ return status; }\n\t\t\t}\n\t\t;\n\t\t_promise.toSource = _promise.toString = _promise.valueOf = function(){return value === undef ? this : value; };\n\n\n\t\tfunction execCallbacks(){\n\t\t\tif ( status === 0 ) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tvar cbs = pendings, i = 0, l = cbs.length, cbIndex = ~status ? 0 : 1, cb;\n\t\t\tpendings = [];\n\t\t\tfor( ; i < l; i++ ){\n\t\t\t\t(cb = cbs[i][cbIndex]) && cb(value);\n\t\t\t}\n\t\t}\n\n\t\t/**\n\t\t * fulfill deferred with given value\n\t\t * @param {*} val\n\t\t * @returns {deferred} this for method chaining\n\t\t */\n\t\tfunction _resolve(val){\n\t\t\tvar done = false;\n\t\t\tfunction once(f){\n\t\t\t\treturn function(x){\n\t\t\t\t\tif (done) {\n\t\t\t\t\t\treturn undefined;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tdone = true;\n\t\t\t\t\t\treturn f(x);\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t}\n\t\t\tif ( status ) {\n\t\t\t\treturn this;\n\t\t\t}\n\t\t\ttry {\n\t\t\t\tvar then = isObjOrFunc(val) && val.then;\n\t\t\t\tif ( isFunc(then) ) { // managing a promise\n\t\t\t\t\tif( val === _promise ){\n\t\t\t\t\t\tthrow new tErr(\"Promise can't resolve itself\");\n\t\t\t\t\t}\n\t\t\t\t\tthen.call(val, once(_resolve), once(_reject));\n\t\t\t\t\treturn this;\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\tonce(_reject)(e);\n\t\t\t\treturn this;\n\t\t\t}\n\t\t\talwaysAsyncFn(function(){\n\t\t\t\tvalue = val;\n\t\t\t\tstatus = 1;\n\t\t\t\texecCallbacks();\n\t\t\t});\n\t\t\treturn this;\n\t\t}\n\n\t\t/**\n\t\t * reject deferred with given reason\n\t\t * @param {*} Err\n\t\t * @returns {deferred} this for method chaining\n\t\t */\n\t\tfunction _reject(Err){\n\t\t\tstatus || alwaysAsyncFn(function(){\n\t\t\t\ttry{ throw(Err); }catch(e){ value = e; }\n\t\t\t\tstatus = -1;\n\t\t\t\texecCallbacks();\n\t\t\t});\n\t\t\treturn this;\n\t\t}\n\t\treturn /**@type deferred */ {\n\t\t\tpromise:_promise\n\t\t\t,resolve:_resolve\n\t\t\t,fulfill:_resolve // alias\n\t\t\t,reject:_reject\n\t\t};\n\t};\n\n\tdefer.deferred = defer.defer = defer;\n\tdefer.nextTick = nextTick;\n\tdefer.alwaysAsync = true; // setting this will change default behaviour. use it only if necessary as asynchronicity will force some delay between your promise resolutions and is not always what you want.\n\t/**\n\t* setting onlyFuncs to false will break promises/A+ conformity by allowing you to pass non undefined/null values instead of callbacks\n\t* instead of just ignoring any non function parameters to then,success,error... it will accept non null|undefined values.\n\t* this will allow you shortcuts like promise.then('val','handled error'')\n\t* to be equivalent of promise.then(function(){ return 'val';},function(){ return 'handled error'})\n\t*/\n\tdefer.onlyFuncs = true;\n\n\t/**\n\t * return a fulfilled promise of given value (always async resolution)\n\t * @param {*} value\n\t * @returns {promise}\n\t */\n\tdefer.resolved = defer.fulfilled = function(value){ return defer(true).resolve(value).promise; };\n\n\t/**\n\t * return a rejected promise with given reason of rejection (always async rejection)\n\t * @param {*} reason\n\t * @returns {promise}\n\t */\n\tdefer.rejected = function(reason){ return defer(true).reject(reason).promise; };\n\n\t/**\n\t * return a promise with no resolution value which will be resolved in time ms (using setTimeout)\n\t * @param {int} [time] in ms default to 0\n\t * @returns {promise}\n\t */\n\tdefer.wait = function(time){\n\t\tvar d = defer();\n\t\tsetTimeout(d.resolve, time || 0);\n\t\treturn d.promise;\n\t};\n\n\t/**\n\t * return a promise for the return value of function call which will be fulfilled in delay ms or rejected if given fn throw an error\n\t * @param {function} fn\n\t * @param {int} [delay] in ms default to 0\n\t * @returns {promise}\n\t */\n\tdefer.delay = function(fn, delay){\n\t\tvar d = defer();\n\t\tsetTimeout(function(){ try{ d.resolve(fn.apply(null)); }catch(e){ d.reject(e); } }, delay || 0);\n\t\treturn d.promise;\n\t};\n\n\t/**\n\t * if given value is not a promise return a fulfilled promise resolved to given value\n\t * @param {*} promise a value or a promise\n\t * @returns {promise}\n\t */\n\tdefer.promisify = function(promise){\n\t\tif ( promise && isFunc(promise.then) ) { return promise;}\n\t\treturn defer.resolved(promise);\n\t};\n\n\tfunction multiPromiseResolver(callerArguments, returnPromises){\n\t\tvar promises = slice(callerArguments);\n\t\tif ( promises.length === 1 && isArray(promises[0]) ) {\n\t\t\tif(! promises[0].length ){\n\t\t\t\treturn defer.fulfilled([]);\n\t\t\t}\n\t\t\tpromises = promises[0];\n\t\t}\n\t\tvar args = []\n\t\t\t, d = defer()\n\t\t\t, c = promises.length\n\t\t;\n\t\tif ( !c ) {\n\t\t\td.resolve(args);\n\t\t} else {\n\t\t\tvar resolver = function(i){\n\t\t\t\tpromises[i] = defer.promisify(promises[i]);\n\t\t\t\tpromises[i].then(\n\t\t\t\t\tfunction(v){\n\t\t\t\t\t\tif (! (i in args) ) { //@todo check this is still required as promises can't be resolve more than once\n\t\t\t\t\t\t\targs[i] = returnPromises ? promises[i] : v;\n\t\t\t\t\t\t\t(--c) || d.resolve(args);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\t, function(e){\n\t\t\t\t\t\tif(! (i in args) ){\n\t\t\t\t\t\t\tif( ! returnPromises ){\n\t\t\t\t\t\t\t\td.reject(e);\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\targs[i] = promises[i];\n\t\t\t\t\t\t\t\t(--c) || d.resolve(args);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t};\n\t\t\tfor( var i = 0, l = c; i < l; i++ ){\n\t\t\t\tresolver(i);\n\t\t\t}\n\t\t}\n\t\treturn d.promise;\n\t}\n\n\t/**\n\t * return a promise for all given promises / values.\n\t * the returned promises will be fulfilled with a list of resolved value.\n\t * if any given promise is rejected then on the first rejection the returned promised will be rejected with the same reason\n\t * @param {array|...*} [promise] can be a single array of promise/values as first parameter or a list of direct parameters promise/value\n\t * @returns {promise} of a list of given promise resolution value\n\t */\n\tdefer.all = function(){ return multiPromiseResolver(arguments,false); };\n\n\t/**\n\t * return an always fulfilled promise of array<promise> list of promises/values regardless they resolve fulfilled or rejected\n\t * @param {array|...*} [promise] can be a single array of promise/values as first parameter or a list of direct parameters promise/value\n\t *                     (non promise values will be promisified)\n\t * @returns {promise} of the list of given promises\n\t */\n\tdefer.resolveAll = function(){ return multiPromiseResolver(arguments,true); };\n\n\t/**\n\t * transform a typical nodejs async method awaiting a callback as last parameter, receiving error as first parameter to a function that\n\t * will return a promise instead. the returned promise will resolve with normal callback value minus the first error parameter on\n\t * fulfill and will be rejected with that error as reason in case of error.\n\t * @param {object} [subject] optional subject of the method to encapsulate\n\t * @param {function} fn the function to encapsulate if the normal callback should receive more than a single parameter (minus the error)\n\t *                      the promise will resolve with the list or parameters as fulfillment value. If only one parameter is sent to the\n\t *                      callback then it will be used as the resolution value.\n\t * @returns {Function}\n\t */\n\tdefer.nodeCapsule = function(subject, fn){\n\t\tif ( !fn ) {\n\t\t\tfn = subject;\n\t\t\tsubject = void(0);\n\t\t}\n\t\treturn function(){\n\t\t\tvar d = defer(), args = slice(arguments);\n\t\t\targs.push(function(err, res){\n\t\t\t\terr ? d.reject(err) : d.resolve(arguments.length > 2 ? slice(arguments, 1) : res);\n\t\t\t});\n\t\t\ttry{\n\t\t\t\tfn.apply(subject, args);\n\t\t\t}catch(e){\n\t\t\t\td.reject(e);\n\t\t\t}\n\t\t\treturn d.promise;\n\t\t};\n\t};\n\n\ttypeof window !== undefStr && (window.D = defer);\n\ttypeof module !== undefStr && module.exports && (module.exports = defer);\n\n})();\n"]}","/**\n * Module dependencies.\n */\n\nvar Emitter = require('emitter');\nvar reduce = require('reduce');\n\n/**\n * Root reference for iframes.\n */\n\nvar root = 'undefined' == typeof window\n  ? this\n  : window;\n\n/**\n * Noop.\n */\n\nfunction noop(){};\n\n/**\n * Check if `obj` is a host object,\n * we don't want to serialize these :)\n *\n * TODO: future proof, move to compoent land\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\n\nfunction isHost(obj) {\n  var str = {}.toString.call(obj);\n\n  switch (str) {\n    case '[object File]':\n    case '[object Blob]':\n    case '[object FormData]':\n      return true;\n    default:\n      return false;\n  }\n}\n\n/**\n * Determine XHR.\n */\n\nfunction getXHR() {\n  if (root.XMLHttpRequest\n    && ('file:' != root.location.protocol || !root.ActiveXObject)) {\n    return new XMLHttpRequest;\n  } else {\n    try { return new ActiveXObject('Microsoft.XMLHTTP'); } catch(e) {}\n    try { return new ActiveXObject('Msxml2.XMLHTTP.6.0'); } catch(e) {}\n    try { return new ActiveXObject('Msxml2.XMLHTTP.3.0'); } catch(e) {}\n    try { return new ActiveXObject('Msxml2.XMLHTTP'); } catch(e) {}\n  }\n  return false;\n}\n\n/**\n * Removes leading and trailing whitespace, added to support IE.\n *\n * @param {String} s\n * @return {String}\n * @api private\n */\n\nvar trim = ''.trim\n  ? function(s) { return s.trim(); }\n  : function(s) { return s.replace(/(^\\s*|\\s*$)/g, ''); };\n\n/**\n * Check if `obj` is an object.\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\n\nfunction isObject(obj) {\n  return obj === Object(obj);\n}\n\n/**\n * Serialize the given `obj`.\n *\n * @param {Object} obj\n * @return {String}\n * @api private\n */\n\nfunction serialize(obj) {\n  if (!isObject(obj)) return obj;\n  var pairs = [];\n  for (var key in obj) {\n    if (null != obj[key]) {\n      pairs.push(encodeURIComponent(key)\n        + '=' + encodeURIComponent(obj[key]));\n    }\n  }\n  return pairs.join('&');\n}\n\n/**\n * Expose serialization method.\n */\n\n request.serializeObject = serialize;\n\n /**\n  * Parse the given x-www-form-urlencoded `str`.\n  *\n  * @param {String} str\n  * @return {Object}\n  * @api private\n  */\n\nfunction parseString(str) {\n  var obj = {};\n  var pairs = str.split('&');\n  var parts;\n  var pair;\n\n  for (var i = 0, len = pairs.length; i < len; ++i) {\n    pair = pairs[i];\n    parts = pair.split('=');\n    obj[decodeURIComponent(parts[0])] = decodeURIComponent(parts[1]);\n  }\n\n  return obj;\n}\n\n/**\n * Expose parser.\n */\n\nrequest.parseString = parseString;\n\n/**\n * Default MIME type map.\n *\n *     superagent.types.xml = 'application/xml';\n *\n */\n\nrequest.types = {\n  html: 'text/html',\n  json: 'application/json',\n  xml: 'application/xml',\n  urlencoded: 'application/x-www-form-urlencoded',\n  'form': 'application/x-www-form-urlencoded',\n  'form-data': 'application/x-www-form-urlencoded'\n};\n\n/**\n * Default serialization map.\n *\n *     superagent.serialize['application/xml'] = function(obj){\n *       return 'generated xml here';\n *     };\n *\n */\n\n request.serialize = {\n   'application/x-www-form-urlencoded': serialize,\n   'application/json': JSON.stringify\n };\n\n /**\n  * Default parsers.\n  *\n  *     superagent.parse['application/xml'] = function(str){\n  *       return { object parsed from str };\n  *     };\n  *\n  */\n\nrequest.parse = {\n  'application/x-www-form-urlencoded': parseString,\n  'application/json': JSON.parse\n};\n\n/**\n * Parse the given header `str` into\n * an object containing the mapped fields.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseHeader(str) {\n  var lines = str.split(/\\r?\\n/);\n  var fields = {};\n  var index;\n  var line;\n  var field;\n  var val;\n\n  lines.pop(); // trailing CRLF\n\n  for (var i = 0, len = lines.length; i < len; ++i) {\n    line = lines[i];\n    index = line.indexOf(':');\n    field = line.slice(0, index).toLowerCase();\n    val = trim(line.slice(index + 1));\n    fields[field] = val;\n  }\n\n  return fields;\n}\n\n/**\n * Return the mime type for the given `str`.\n *\n * @param {String} str\n * @return {String}\n * @api private\n */\n\nfunction type(str){\n  return str.split(/ *; */).shift();\n};\n\n/**\n * Return header field parameters.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction params(str){\n  return reduce(str.split(/ *; */), function(obj, str){\n    var parts = str.split(/ *= */)\n      , key = parts.shift()\n      , val = parts.shift();\n\n    if (key && val) obj[key] = val;\n    return obj;\n  }, {});\n};\n\n/**\n * Initialize a new `Response` with the given `xhr`.\n *\n *  - set flags (.ok, .error, etc)\n *  - parse header\n *\n * Examples:\n *\n *  Aliasing `superagent` as `request` is nice:\n *\n *      request = superagent;\n *\n *  We can use the promise-like API, or pass callbacks:\n *\n *      request.get('/').end(function(res){});\n *      request.get('/', function(res){});\n *\n *  Sending data can be chained:\n *\n *      request\n *        .post('/user')\n *        .send({ name: 'tj' })\n *        .end(function(res){});\n *\n *  Or passed to `.send()`:\n *\n *      request\n *        .post('/user')\n *        .send({ name: 'tj' }, function(res){});\n *\n *  Or passed to `.post()`:\n *\n *      request\n *        .post('/user', { name: 'tj' })\n *        .end(function(res){});\n *\n * Or further reduced to a single call for simple cases:\n *\n *      request\n *        .post('/user', { name: 'tj' }, function(res){});\n *\n * @param {XMLHTTPRequest} xhr\n * @param {Object} options\n * @api private\n */\n\nfunction Response(req, options) {\n  options = options || {};\n  this.req = req;\n  this.xhr = this.req.xhr;\n  this.text = this.req.method !='HEAD' \n     ? this.xhr.responseText \n     : null;\n  this.setStatusProperties(this.xhr.status);\n  this.header = this.headers = parseHeader(this.xhr.getAllResponseHeaders());\n  // getAllResponseHeaders sometimes falsely returns \"\" for CORS requests, but\n  // getResponseHeader still works. so we get content-type even if getting\n  // other headers fails.\n  this.header['content-type'] = this.xhr.getResponseHeader('content-type');\n  this.setHeaderProperties(this.header);\n  this.body = this.req.method != 'HEAD'\n    ? this.parseBody(this.text)\n    : null;\n}\n\n/**\n * Get case-insensitive `field` value.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\nResponse.prototype.get = function(field){\n  return this.header[field.toLowerCase()];\n};\n\n/**\n * Set header related properties:\n *\n *   - `.type` the content type without params\n *\n * A response of \"Content-Type: text/plain; charset=utf-8\"\n * will provide you with a `.type` of \"text/plain\".\n *\n * @param {Object} header\n * @api private\n */\n\nResponse.prototype.setHeaderProperties = function(header){\n  // content-type\n  var ct = this.header['content-type'] || '';\n  this.type = type(ct);\n\n  // params\n  var obj = params(ct);\n  for (var key in obj) this[key] = obj[key];\n};\n\n/**\n * Parse the given body `str`.\n *\n * Used for auto-parsing of bodies. Parsers\n * are defined on the `superagent.parse` object.\n *\n * @param {String} str\n * @return {Mixed}\n * @api private\n */\n\nResponse.prototype.parseBody = function(str){\n  var parse = request.parse[this.type];\n  return parse && str && str.length\n    ? parse(str)\n    : null;\n};\n\n/**\n * Set flags such as `.ok` based on `status`.\n *\n * For example a 2xx response will give you a `.ok` of __true__\n * whereas 5xx will be __false__ and `.error` will be __true__. The\n * `.clientError` and `.serverError` are also available to be more\n * specific, and `.statusType` is the class of error ranging from 1..5\n * sometimes useful for mapping respond colors etc.\n *\n * \"sugar\" properties are also defined for common cases. Currently providing:\n *\n *   - .noContent\n *   - .badRequest\n *   - .unauthorized\n *   - .notAcceptable\n *   - .notFound\n *\n * @param {Number} status\n * @api private\n */\n\nResponse.prototype.setStatusProperties = function(status){\n  var type = status / 100 | 0;\n\n  // status / class\n  this.status = status;\n  this.statusType = type;\n\n  // basics\n  this.info = 1 == type;\n  this.ok = 2 == type;\n  this.clientError = 4 == type;\n  this.serverError = 5 == type;\n  this.error = (4 == type || 5 == type)\n    ? this.toError()\n    : false;\n\n  // sugar\n  this.accepted = 202 == status;\n  this.noContent = 204 == status || 1223 == status;\n  this.badRequest = 400 == status;\n  this.unauthorized = 401 == status;\n  this.notAcceptable = 406 == status;\n  this.notFound = 404 == status;\n  this.forbidden = 403 == status;\n};\n\n/**\n * Return an `Error` representative of this response.\n *\n * @return {Error}\n * @api public\n */\n\nResponse.prototype.toError = function(){\n  var req = this.req;\n  var method = req.method;\n  var url = req.url;\n\n  var msg = 'cannot ' + method + ' ' + url + ' (' + this.status + ')';\n  var err = new Error(msg);\n  err.status = this.status;\n  err.method = method;\n  err.url = url;\n\n  return err;\n};\n\n/**\n * Expose `Response`.\n */\n\nrequest.Response = Response;\n\n/**\n * Initialize a new `Request` with the given `method` and `url`.\n *\n * @param {String} method\n * @param {String} url\n * @api public\n */\n\nfunction Request(method, url) {\n  var self = this;\n  Emitter.call(this);\n  this._query = this._query || [];\n  this.method = method;\n  this.url = url;\n  this.header = {};\n  this._header = {};\n  this.on('end', function(){\n    var err = null;\n    var res = null;\n\n    try {\n      res = new Response(self); \n    } catch(e) {\n      err = new Error('Parser is unable to parse the response');\n      err.parse = true;\n      err.original = e;\n    }\n\n    self.callback(err, res);\n  });\n}\n\n/**\n * Mixin `Emitter`.\n */\n\nEmitter(Request.prototype);\n\n/**\n * Allow for extension\n */\n\nRequest.prototype.use = function(fn) {\n  fn(this);\n  return this;\n}\n\n/**\n * Set timeout to `ms`.\n *\n * @param {Number} ms\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.timeout = function(ms){\n  this._timeout = ms;\n  return this;\n};\n\n/**\n * Clear previous timeout.\n *\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.clearTimeout = function(){\n  this._timeout = 0;\n  clearTimeout(this._timer);\n  return this;\n};\n\n/**\n * Abort the request, and clear potential timeout.\n *\n * @return {Request}\n * @api public\n */\n\nRequest.prototype.abort = function(){\n  if (this.aborted) return;\n  this.aborted = true;\n  this.xhr.abort();\n  this.clearTimeout();\n  this.emit('abort');\n  return this;\n};\n\n/**\n * Set header `field` to `val`, or multiple fields with one object.\n *\n * Examples:\n *\n *      req.get('/')\n *        .set('Accept', 'application/json')\n *        .set('X-API-Key', 'foobar')\n *        .end(callback);\n *\n *      req.get('/')\n *        .set({ Accept: 'application/json', 'X-API-Key': 'foobar' })\n *        .end(callback);\n *\n * @param {String|Object} field\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.set = function(field, val){\n  if (isObject(field)) {\n    for (var key in field) {\n      this.set(key, field[key]);\n    }\n    return this;\n  }\n  this._header[field.toLowerCase()] = val;\n  this.header[field] = val;\n  return this;\n};\n\n/**\n * Remove header `field`.\n *\n * Example:\n *\n *      req.get('/')\n *        .unset('User-Agent')\n *        .end(callback);\n *\n * @param {String} field\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.unset = function(field){\n  delete this._header[field.toLowerCase()];\n  delete this.header[field];\n  return this;\n};\n\n/**\n * Get case-insensitive header `field` value.\n *\n * @param {String} field\n * @return {String}\n * @api private\n */\n\nRequest.prototype.getHeader = function(field){\n  return this._header[field.toLowerCase()];\n};\n\n/**\n * Set Content-Type to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n *      superagent.types.xml = 'application/xml';\n *\n *      request.post('/')\n *        .type('xml')\n *        .send(xmlstring)\n *        .end(callback);\n *\n *      request.post('/')\n *        .type('application/xml')\n *        .send(xmlstring)\n *        .end(callback);\n *\n * @param {String} type\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.type = function(type){\n  this.set('Content-Type', request.types[type] || type);\n  return this;\n};\n\n/**\n * Set Accept to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n *      superagent.types.json = 'application/json';\n *\n *      request.get('/agent')\n *        .accept('json')\n *        .end(callback);\n *\n *      request.get('/agent')\n *        .accept('application/json')\n *        .end(callback);\n *\n * @param {String} accept\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.accept = function(type){\n  this.set('Accept', request.types[type] || type);\n  return this;\n};\n\n/**\n * Set Authorization field value with `user` and `pass`.\n *\n * @param {String} user\n * @param {String} pass\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.auth = function(user, pass){\n  var str = btoa(user + ':' + pass);\n  this.set('Authorization', 'Basic ' + str);\n  return this;\n};\n\n/**\n* Add query-string `val`.\n*\n* Examples:\n*\n*   request.get('/shoes')\n*     .query('size=10')\n*     .query({ color: 'blue' })\n*\n* @param {Object|String} val\n* @return {Request} for chaining\n* @api public\n*/\n\nRequest.prototype.query = function(val){\n  if ('string' != typeof val) val = serialize(val);\n  if (val) this._query.push(val);\n  return this;\n};\n\n/**\n * Write the field `name` and `val` for \"multipart/form-data\"\n * request bodies.\n *\n * ``` js\n * request.post('/upload')\n *   .field('foo', 'bar')\n *   .end(callback);\n * ```\n *\n * @param {String} name\n * @param {String|Blob|File} val\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.field = function(name, val){\n  if (!this._formData) this._formData = new FormData();\n  this._formData.append(name, val);\n  return this;\n};\n\n/**\n * Queue the given `file` as an attachment to the specified `field`,\n * with optional `filename`.\n *\n * ``` js\n * request.post('/upload')\n *   .attach(new Blob(['<a id=\"a\"><b id=\"b\">hey!</b></a>'], { type: \"text/html\"}))\n *   .end(callback);\n * ```\n *\n * @param {String} field\n * @param {Blob|File} file\n * @param {String} filename\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.attach = function(field, file, filename){\n  if (!this._formData) this._formData = new FormData();\n  this._formData.append(field, file, filename);\n  return this;\n};\n\n/**\n * Send `data`, defaulting the `.type()` to \"json\" when\n * an object is given.\n *\n * Examples:\n *\n *       // querystring\n *       request.get('/search')\n *         .end(callback)\n *\n *       // multiple data \"writes\"\n *       request.get('/search')\n *         .send({ search: 'query' })\n *         .send({ range: '1..5' })\n *         .send({ order: 'desc' })\n *         .end(callback)\n *\n *       // manual json\n *       request.post('/user')\n *         .type('json')\n *         .send('{\"name\":\"tj\"})\n *         .end(callback)\n *\n *       // auto json\n *       request.post('/user')\n *         .send({ name: 'tj' })\n *         .end(callback)\n *\n *       // manual x-www-form-urlencoded\n *       request.post('/user')\n *         .type('form')\n *         .send('name=tj')\n *         .end(callback)\n *\n *       // auto x-www-form-urlencoded\n *       request.post('/user')\n *         .type('form')\n *         .send({ name: 'tj' })\n *         .end(callback)\n *\n *       // defaults to x-www-form-urlencoded\n  *      request.post('/user')\n  *        .send('name=tobi')\n  *        .send('species=ferret')\n  *        .end(callback)\n *\n * @param {String|Object} data\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.send = function(data){\n  var obj = isObject(data);\n  var type = this.getHeader('Content-Type');\n\n  // merge\n  if (obj && isObject(this._data)) {\n    for (var key in data) {\n      this._data[key] = data[key];\n    }\n  } else if ('string' == typeof data) {\n    if (!type) this.type('form');\n    type = this.getHeader('Content-Type');\n    if ('application/x-www-form-urlencoded' == type) {\n      this._data = this._data\n        ? this._data + '&' + data\n        : data;\n    } else {\n      this._data = (this._data || '') + data;\n    }\n  } else {\n    this._data = data;\n  }\n\n  if (!obj) return this;\n  if (!type) this.type('json');\n  return this;\n};\n\n/**\n * Invoke the callback with `err` and `res`\n * and handle arity check.\n *\n * @param {Error} err\n * @param {Response} res\n * @api private\n */\n\nRequest.prototype.callback = function(err, res){\n  var fn = this._callback;\n  this.clearTimeout();\n  if (2 == fn.length) return fn(err, res);\n  if (err) return this.emit('error', err);\n  fn(res);\n};\n\n/**\n * Invoke callback with x-domain error.\n *\n * @api private\n */\n\nRequest.prototype.crossDomainError = function(){\n  var err = new Error('Origin is not allowed by Access-Control-Allow-Origin');\n  err.crossDomain = true;\n  this.callback(err);\n};\n\n/**\n * Invoke callback with timeout error.\n *\n * @api private\n */\n\nRequest.prototype.timeoutError = function(){\n  var timeout = this._timeout;\n  var err = new Error('timeout of ' + timeout + 'ms exceeded');\n  err.timeout = timeout;\n  this.callback(err);\n};\n\n/**\n * Enable transmission of cookies with x-domain requests.\n *\n * Note that for this to work the origin must not be\n * using \"Access-Control-Allow-Origin\" with a wildcard,\n * and also must set \"Access-Control-Allow-Credentials\"\n * to \"true\".\n *\n * @api public\n */\n\nRequest.prototype.withCredentials = function(){\n  this._withCredentials = true;\n  return this;\n};\n\n/**\n * Initiate request, invoking callback `fn(res)`\n * with an instanceof `Response`.\n *\n * @param {Function} fn\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.end = function(fn){\n  var self = this;\n  var xhr = this.xhr = getXHR();\n  var query = this._query.join('&');\n  var timeout = this._timeout;\n  var data = this._formData || this._data;\n\n  // store callback\n  this._callback = fn || noop;\n\n  // state change\n  xhr.onreadystatechange = function(){\n    if (4 != xhr.readyState) return;\n    if (0 == xhr.status) {\n      if (self.aborted) return self.timeoutError();\n      return self.crossDomainError();\n    }\n    self.emit('end');\n  };\n\n  // progress\n  if (xhr.upload) {\n    xhr.upload.onprogress = function(e){\n      e.percent = e.loaded / e.total * 100;\n      self.emit('progress', e);\n    };\n  }\n\n  // timeout\n  if (timeout && !this._timer) {\n    this._timer = setTimeout(function(){\n      self.abort();\n    }, timeout);\n  }\n\n  // querystring\n  if (query) {\n    query = request.serializeObject(query);\n    this.url += ~this.url.indexOf('?')\n      ? '&' + query\n      : '?' + query;\n  }\n\n  // initiate request\n  xhr.open(this.method, this.url, true);\n\n  // CORS\n  if (this._withCredentials) xhr.withCredentials = true;\n\n  // body\n  if ('GET' != this.method && 'HEAD' != this.method && 'string' != typeof data && !isHost(data)) {\n    // serialize stuff\n    var serialize = request.serialize[this.getHeader('Content-Type')];\n    if (serialize) data = serialize(data);\n  }\n\n  // set header fields\n  for (var field in this.header) {\n    if (null == this.header[field]) continue;\n    xhr.setRequestHeader(field, this.header[field]);\n  }\n\n  // send stuff\n  this.emit('request', this);\n  xhr.send(data);\n  return this;\n};\n\n/**\n * Expose `Request`.\n */\n\nrequest.Request = Request;\n\n/**\n * Issue a request:\n *\n * Examples:\n *\n *    request('GET', '/users').end(callback)\n *    request('/users').end(callback)\n *    request('/users', callback)\n *\n * @param {String} method\n * @param {String|Function} url or callback\n * @return {Request}\n * @api public\n */\n\nfunction request(method, url) {\n  // callback\n  if ('function' == typeof url) {\n    return new Request('GET', method).end(url);\n  }\n\n  // url first\n  if (1 == arguments.length) {\n    return new Request('GET', method);\n  }\n\n  return new Request(method, url);\n}\n\n/**\n * GET `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} data or fn\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.get = function(url, data, fn){\n  var req = request('GET', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.query(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * HEAD `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} data or fn\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.head = function(url, data, fn){\n  var req = request('HEAD', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.send(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * DELETE `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.del = function(url, fn){\n  var req = request('DELETE', url);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * PATCH `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} data\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.patch = function(url, data, fn){\n  var req = request('PATCH', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.send(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * POST `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} data\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.post = function(url, data, fn){\n  var req = request('POST', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.send(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * PUT `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} data or fn\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.put = function(url, data, fn){\n  var req = request('PUT', url);\n  if ('function' == typeof data) fn = data, data = null;\n  if (data) req.send(data);\n  if (fn) req.end(fn);\n  return req;\n};\n\n/**\n * Expose `request`.\n */\n\nmodule.exports = request;\n","\n/**\n * Expose `Emitter`.\n */\n\nmodule.exports = Emitter;\n\n/**\n * Initialize a new `Emitter`.\n *\n * @api public\n */\n\nfunction Emitter(obj) {\n  if (obj) return mixin(obj);\n};\n\n/**\n * Mixin the emitter properties.\n *\n * @param {Object} obj\n * @return {Object}\n * @api private\n */\n\nfunction mixin(obj) {\n  for (var key in Emitter.prototype) {\n    obj[key] = Emitter.prototype[key];\n  }\n  return obj;\n}\n\n/**\n * Listen on the given `event` with `fn`.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.on =\nEmitter.prototype.addEventListener = function(event, fn){\n  this._callbacks = this._callbacks || {};\n  (this._callbacks[event] = this._callbacks[event] || [])\n    .push(fn);\n  return this;\n};\n\n/**\n * Adds an `event` listener that will be invoked a single\n * time then automatically removed.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.once = function(event, fn){\n  var self = this;\n  this._callbacks = this._callbacks || {};\n\n  function on() {\n    self.off(event, on);\n    fn.apply(this, arguments);\n  }\n\n  on.fn = fn;\n  this.on(event, on);\n  return this;\n};\n\n/**\n * Remove the given callback for `event` or all\n * registered callbacks.\n *\n * @param {String} event\n * @param {Function} fn\n * @return {Emitter}\n * @api public\n */\n\nEmitter.prototype.off =\nEmitter.prototype.removeListener =\nEmitter.prototype.removeAllListeners =\nEmitter.prototype.removeEventListener = function(event, fn){\n  this._callbacks = this._callbacks || {};\n\n  // all\n  if (0 == arguments.length) {\n    this._callbacks = {};\n    return this;\n  }\n\n  // specific event\n  var callbacks = this._callbacks[event];\n  if (!callbacks) return this;\n\n  // remove all handlers\n  if (1 == arguments.length) {\n    delete this._callbacks[event];\n    return this;\n  }\n\n  // remove specific handler\n  var cb;\n  for (var i = 0; i < callbacks.length; i++) {\n    cb = callbacks[i];\n    if (cb === fn || cb.fn === fn) {\n      callbacks.splice(i, 1);\n      break;\n    }\n  }\n  return this;\n};\n\n/**\n * Emit `event` with the given args.\n *\n * @param {String} event\n * @param {Mixed} ...\n * @return {Emitter}\n */\n\nEmitter.prototype.emit = function(event){\n  this._callbacks = this._callbacks || {};\n  var args = [].slice.call(arguments, 1)\n    , callbacks = this._callbacks[event];\n\n  if (callbacks) {\n    callbacks = callbacks.slice(0);\n    for (var i = 0, len = callbacks.length; i < len; ++i) {\n      callbacks[i].apply(this, args);\n    }\n  }\n\n  return this;\n};\n\n/**\n * Return array of callbacks for `event`.\n *\n * @param {String} event\n * @return {Array}\n * @api public\n */\n\nEmitter.prototype.listeners = function(event){\n  this._callbacks = this._callbacks || {};\n  return this._callbacks[event] || [];\n};\n\n/**\n * Check if this emitter has `event` handlers.\n *\n * @param {String} event\n * @return {Boolean}\n * @api public\n */\n\nEmitter.prototype.hasListeners = function(event){\n  return !! this.listeners(event).length;\n};\n","\n/**\n * Reduce `arr` with `fn`.\n *\n * @param {Array} arr\n * @param {Function} fn\n * @param {Mixed} initial\n *\n * TODO: combatible error handling?\n */\n\nmodule.exports = function(arr, fn, initial){  \n  var idx = 0;\n  var len = arr.length;\n  var curr = arguments.length == 3\n    ? initial\n    : arr[idx++];\n\n  while (idx < len) {\n    curr = fn.call(null, curr, arr[idx], ++idx, arr);\n  }\n  \n  return curr;\n};","module.exports={\n  \"name\": \"deployr\",\n  \"version\": \"7.4.1\",\n  \"description\": \"Simplified JavaScript client library for making requests to DeployR.\",\n  \"keywords\": [\n    \"deployr\",\n    \"deployr.io\",\n    \"ajax\",\n    \"R\",\n    \"api\",\n    \"simple\"\n  ],\n  \"author\": \"DeployR - Revolution Analytics Inc.\",\n  \"contributors\": [\n    \"Sean Wells\"\n  ],\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git://github.com/deployr/js-client-library.git\"\n  },\n  \"homepage\": \"http://deployr.revolutionanalytics.com/documents/dev/client-jsdoc\",\n  \"scripts\": {\n    \"start\": \"gulp start\",\n    \"build\": \"gulp\"\n  },\n  \"devDependencies\": {\n    \"browserify\": \"^9.0.3\",\n    \"gulp\": \"^3.8.11\",\n    \"gulp-connect\": \"^2.2.0\",\n    \"gulp-header\": \"^1.2.2\",\n    \"gulp-jshint\": \"^1.9.2\",\n    \"gulp-livereload\": \"^3.8.0\",\n    \"gulp-plumber\": \"^0.6.6\",\n    \"gulp-rename\": \"^1.2.2\",    \n    \"gulp-uglify\": \"^1.2.0\",\n    \"gulp-util\": \"^3.0.4\",\n    \"tape\": \"^3.5.0\",\n    \"vinyl-source-stream\": \"^1.0.0\"\n  },\n  \"dependencies\": {\n    \"d.js\": \"^0.6.0\",    \n    \"superagent\": \"^0.21.0\",\n    \"ws\": \"^0.4.32\"\n  },\n  \"main\": \"deployr.js\",\n  \"engines\": {\n    \"node\": \">= 0.10.0\"\n  },\n  \"license\": \"Apache 2.0 License\",\n  \"bugs\": {\n    \"url\": \"https://github.com/deployr/js-client-library/issues\"\n  },\n  \"directories\": {\n    \"example\": \"examples\",\n    \"test\": \"test\"\n  }\n}\n"]} diff --git a/browser/deployr.min.js b/browser/deployr.min.js index 1a50bb2..9f03786 100644 --- a/browser/deployr.min.js +++ b/browser/deployr.min.js @@ -144,4 +144,4 @@ * Date: 2015-07-27 */ !function(t){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=t();else if("function"==typeof define&&define.amd)define([],t);else{var e;e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:this,e.deployr=t()}}(function(){var t;return function e(t,r,o){function i(s,a){if(!r[s]){if(!t[s]){var c="function"==typeof require&&require;if(!a&&c)return c(s,!0);if(n)return n(s,!0);var u=new Error("Cannot find module '"+s+"'");throw u.code="MODULE_NOT_FOUND",u}var l=r[s]={exports:{}};t[s][0].call(l.exports,function(e){var r=t[s][1][e];return i(r?r:e)},l,l.exports,e,t,r,o)}return r[s].exports}for(var n="function"==typeof require&&require,s=0;s3&&(o=o.slice(1)),E["new"]("/r/repository/shell/execute",r).data({author:o[0],directory:o[1],filename:o[2],args:e})},code:function(t,e){var r={cookies:this.cookies,queue:this.q,deferred:this.deferred},o="/r/project/execute/code";return e?E["new"](o,r).data({code:t,project:e}):E["new"]("/r/project/create",r).end(function(t){return{project:t.get("project").project}}).io(o).data({code:t})},release:function(t,e){function r(t){t===c&&(e?(i.resolve(!0),o.destroy()):E["new"]("/r/user/logout").share(u).error(function(){i.reject(!1)}).end(function(){i.resolve(!0)}).ensure(function(){o.destroy()}))}t=p.isArray(t)?t:[t];var o=this,i=s(),n=!t||!t[0],a=0,c=n?a:t.length-1,u=this.getCookies();return n?r(a):t.forEach(function(t){E["new"]("/r/project/close").data({project:t}).share(u).end().ensure(function(){r(a),a++})}),i.promise},routputs:function(t){return t&&(this.outputs=this.outputs.concat(t)),this},routput:function(t){return t&&this.routputs([t]),this},rinputs:function(t){return t&&(this.inputs=this.inputs.concat(t)),this},rinput:function(t){return t&&this.inputs.push(t),this},destroy:function(){try{this.emit("destroy"),this.offAll();for(var t in this)this.hasOwnProperty(t)&&(this[t]=null,delete this[t])}catch(e){}},_clear:function(){this.params={},this.inputs=[],this.outputs=[],this.rstream=!1,this.delayed=!1,this.api=null,this.file=null,this.entities=null,this.ioFilter=null},_prepRequest:function(t,e){var r=this.req,o=this.file;if(this.api.upload?i||this.req.type("multipart/form-data"):r.type("form"),r.on("error",function(t){t=t||{code:"UNKNOWN CODE",text:"UNKNOWN ERROR"},this._handleError({status:t.code||"UNKNOWN CODE",text:t})}.bind(this)),this.share(e?e.__cookies__:null),e&&this.data(e),this.inputs.length>0&&this.data({inputs:y.encode(this.inputs)}),this.outputs.length>0&&this.data({robjects:this.outputs.join()}),this.cookies&&this.cookies.forEach(function(t){r.set("Cookie",t)}),this.api.upload){for(var n in this.params)r.field(n,this.params[n]||this.params[n]===!1?this.params[n]+"":"");r.attach("file",this.rstream?a.createReadStream(o):o)}else r["GET"===this.api.method?"query":"send"](this.params)},_handleError:function(t){var e=t.status,r=t.body&&t.body.deployr?t.body:t,i=200!==e||r.deployr&&!r.deployr.response.success;return i&&(r={get:function(t){return l.get(this.deployr.response,t)},deployr:{response:{success:!1,call:this.api.call,errorCode:r.deployr?r.deployr.response.errorCode:e,error:r.deployr?r.deployr.response.error:r.text}}},h.error("error()",this.api,r,t),this.logger.error("error()",this.api,r,t),this.globalEvts&&o(this.api.call,r),this.emit("error",r),this.emit("deployr-io:"+r.deployr.response.errorCode,r),this.deferred.reject(r)),i}});i&&(window.Revolution=window.Revolution||t("./lib/deprecated")),e.exports={DeployR:E,apis:function(t){return t?Object.keys(c):c},configure:function(t){t=t||{};for(var e in t)j.set(e,t[e]);return j.sticky||j.set("cookies",null),h.setLevel(j.logging?h.DEBUG:h.OFF),this},io:function(t){return E["new"](t)},auth:function(t,e){var r={username:t,password:e};return E["new"]("/r/user/login").data(r).end()},script:function(){var t=l.signature(arguments),e=t.opts,r=t.api;return t.create?E["new"]("/r/project/create").end(function(t){return{project:t.get("project").project}}).io(r).data(e):E["new"](r).data(e)},pipeline:function(t){function e(){i.add(function(){t.shift().drain().then(function(t){n.push(t),a.push(c),i.isEmpty()&&(r.configure(u),o.resolve({results:n,errors:a})),i.take()},function(t){n.push(c),a.push(t),i.isEmpty()&&0===n.length&&(r.configure(u),o.reject(a)),i.take()})},null,!0)}var r=this,o=s(),i=new f,n=[],a=[],c=null,u={sticky:j.sticky,cookies:j.cookies};t=t.slice(0),r.configure({sticky:!0});for(var l=0;l=0;o.lengthi?"0"+i:i,s=10>s?"0"+s:s,a=10>a?"0"+a:a,c=10>c?"0"+c:c,l=o+"-"+i+"-"+n,e===p.RPOSIX_DATE||e===p.RPOSIX_DATE_VECTOR){var h=s+":"+a+":"+c,f=-u,d="+";0>f&&(f=-f,d="-"),u=d+r(f/60,2)+""+r(f%60,2),l+=" "+h+" "+u}return l}function n(t,e){for(var r=t.value,s=0;s "+i[2].call]);for(var u=2;u=this.context.value&&o(e,{level:t,name:this.context.name,value:this.context.value})},debug:function(){this.log(s.DEBUG,arguments)},error:function(){this.log(s.ERROR,arguments)},info:function(){this.log(s.INFO,arguments)},warn:function(){this.log(s.WARN,arguments)},setLevel:function(t){t&&"value"in t&&(this.context=t)}},s.DEBUG={value:1,name:"DEBUG"},s.INFO={value:2,name:"INFO"},s.WARN={value:4,name:"WARN"},s.ERROR={value:8,name:"ERROR"},s.OFF={value:99,name:"OFF"},s.setLevel=function(t){n.setLevel(t)},s.debug=function(){n.debug.apply(n,arguments)},s.info=function(){n.info.apply(n,arguments)},s.warn=function(){n.warn.apply(n,arguments)},s.error=function(){n.error.apply(n,arguments)},s.get=function(t,e,r){return a[t]||function(){return a[t]=new i(t,e,r),a[t]}()},n=s.get("global"),e.exports=s},{}],9:[function(t,e,r){e.exports=function(e){try{return t(e)}catch(r){}}},{}],10:[function(t,e,r){function o(){this.emptyCallback=null,this.callbacks=[],this.yielded=!1,this.response=null,this.responseChain=[]}o.prototype={add:function(t,e,r){this.yielded||r?this.callbacks.push({fn:t,ctx:e}):t.apply(e||this,[this.response])},size:function(){return this.callbacks.length},isEmpty:function(){return 0===this.callbacks.length},empty:function(t,e){this.emptyCallback={fn:t,ctx:e}},"yield":function(t){this.yielded=t},take:function(t,e,r){var o;t&&(this.response=t,this.responseChain.push(t)),!this.yielded&&this.callbacks[0]&&(o=this.callbacks.shift(),o.fn.apply(o.ctx||this,[this.responseChain,e,r]),this.callbacks[0]&&this.emptyCallback&&this.emptyCallback.fn.call(this.emptyCallback.ctx||this))},flush:function(t,e,r){for(t&&(this.response=t,this.responseChain.push(t));this.callbacks[0]&&!this.yielded;){var o=this.callbacks.shift();o.fn.apply(o.ctx||this,[this.responseChain,e,r]),this.callbacks[0]&&this.emptyCallback&&this.emptyCallback.fn.call(this.emptyCallback.ctx||this)}}},e.exports=o},{}],11:[function(t,e,r){var o=t("./selfish").Base,i=t("./rtypes");e.exports=o.extend(i,{initialize:function(t,e,r){this.name=t,this.value=e,this.options=r||{}},numeric:function(){return this.assert({type:this.deployr.RNUMERIC,name:this.name,value:this.value,toString:this.toString})},integer:function(){return this.assert({type:this.deployr.RINTEGER,name:this.name,value:this.value,toString:this.toString})},logical:function(){return this.assert({type:this.deployr.RBOOLEAN,name:this.name,value:this.value,toString:this.toString})},character:function(){return this.assert({type:this.deployr.RSTRING,name:this.name,value:this.value,toString:this.toString})},date:function(){return this.assert({type:this.deployr.RDATE,name:this.name,value:this.value,format:"yyyy-MM-dd",toString:this.toString})},posixct:function(){return this.assert({type:this.deployr.RPOSIX_DATE,name:this.name,value:this.value,format:"yyyy-MM-dd HH:mm:ss Z",toString:this.toString})},numericVector:function(){return this.assert({type:this.deployr.RNUMERIC_VECTOR,name:this.name,value:this.value,toString:this.toString})},integerVector:function(){return this.assert({type:this.deployr.RINTEGER_VECTOR,name:this.name,value:this.value,toString:this.toString})},logicalVector:function(){return this.assert({type:this.deployr.RBOOLEAN_VECTOR,name:this.name,value:this.value,toString:this.toString})},characterVector:function(){return this.assert({type:this.deployr.RSTRING_VECTOR,name:this.name,value:this.value,toString:this.toString})},dateVector:function(){return this.assert({type:this.deployr.RDATE_VECTOR,name:this.name,value:this.value,format:"yyyy-MM-dd",toString:this.toString})},posixctVector:function(){return this.assert({type:this.deployr.RPOSIX_DATE_VECTOR,name:this.name,value:this.value,format:"yyyy-MM-dd HH:mm:ss Z",toString:this.toString})},list:function(){return this.assert({type:this.deployr.RLIST,name:this.name,value:this.value,toString:this.toString})},dataframe:function(){return this.assert({type:this.deployr.RDATAFRAME,name:this.name,value:this.value,toString:this.toString})},factor:function(){var t=this.options;return this.assert({type:this.deployr.RFACTOR,name:this.name,value:this.value,ordered:!1,levels:t.levels,labels:t.labels,toString:this.toString})},ordered:function(){var t=this.options;return this.assert({type:this.deployr.RORDERED,name:this.name,value:this.value,ordered:!0,levels:t.levels,labels:t.labels,toString:this.toString})},numericMatrix:function(){return this.assert({type:this.deployr.RNUMERIC_MATRIX,name:this.name,value:this.value,toString:this.toString})},integerMatrix:function(){return this.assert({type:this.deployr.RINTEGER_MATRIX,name:this.name,value:this.value,toString:this.toString})},logicalMatrix:function(){return this.assert({type:this.deployr.RBOOLEAN_MATRIX,name:this.name,value:this.value,toString:this.toString})},characterMatrix:function(){return this.assert({type:this.deployr.RSTRING_MATRIX,name:this.name,value:this.value,toString:this.toString})},toString:function(){var t=this.options||{},e=t.levels?"[ levels = "+t.levels+"]":"",r=t.labels?"[ labels = "+t.labels+"]":"";return"[ name = "+this.name+" ] [ value = "+this.value+" ] [ type = "+this.type+" ] "+e+r}})},{"./rtypes":13,"./selfish":14}],12:[function(t,e,r){function o(t,e,r,o){var i;if(s.isObject(e)){if(i=e,!i.type!==t)throw new Error('IllegalArgumentError:Expecting "'+t+'" but found "'+i.type+'"')}else i=a["new"](e,r,o)[t]();return i}var i=t("./selfish").Base,n=t("./rtypes"),s=t("./lang"),a=t("./rinput");e.exports=i.extend(n,{numeric:function(t,e){return this.inputs.push(o(this.deployr.RNUMERIC,t,e)),this},integer:function(t,e){return this.inputs.push(o(this.deployr.RINTEGER,t,e)),this},logical:function(t,e){return this.inputs.push(o(this.deployr.RBOOLEAN,t,e)),this},character:function(t,e){return this.inputs.push(o(this.deployr.RSTRING,t,e)),this},date:function(t,e){return this.inputs.push(o(this.deployr.RDATE,t,e)),this},posixct:function(t,e){return this.inputs.push(o(this.deployr.RPOSIX_DATE,t,e)),this},numericVector:function(t,e){return this.inputs.push(o(this.deployr.RNUMERIC_VECTOR,t,e)),this},integerVector:function(t,e){return this.inputs.push(o(this.deployr.RINTEGER_VECTOR,t,e)),this},logicalVector:function(t,e){return this.inputs.push(o(this.deployr.RBOOLEAN_VECTOR,t,e)),this},characterVector:function(t,e){return this.inputs.push(o(this.deployr.RSTRING_VECTOR,t,e)),this},dateVector:function(t,e){return this.inputs.push(o(this.deployr.RDATE_VECTOR,t,e)),this},posixctVector:function(t,e){return this.inputs.push(o(this.deployr.RPOSIX_DATE_VECTOR,t,e)),this},list:function(t,e){return this.inputs.push(o(this.deployr.RLIST,t,e)),this},dataframe:function(t,e){return this.inputs.push(o(this.deployr.RDATAFRAME,t,e)),this},factor:function(t,e,r,i){var n={levels:r,labels:i};return this.inputs.push(o(this.deployr.RFACTOR,t,e,n)),this},ordered:function(t,e,r,i){var n={levels:r,labels:i};return this.inputs.push(o(this.deployr.RORDERED,t,e,n)),this},numericMatrix:function(t,e){return this.inputs.push(o(this.deployr.RNUMERIC_MATRIX,t,e)),this},integerMatrix:function(t,e){return this.inputs.push(o(this.deployr.RINTEGER_MATRIX,t,e)),this},logicalMatrix:function(t,e){return this.inputs.push(o(this.deployr.RBOOLEAN_MATRIX,t,e)),this},characterMatrix:function(t,e){return this.inputs.push(o(this.deployr.RSTRING_MATRIX,t,e)),this}})},{"./lang":7,"./rinput":11,"./rtypes":13,"./selfish":14}],13:[function(t,e,r){var o=t("./selfish").Base,i=t("./lang"),n={};e.exports=o.extend({r:{PRIMITIVE:"primitive",DATAFRAME:"dataframe",LIST:"list",MATRIX:"matrix",DATE:"date",FACTOR:"factor",VECTOR:"vector"},deployr:{RBOOLEAN:"logical",RNUMERIC:"numeric",RINTEGER:"integer",RSTRING:"character",RDATE:"date",RPOSIX_DATE:"posixct",RBOOLEAN_VECTOR:"logicalVector",RNUMERIC_VECTOR:"numericVector",RINTEGER_VECTOR:"integerVector",RSTRING_VECTOR:"characterVector",RDATE_VECTOR:"dateVector",RPOSIX_DATE_VECTOR:"posixctVector",RLIST:"list",RDATAFRAME:"dataframe",RFACTOR:"factor",RORDERED:"ordered",RBOOLEAN_MATRIX:"logicalMatrix",RNUMERIC_MATRIX:"numericMatrix",RINTEGER_MATRIX:"integerMatrix",RSTRING_MATRIX:"characterMatrix"},isDate:function(t){return t===this.deployr.RDATE||t===this.deployr.RPOSIX_DATE||t===this.deployr.RDATE_VECTOR||t===this.deployr.RPOSIX_DATE_VECTOR||t===this.r.DATE},deployrToR:function(t){var e=this.deployr,r=this.r;return n[t]||(n[e.RBOOLEAN]=r.PRIMITIVE,n[e.RNUMERIC]=r.PRIMITIVE,n[e.RINTEGER]=r.PRIMITIVE,n[e.RSTRING]=r.PRIMITIVE,n[e.RDATE]=r.DATE,n[e.RPOSIX_DATE]=r.DATE,n[e.RBOOLEAN_VECTOR]=r.VECTOR,n[e.RNUMERIC_VECTOR]=r.VECTOR,n[e.RINTEGER_VECTOR]=r.VECTOR,n[e.RSTRING_VECTOR]=r.VECTOR,n[e.RDATE_VECTOR]=r.VECTOR,n[e.RPOSIX_DATE_VECTOR]=r.VECTOR,n[e.RLIST]=r.LIST,n[e.RDATAFRAME]=r.DATAFRAME,n[e.RFACTOR]=r.FACTOR,n[e.RORDERED]=r.FACTOR,n[e.RBOOLEAN_MATRIX]=r.MATRIX,n[e.RNUMERIC_MATRIX]=r.MATRIX,n[e.RINTEGER_MATRIX]=r.MATRIX,n[e.RSTRING_MATRIX]=r.MATRIX),n[t]},assert:function(t){var e,r=this.deployr,o=null,n=t.value;n=i.isArray(n)?n:[n];for(var s=0;so;o++)if(r){if(t[o][r]===e)return t[o]}else if(t[o]===e)return t[o];return null};r.merge=function(t,e){t&&"object"==typeof t||(t={}),e&&"object"==typeof e||(e={});for(var r in e)t[r]=e[r];return t},r.workspace=function(t,e){var r=i(t,"workspace");return r?e?n(r.objects,e,"name"):r.objects||r.object:null},r.signature=function(){var t,e=Array.prototype.slice.call(arguments[0],0),r=e.length,i=!1,n={};if(1===r&&o.isObject(e[0]))n=e[0],t=n.project?"/r/project/execute/script":"/r/repository/script/execute";else if(1===r&&o.isString(e[0]))e=e[0].split("/"),t="/r/repository/script/execute",n={author:e[1],directory:e[2],filename:e[3]};else if(2===r){var s=e[1];t=s?"/r/project/execute/script":"/r/repository/script/execute",e=e[0].split("/"),n={project:s,author:e[1],directory:e[2],filename:e[3]}}else r>2&&(n={author:e[2],directory:e[1],filename:e[0]});return n.project&&o.isBoolean(n.project)&&(delete n.project,i=!0),{api:t,opts:n,create:i}}},{"./lang":7}],16:[function(t,e,r){},{}],17:[function(t,e,r){function o(){if(!a){a=!0;for(var t,e=s.length;e;){t=s,s=[];for(var r=-1;++ra;a++)s(a);else i.resolve(o);return i.promise}var p,h=function(t){return"function"==typeof t},f=function(t){return Array.isArray?Array.isArray(t):t instanceof Array},d=function(t){return!(!t||!(typeof t).match(/function|object/))},y=function(t){return t===!1||t===r||null===t},m=function(t,e){return[].slice.call(t,e)},v="undefined",R=typeof TypeError===v?Error:TypeError;if(typeof t!==v&&t.nextTick)p=t.nextTick;else if(typeof MessageChannel!==v){var g=new MessageChannel,j=[];g.port1.onmessage=function(){j.length&&j.shift()()},p=function(t){j.push(t),g.port2.postMessage(0)}}else p=function(t){setTimeout(t,0)};var T=function(t){function e(){if(0!==v){var t,e=g,r=0,o=e.length,i=~v?0:1;for(g=[];o>r;r++)(t=e[r][i])&&t(f)}}function o(t){function r(t){return function(e){return i?void 0:(i=!0,t(e))}}var i=!1;if(v)return this;try{var n=d(t)&&t.then;if(h(n)){if(t===j)throw new R("Promise can't resolve itself");return n.call(t,r(o),r(l)),this}}catch(s){return r(l)(s),this}return m(function(){f=t,v=1,e()}),this}function l(t){return v||m(function(){try{throw t}catch(r){f=r}v=-1,e()}),this}var f,m=(r!==t?t:T.alwaysAsync)?p:function(t){t()},v=0,g=[],j={then:function(t,r){var o=T();return g.push([function(e){try{o.resolve(y(t)?e:h(t)?t(e):T.onlyFuncs?e:t)}catch(r){o.reject(r)}},function(t){if((y(r)||!h(r)&&T.onlyFuncs)&&o.reject(t),r)try{o.resolve(h(r)?r(t):r)}catch(e){o.reject(e)}}]),0!==v&&m(e),o.promise},success:i,error:n,otherwise:n,apply:s,spread:s,ensure:a,nodify:c,rethrow:u,isPending:function(){return!(0!==v)},getStatus:function(){return v}};return j.toSource=j.toString=j.valueOf=function(){return f===r?this:f},{promise:j,resolve:o,fulfill:o,reject:l}};T.deferred=T.defer=T,T.nextTick=p,T.alwaysAsync=!0,T.onlyFuncs=!0,T.resolved=T.fulfilled=function(t){return T(!0).resolve(t).promise},T.rejected=function(t){return T(!0).reject(t).promise},T.wait=function(t){var e=T();return setTimeout(e.resolve,t||0),e.promise},T.delay=function(t,e){var r=T();return setTimeout(function(){try{r.resolve(t.apply(null))}catch(e){r.reject(e)}},e||0),r.promise},T.promisify=function(t){return t&&h(t.then)?t:T.resolved(t)},T.all=function(){return l(arguments,!1)},T.resolveAll=function(){return l(arguments,!0)},T.nodeCapsule=function(t,e){return e||(e=t,t=void 0),function(){var r=T(),o=m(arguments);o.push(function(t,e){t?r.reject(t):r.resolve(arguments.length>2?m(arguments,1):e)});try{e.apply(t,o)}catch(i){r.reject(i)}return r.promise}},typeof window!==v&&(window.D=T),typeof e!==v&&e.exports&&(e.exports=T)}()}).call(this,t("_process"))},{_process:17}],19:[function(t,e,r){function o(){}function i(t){var e={}.toString.call(t);switch(e){case"[object File]":case"[object Blob]":case"[object FormData]":return!0;default:return!1}}function n(){if(v.XMLHttpRequest&&("file:"!=v.location.protocol||!v.ActiveXObject))return new XMLHttpRequest;try{return new ActiveXObject("Microsoft.XMLHTTP")}catch(t){}try{return new ActiveXObject("Msxml2.XMLHTTP.6.0")}catch(t){}try{return new ActiveXObject("Msxml2.XMLHTTP.3.0")}catch(t){}try{return new ActiveXObject("Msxml2.XMLHTTP")}catch(t){}return!1}function s(t){return t===Object(t)}function a(t){if(!s(t))return t;var e=[];for(var r in t)null!=t[r]&&e.push(encodeURIComponent(r)+"="+encodeURIComponent(t[r]));return e.join("&")}function c(t){for(var e,r,o={},i=t.split("&"),n=0,s=i.length;s>n;++n)r=i[n],e=r.split("="),o[decodeURIComponent(e[0])]=decodeURIComponent(e[1]);return o}function u(t){var e,r,o,i,n=t.split(/\r?\n/),s={};n.pop();for(var a=0,c=n.length;c>a;++a)r=n[a],e=r.indexOf(":"),o=r.slice(0,e).toLowerCase(),i=R(r.slice(e+1)),s[o]=i;return s}function l(t){return t.split(/ *; */).shift()}function p(t){return m(t.split(/ *; */),function(t,e){var r=e.split(/ *= */),o=r.shift(),i=r.shift();return o&&i&&(t[o]=i),t},{})}function h(t,e){e=e||{},this.req=t,this.xhr=this.req.xhr,this.text="HEAD"!=this.req.method?this.xhr.responseText:null,this.setStatusProperties(this.xhr.status),this.header=this.headers=u(this.xhr.getAllResponseHeaders()),this.header["content-type"]=this.xhr.getResponseHeader("content-type"),this.setHeaderProperties(this.header),this.body="HEAD"!=this.req.method?this.parseBody(this.text):null}function f(t,e){var r=this;y.call(this),this._query=this._query||[],this.method=t,this.url=e,this.header={},this._header={},this.on("end",function(){var t=null,e=null;try{e=new h(r)}catch(o){t=new Error("Parser is unable to parse the response"),t.parse=!0,t.original=o}r.callback(t,e)})}function d(t,e){return"function"==typeof e?new f("GET",t).end(e):1==arguments.length?new f("GET",t):new f(t,e)}var y=t("emitter"),m=t("reduce"),v="undefined"==typeof window?this:window,R="".trim?function(t){return t.trim()}:function(t){return t.replace(/(^\s*|\s*$)/g,"")};d.serializeObject=a,d.parseString=c,d.types={html:"text/html",json:"application/json",xml:"application/xml",urlencoded:"application/x-www-form-urlencoded",form:"application/x-www-form-urlencoded","form-data":"application/x-www-form-urlencoded"},d.serialize={"application/x-www-form-urlencoded":a,"application/json":JSON.stringify},d.parse={"application/x-www-form-urlencoded":c,"application/json":JSON.parse},h.prototype.get=function(t){return this.header[t.toLowerCase()]},h.prototype.setHeaderProperties=function(t){var e=this.header["content-type"]||"";this.type=l(e);var r=p(e);for(var o in r)this[o]=r[o]},h.prototype.parseBody=function(t){var e=d.parse[this.type];return e&&t&&t.length?e(t):null},h.prototype.setStatusProperties=function(t){var e=t/100|0;this.status=t,this.statusType=e,this.info=1==e,this.ok=2==e,this.clientError=4==e,this.serverError=5==e,this.error=4==e||5==e?this.toError():!1,this.accepted=202==t,this.noContent=204==t||1223==t,this.badRequest=400==t,this.unauthorized=401==t,this.notAcceptable=406==t,this.notFound=404==t,this.forbidden=403==t},h.prototype.toError=function(){var t=this.req,e=t.method,r=t.url,o="cannot "+e+" "+r+" ("+this.status+")",i=new Error(o);return i.status=this.status,i.method=e,i.url=r,i},d.Response=h,y(f.prototype),f.prototype.use=function(t){return t(this),this},f.prototype.timeout=function(t){return this._timeout=t,this},f.prototype.clearTimeout=function(){return this._timeout=0,clearTimeout(this._timer),this},f.prototype.abort=function(){return this.aborted?void 0:(this.aborted=!0,this.xhr.abort(),this.clearTimeout(),this.emit("abort"),this)},f.prototype.set=function(t,e){if(s(t)){for(var r in t)this.set(r,t[r]);return this}return this._header[t.toLowerCase()]=e,this.header[t]=e,this},f.prototype.unset=function(t){return delete this._header[t.toLowerCase()],delete this.header[t],this},f.prototype.getHeader=function(t){return this._header[t.toLowerCase()]},f.prototype.type=function(t){return this.set("Content-Type",d.types[t]||t),this},f.prototype.accept=function(t){return this.set("Accept",d.types[t]||t),this},f.prototype.auth=function(t,e){var r=btoa(t+":"+e);return this.set("Authorization","Basic "+r),this},f.prototype.query=function(t){return"string"!=typeof t&&(t=a(t)),t&&this._query.push(t),this},f.prototype.field=function(t,e){return this._formData||(this._formData=new FormData),this._formData.append(t,e),this},f.prototype.attach=function(t,e,r){return this._formData||(this._formData=new FormData),this._formData.append(t,e,r),this},f.prototype.send=function(t){var e=s(t),r=this.getHeader("Content-Type");if(e&&s(this._data))for(var o in t)this._data[o]=t[o];else"string"==typeof t?(r||this.type("form"),r=this.getHeader("Content-Type"),this._data="application/x-www-form-urlencoded"==r?this._data?this._data+"&"+t:t:(this._data||"")+t):this._data=t;return e?(r||this.type("json"),this):this},f.prototype.callback=function(t,e){var r=this._callback;return this.clearTimeout(),2==r.length?r(t,e):t?this.emit("error",t):void r(e)},f.prototype.crossDomainError=function(){var t=new Error("Origin is not allowed by Access-Control-Allow-Origin");t.crossDomain=!0,this.callback(t)},f.prototype.timeoutError=function(){var t=this._timeout,e=new Error("timeout of "+t+"ms exceeded");e.timeout=t,this.callback(e)},f.prototype.withCredentials=function(){return this._withCredentials=!0,this},f.prototype.end=function(t){var e=this,r=this.xhr=n(),s=this._query.join("&"),a=this._timeout,c=this._formData||this._data;if(this._callback=t||o,r.onreadystatechange=function(){return 4==r.readyState?0==r.status?e.aborted?e.timeoutError():e.crossDomainError():void e.emit("end"):void 0},r.upload&&(r.upload.onprogress=function(t){t.percent=t.loaded/t.total*100,e.emit("progress",t)}),a&&!this._timer&&(this._timer=setTimeout(function(){e.abort()},a)),s&&(s=d.serializeObject(s),this.url+=~this.url.indexOf("?")?"&"+s:"?"+s),r.open(this.method,this.url,!0),this._withCredentials&&(r.withCredentials=!0),"GET"!=this.method&&"HEAD"!=this.method&&"string"!=typeof c&&!i(c)){var u=d.serialize[this.getHeader("Content-Type")];u&&(c=u(c))}for(var l in this.header)null!=this.header[l]&&r.setRequestHeader(l,this.header[l]);return this.emit("request",this),r.send(c),this},d.Request=f,d.get=function(t,e,r){var o=d("GET",t);return"function"==typeof e&&(r=e,e=null),e&&o.query(e),r&&o.end(r),o},d.head=function(t,e,r){var o=d("HEAD",t);return"function"==typeof e&&(r=e,e=null),e&&o.send(e),r&&o.end(r),o},d.del=function(t,e){var r=d("DELETE",t);return e&&r.end(e),r},d.patch=function(t,e,r){var o=d("PATCH",t);return"function"==typeof e&&(r=e,e=null),e&&o.send(e),r&&o.end(r),o},d.post=function(t,e,r){var o=d("POST",t);return"function"==typeof e&&(r=e,e=null),e&&o.send(e),r&&o.end(r),o},d.put=function(t,e,r){var o=d("PUT",t);return"function"==typeof e&&(r=e,e=null),e&&o.send(e),r&&o.end(r),o},e.exports=d},{emitter:20,reduce:21}],20:[function(t,e,r){function o(t){return t?i(t):void 0}function i(t){for(var e in o.prototype)t[e]=o.prototype[e];return t}e.exports=o,o.prototype.on=o.prototype.addEventListener=function(t,e){return this._callbacks=this._callbacks||{},(this._callbacks[t]=this._callbacks[t]||[]).push(e),this},o.prototype.once=function(t,e){function r(){o.off(t,r),e.apply(this,arguments)}var o=this;return this._callbacks=this._callbacks||{},r.fn=e,this.on(t,r),this},o.prototype.off=o.prototype.removeListener=o.prototype.removeAllListeners=o.prototype.removeEventListener=function(t,e){if(this._callbacks=this._callbacks||{},0==arguments.length)return this._callbacks={},this;var r=this._callbacks[t];if(!r)return this;if(1==arguments.length)return delete this._callbacks[t],this;for(var o,i=0;io;++o)r[o].apply(this,e)}return this},o.prototype.listeners=function(t){return this._callbacks=this._callbacks||{},this._callbacks[t]||[]},o.prototype.hasListeners=function(t){return!!this.listeners(t).length}},{}],21:[function(t,e,r){e.exports=function(t,e,r){for(var o=0,i=t.length,n=3==arguments.length?r:t[o++];i>o;)n=e.call(null,n,t[o],++o,t);return n}},{}],22:[function(t,e,r){e.exports={name:"deployr",version:"7.4.1",description:"Simplified JavaScript client library for making requests to DeployR.",keywords:["deployr","deployr.io","ajax","R","api","simple"],author:"DeployR - Revolution Analytics Inc.",contributors:["Sean Wells"],repository:{type:"git",url:"git://github.com/deployr/js-client-library.git"},homepage:"http://deployr.revolutionanalytics.com/documents/dev/client-jsdoc",scripts:{start:"gulp start",build:"gulp"},devDependencies:{browserify:"^9.0.3",gulp:"^3.8.11","gulp-connect":"^2.2.0","gulp-header":"^1.2.2","gulp-jshint":"^1.9.2","gulp-livereload":"^3.8.0","gulp-plumber":"^0.6.6","gulp-rename":"^1.2.2","gulp-uglify":"^1.2.0","gulp-util":"^3.0.4",tape:"^3.5.0","vinyl-source-stream":"^1.0.0"},dependencies:{"d.js":"^0.6.0",superagent:"^0.21.0",ws:"^0.4.32"},main:"deployr.js",engines:{node:">= 0.10.0"},license:"Apache 2.0 License",bugs:{url:"https://github.com/deployr/js-client-library/issues"},directories:{example:"examples",test:"test"}}},{}]},{},[1])(1)}); \ No newline at end of file +value:i(u.value,u.type)};break;case p.RFACTOR:case p.RORDERED:e={name:u.name,type:l.FACTOR,ordered:u.ordered,labels:u.labels,levels:u.levels,value:u.value};break;case p.RSTRING:case p.RBOOLEAN:case p.RNUMERIC:case p.RINTEGER:e={name:u.name,type:l.PRIMITIVE,value:u.value};break;case p.RNUMERIC_VECTOR:case p.RINTEGER_VECTOR:case p.RBOOLEAN_VECTOR:case p.RSTRING_VECTOR:e={name:u.name,type:l.VECTOR,value:u.value};break;case p.RDATE_VECTOR:case p.RPOSIX_DATE_VECTOR:e={name:u.name,type:l.VECTOR,value:o(u.value,u.type),format:u.format};break;default:throw new Error('No RDataType found for "'+u.type+'"')}r.value.push(e)}return r}var c=t("./lang"),u=t("./rtypes"),l=u.r,p=u.deployr;e.exports={encode:function(t){for(var e={},r=0;r "+i[2].call]);for(var u=2;u=this.context.value&&o(e,{level:t,name:this.context.name,value:this.context.value})},debug:function(){this.log(s.DEBUG,arguments)},error:function(){this.log(s.ERROR,arguments)},info:function(){this.log(s.INFO,arguments)},warn:function(){this.log(s.WARN,arguments)},setLevel:function(t){t&&"value"in t&&(this.context=t)}},s.DEBUG={value:1,name:"DEBUG"},s.INFO={value:2,name:"INFO"},s.WARN={value:4,name:"WARN"},s.ERROR={value:8,name:"ERROR"},s.OFF={value:99,name:"OFF"},s.setLevel=function(t){n.setLevel(t)},s.debug=function(){n.debug.apply(n,arguments)},s.info=function(){n.info.apply(n,arguments)},s.warn=function(){n.warn.apply(n,arguments)},s.error=function(){n.error.apply(n,arguments)},s.get=function(t,e,r){return a[t]||function(){return a[t]=new i(t,e,r),a[t]}()},n=s.get("global"),e.exports=s},{}],9:[function(t,e,r){e.exports=function(e){try{return t(e)}catch(r){}}},{}],10:[function(t,e,r){function o(){this.emptyCallback=null,this.callbacks=[],this.yielded=!1,this.response=null,this.responseChain=[]}o.prototype={add:function(t,e,r){this.yielded||r?this.callbacks.push({fn:t,ctx:e}):t.apply(e||this,[this.response])},size:function(){return this.callbacks.length},isEmpty:function(){return 0===this.callbacks.length},empty:function(t,e){this.emptyCallback={fn:t,ctx:e}},"yield":function(t){this.yielded=t},take:function(t,e,r){var o;t&&(this.response=t,this.responseChain.push(t)),!this.yielded&&this.callbacks[0]&&(o=this.callbacks.shift(),o.fn.apply(o.ctx||this,[this.responseChain,e,r]),this.callbacks[0]&&this.emptyCallback&&this.emptyCallback.fn.call(this.emptyCallback.ctx||this))},flush:function(t,e,r){for(t&&(this.response=t,this.responseChain.push(t));this.callbacks[0]&&!this.yielded;){var o=this.callbacks.shift();o.fn.apply(o.ctx||this,[this.responseChain,e,r]),this.callbacks[0]&&this.emptyCallback&&this.emptyCallback.fn.call(this.emptyCallback.ctx||this)}}},e.exports=o},{}],11:[function(t,e,r){var o=t("./selfish").Base,i=t("./rtypes");e.exports=o.extend(i,{initialize:function(t,e,r){this.name=t,this.value=e,this.options=r||{}},numeric:function(){return this.value=parseFloat(this.value),this.assert({type:this.deployr.RNUMERIC,name:this.name,value:this.value,toString:this.toString})},integer:function(){return this.value=parseInt(this.value,10),this.assert({type:this.deployr.RINTEGER,name:this.name,value:this.value,toString:this.toString})},logical:function(){return this.assert({type:this.deployr.RBOOLEAN,name:this.name,value:this.value,toString:this.toString})},character:function(){return this.assert({type:this.deployr.RSTRING,name:this.name,value:this.value,toString:this.toString})},date:function(){return this.assert({type:this.deployr.RDATE,name:this.name,value:this.value,format:"yyyy-MM-dd",toString:this.toString})},posixct:function(){return this.assert({type:this.deployr.RPOSIX_DATE,name:this.name,value:this.value,format:"yyyy-MM-dd HH:mm:ss Z",toString:this.toString})},numericVector:function(){return this.assert({type:this.deployr.RNUMERIC_VECTOR,name:this.name,value:this.value,toString:this.toString})},integerVector:function(){return this.assert({type:this.deployr.RINTEGER_VECTOR,name:this.name,value:this.value,toString:this.toString})},logicalVector:function(){return this.assert({type:this.deployr.RBOOLEAN_VECTOR,name:this.name,value:this.value,toString:this.toString})},characterVector:function(){return this.assert({type:this.deployr.RSTRING_VECTOR,name:this.name,value:this.value,toString:this.toString})},dateVector:function(){return this.assert({type:this.deployr.RDATE_VECTOR,name:this.name,value:this.value,format:"yyyy-MM-dd",toString:this.toString})},posixctVector:function(){return this.assert({type:this.deployr.RPOSIX_DATE_VECTOR,name:this.name,value:this.value,format:"yyyy-MM-dd HH:mm:ss Z",toString:this.toString})},list:function(){return this.assert({type:this.deployr.RLIST,name:this.name,value:this.value,toString:this.toString})},dataframe:function(){return this.assert({type:this.deployr.RDATAFRAME,name:this.name,value:this.value,toString:this.toString})},factor:function(){var t=this.options;return this.assert({type:this.deployr.RFACTOR,name:this.name,value:this.value,ordered:!1,levels:t.levels,labels:t.labels,toString:this.toString})},ordered:function(){var t=this.options;return this.assert({type:this.deployr.RORDERED,name:this.name,value:this.value,ordered:!0,levels:t.levels,labels:t.labels,toString:this.toString})},numericMatrix:function(){return this.assert({type:this.deployr.RNUMERIC_MATRIX,name:this.name,value:this.value,toString:this.toString})},integerMatrix:function(){return this.assert({type:this.deployr.RINTEGER_MATRIX,name:this.name,value:this.value,toString:this.toString})},logicalMatrix:function(){return this.assert({type:this.deployr.RBOOLEAN_MATRIX,name:this.name,value:this.value,toString:this.toString})},characterMatrix:function(){return this.assert({type:this.deployr.RSTRING_MATRIX,name:this.name,value:this.value,toString:this.toString})},toString:function(){var t=this.options||{},e=t.levels?"[ levels = "+t.levels+"]":"",r=t.labels?"[ labels = "+t.labels+"]":"";return"[ name = "+this.name+" ] [ value = "+this.value+" ] [ type = "+this.type+" ] "+e+r}})},{"./rtypes":13,"./selfish":14}],12:[function(t,e,r){function o(t,e,r,o){var i;if(s.isObject(e)){if(i=e,!i.type!==t)throw new Error('IllegalArgumentError:Expecting "'+t+'" but found "'+i.type+'"')}else i=a["new"](e,r,o)[t]();return i}var i=t("./selfish").Base,n=t("./rtypes"),s=t("./lang"),a=t("./rinput");e.exports=i.extend(n,{numeric:function(t,e){return this.inputs.push(o(this.deployr.RNUMERIC,t,e)),this},integer:function(t,e){return this.inputs.push(o(this.deployr.RINTEGER,t,e)),this},logical:function(t,e){return this.inputs.push(o(this.deployr.RBOOLEAN,t,e)),this},character:function(t,e){return this.inputs.push(o(this.deployr.RSTRING,t,e)),this},date:function(t,e){return this.inputs.push(o(this.deployr.RDATE,t,e)),this},posixct:function(t,e){return this.inputs.push(o(this.deployr.RPOSIX_DATE,t,e)),this},numericVector:function(t,e){return this.inputs.push(o(this.deployr.RNUMERIC_VECTOR,t,e)),this},integerVector:function(t,e){return this.inputs.push(o(this.deployr.RINTEGER_VECTOR,t,e)),this},logicalVector:function(t,e){return this.inputs.push(o(this.deployr.RBOOLEAN_VECTOR,t,e)),this},characterVector:function(t,e){return this.inputs.push(o(this.deployr.RSTRING_VECTOR,t,e)),this},dateVector:function(t,e){return this.inputs.push(o(this.deployr.RDATE_VECTOR,t,e)),this},posixctVector:function(t,e){return this.inputs.push(o(this.deployr.RPOSIX_DATE_VECTOR,t,e)),this},list:function(t,e){return this.inputs.push(o(this.deployr.RLIST,t,e)),this},dataframe:function(t,e){return this.inputs.push(o(this.deployr.RDATAFRAME,t,e)),this},factor:function(t,e,r,i){var n={levels:r,labels:i};return this.inputs.push(o(this.deployr.RFACTOR,t,e,n)),this},ordered:function(t,e,r,i){var n={levels:r,labels:i};return this.inputs.push(o(this.deployr.RORDERED,t,e,n)),this},numericMatrix:function(t,e){return this.inputs.push(o(this.deployr.RNUMERIC_MATRIX,t,e)),this},integerMatrix:function(t,e){return this.inputs.push(o(this.deployr.RINTEGER_MATRIX,t,e)),this},logicalMatrix:function(t,e){return this.inputs.push(o(this.deployr.RBOOLEAN_MATRIX,t,e)),this},characterMatrix:function(t,e){return this.inputs.push(o(this.deployr.RSTRING_MATRIX,t,e)),this}})},{"./lang":7,"./rinput":11,"./rtypes":13,"./selfish":14}],13:[function(t,e,r){var o=t("./selfish").Base,i=t("./lang"),n={};e.exports=o.extend({r:{PRIMITIVE:"primitive",DATAFRAME:"dataframe",LIST:"list",MATRIX:"matrix",DATE:"date",FACTOR:"factor",VECTOR:"vector"},deployr:{RBOOLEAN:"logical",RNUMERIC:"numeric",RINTEGER:"integer",RSTRING:"character",RDATE:"date",RPOSIX_DATE:"posixct",RBOOLEAN_VECTOR:"logicalVector",RNUMERIC_VECTOR:"numericVector",RINTEGER_VECTOR:"integerVector",RSTRING_VECTOR:"characterVector",RDATE_VECTOR:"dateVector",RPOSIX_DATE_VECTOR:"posixctVector",RLIST:"list",RDATAFRAME:"dataframe",RFACTOR:"factor",RORDERED:"ordered",RBOOLEAN_MATRIX:"logicalMatrix",RNUMERIC_MATRIX:"numericMatrix",RINTEGER_MATRIX:"integerMatrix",RSTRING_MATRIX:"characterMatrix"},isDate:function(t){return t===this.deployr.RDATE||t===this.deployr.RPOSIX_DATE||t===this.deployr.RDATE_VECTOR||t===this.deployr.RPOSIX_DATE_VECTOR||t===this.r.DATE},deployrToR:function(t){var e=this.deployr,r=this.r;return n[t]||(n[e.RBOOLEAN]=r.PRIMITIVE,n[e.RNUMERIC]=r.PRIMITIVE,n[e.RINTEGER]=r.PRIMITIVE,n[e.RSTRING]=r.PRIMITIVE,n[e.RDATE]=r.DATE,n[e.RPOSIX_DATE]=r.DATE,n[e.RBOOLEAN_VECTOR]=r.VECTOR,n[e.RNUMERIC_VECTOR]=r.VECTOR,n[e.RINTEGER_VECTOR]=r.VECTOR,n[e.RSTRING_VECTOR]=r.VECTOR,n[e.RDATE_VECTOR]=r.VECTOR,n[e.RPOSIX_DATE_VECTOR]=r.VECTOR,n[e.RLIST]=r.LIST,n[e.RDATAFRAME]=r.DATAFRAME,n[e.RFACTOR]=r.FACTOR,n[e.RORDERED]=r.FACTOR,n[e.RBOOLEAN_MATRIX]=r.MATRIX,n[e.RNUMERIC_MATRIX]=r.MATRIX,n[e.RINTEGER_MATRIX]=r.MATRIX,n[e.RSTRING_MATRIX]=r.MATRIX),n[t]},assert:function(t){var e,r=this.deployr,o=null,n=t.value;n=i.isArray(n)?n:[n];for(var s=0;so;o++)if(r){if(t[o][r]===e)return t[o]}else if(t[o]===e)return t[o];return null};r.merge=function(t,e){t&&"object"==typeof t||(t={}),e&&"object"==typeof e||(e={});for(var r in e)t[r]=e[r];return t},r.workspace=function(t,e){var r=i(t,"workspace");return r?e?n(r.objects,e,"name"):r.objects||r.object:null},r.signature=function(){var t,e=Array.prototype.slice.call(arguments[0],0),r=e.length,i=!1,n={};if(1===r&&o.isObject(e[0]))n=e[0],t=n.project?"/r/project/execute/script":"/r/repository/script/execute";else if(1===r&&o.isString(e[0]))e=e[0].split("/"),t="/r/repository/script/execute",n={author:e[1],directory:e[2],filename:e[3]};else if(2===r){var s=e[1];t=s?"/r/project/execute/script":"/r/repository/script/execute",e=e[0].split("/"),n={project:s,author:e[1],directory:e[2],filename:e[3]}}else r>2&&(n={author:e[2],directory:e[1],filename:e[0]});return n.project&&o.isBoolean(n.project)&&(delete n.project,i=!0),{api:t,opts:n,create:i}}},{"./lang":7}],16:[function(t,e,r){},{}],17:[function(t,e,r){function o(){if(!a){a=!0;for(var t,e=s.length;e;){t=s,s=[];for(var r=-1;++ra;a++)s(a);else i.resolve(o);return i.promise}var p,h=function(t){return"function"==typeof t},f=function(t){return Array.isArray?Array.isArray(t):t instanceof Array},d=function(t){return!(!t||!(typeof t).match(/function|object/))},y=function(t){return t===!1||t===r||null===t},m=function(t,e){return[].slice.call(t,e)},v="undefined",R=typeof TypeError===v?Error:TypeError;if(typeof t!==v&&t.nextTick)p=t.nextTick;else if(typeof MessageChannel!==v){var g=new MessageChannel,j=[];g.port1.onmessage=function(){j.length&&j.shift()()},p=function(t){j.push(t),g.port2.postMessage(0)}}else p=function(t){setTimeout(t,0)};var T=function(t){function e(){if(0!==v){var t,e=g,r=0,o=e.length,i=~v?0:1;for(g=[];o>r;r++)(t=e[r][i])&&t(f)}}function o(t){function r(t){return function(e){return i?void 0:(i=!0,t(e))}}var i=!1;if(v)return this;try{var n=d(t)&&t.then;if(h(n)){if(t===j)throw new R("Promise can't resolve itself");return n.call(t,r(o),r(l)),this}}catch(s){return r(l)(s),this}return m(function(){f=t,v=1,e()}),this}function l(t){return v||m(function(){try{throw t}catch(r){f=r}v=-1,e()}),this}var f,m=(r!==t?t:T.alwaysAsync)?p:function(t){t()},v=0,g=[],j={then:function(t,r){var o=T();return g.push([function(e){try{o.resolve(y(t)?e:h(t)?t(e):T.onlyFuncs?e:t)}catch(r){o.reject(r)}},function(t){if((y(r)||!h(r)&&T.onlyFuncs)&&o.reject(t),r)try{o.resolve(h(r)?r(t):r)}catch(e){o.reject(e)}}]),0!==v&&m(e),o.promise},success:i,error:n,otherwise:n,apply:s,spread:s,ensure:a,nodify:c,rethrow:u,isPending:function(){return!(0!==v)},getStatus:function(){return v}};return j.toSource=j.toString=j.valueOf=function(){return f===r?this:f},{promise:j,resolve:o,fulfill:o,reject:l}};T.deferred=T.defer=T,T.nextTick=p,T.alwaysAsync=!0,T.onlyFuncs=!0,T.resolved=T.fulfilled=function(t){return T(!0).resolve(t).promise},T.rejected=function(t){return T(!0).reject(t).promise},T.wait=function(t){var e=T();return setTimeout(e.resolve,t||0),e.promise},T.delay=function(t,e){var r=T();return setTimeout(function(){try{r.resolve(t.apply(null))}catch(e){r.reject(e)}},e||0),r.promise},T.promisify=function(t){return t&&h(t.then)?t:T.resolved(t)},T.all=function(){return l(arguments,!1)},T.resolveAll=function(){return l(arguments,!0)},T.nodeCapsule=function(t,e){return e||(e=t,t=void 0),function(){var r=T(),o=m(arguments);o.push(function(t,e){t?r.reject(t):r.resolve(arguments.length>2?m(arguments,1):e)});try{e.apply(t,o)}catch(i){r.reject(i)}return r.promise}},typeof window!==v&&(window.D=T),typeof e!==v&&e.exports&&(e.exports=T)}()}).call(this,t("_process"))},{_process:17}],19:[function(t,e,r){function o(){}function i(t){var e={}.toString.call(t);switch(e){case"[object File]":case"[object Blob]":case"[object FormData]":return!0;default:return!1}}function n(){if(v.XMLHttpRequest&&("file:"!=v.location.protocol||!v.ActiveXObject))return new XMLHttpRequest;try{return new ActiveXObject("Microsoft.XMLHTTP")}catch(t){}try{return new ActiveXObject("Msxml2.XMLHTTP.6.0")}catch(t){}try{return new ActiveXObject("Msxml2.XMLHTTP.3.0")}catch(t){}try{return new ActiveXObject("Msxml2.XMLHTTP")}catch(t){}return!1}function s(t){return t===Object(t)}function a(t){if(!s(t))return t;var e=[];for(var r in t)null!=t[r]&&e.push(encodeURIComponent(r)+"="+encodeURIComponent(t[r]));return e.join("&")}function c(t){for(var e,r,o={},i=t.split("&"),n=0,s=i.length;s>n;++n)r=i[n],e=r.split("="),o[decodeURIComponent(e[0])]=decodeURIComponent(e[1]);return o}function u(t){var e,r,o,i,n=t.split(/\r?\n/),s={};n.pop();for(var a=0,c=n.length;c>a;++a)r=n[a],e=r.indexOf(":"),o=r.slice(0,e).toLowerCase(),i=R(r.slice(e+1)),s[o]=i;return s}function l(t){return t.split(/ *; */).shift()}function p(t){return m(t.split(/ *; */),function(t,e){var r=e.split(/ *= */),o=r.shift(),i=r.shift();return o&&i&&(t[o]=i),t},{})}function h(t,e){e=e||{},this.req=t,this.xhr=this.req.xhr,this.text="HEAD"!=this.req.method?this.xhr.responseText:null,this.setStatusProperties(this.xhr.status),this.header=this.headers=u(this.xhr.getAllResponseHeaders()),this.header["content-type"]=this.xhr.getResponseHeader("content-type"),this.setHeaderProperties(this.header),this.body="HEAD"!=this.req.method?this.parseBody(this.text):null}function f(t,e){var r=this;y.call(this),this._query=this._query||[],this.method=t,this.url=e,this.header={},this._header={},this.on("end",function(){var t=null,e=null;try{e=new h(r)}catch(o){t=new Error("Parser is unable to parse the response"),t.parse=!0,t.original=o}r.callback(t,e)})}function d(t,e){return"function"==typeof e?new f("GET",t).end(e):1==arguments.length?new f("GET",t):new f(t,e)}var y=t("emitter"),m=t("reduce"),v="undefined"==typeof window?this:window,R="".trim?function(t){return t.trim()}:function(t){return t.replace(/(^\s*|\s*$)/g,"")};d.serializeObject=a,d.parseString=c,d.types={html:"text/html",json:"application/json",xml:"application/xml",urlencoded:"application/x-www-form-urlencoded",form:"application/x-www-form-urlencoded","form-data":"application/x-www-form-urlencoded"},d.serialize={"application/x-www-form-urlencoded":a,"application/json":JSON.stringify},d.parse={"application/x-www-form-urlencoded":c,"application/json":JSON.parse},h.prototype.get=function(t){return this.header[t.toLowerCase()]},h.prototype.setHeaderProperties=function(t){var e=this.header["content-type"]||"";this.type=l(e);var r=p(e);for(var o in r)this[o]=r[o]},h.prototype.parseBody=function(t){var e=d.parse[this.type];return e&&t&&t.length?e(t):null},h.prototype.setStatusProperties=function(t){var e=t/100|0;this.status=t,this.statusType=e,this.info=1==e,this.ok=2==e,this.clientError=4==e,this.serverError=5==e,this.error=4==e||5==e?this.toError():!1,this.accepted=202==t,this.noContent=204==t||1223==t,this.badRequest=400==t,this.unauthorized=401==t,this.notAcceptable=406==t,this.notFound=404==t,this.forbidden=403==t},h.prototype.toError=function(){var t=this.req,e=t.method,r=t.url,o="cannot "+e+" "+r+" ("+this.status+")",i=new Error(o);return i.status=this.status,i.method=e,i.url=r,i},d.Response=h,y(f.prototype),f.prototype.use=function(t){return t(this),this},f.prototype.timeout=function(t){return this._timeout=t,this},f.prototype.clearTimeout=function(){return this._timeout=0,clearTimeout(this._timer),this},f.prototype.abort=function(){return this.aborted?void 0:(this.aborted=!0,this.xhr.abort(),this.clearTimeout(),this.emit("abort"),this)},f.prototype.set=function(t,e){if(s(t)){for(var r in t)this.set(r,t[r]);return this}return this._header[t.toLowerCase()]=e,this.header[t]=e,this},f.prototype.unset=function(t){return delete this._header[t.toLowerCase()],delete this.header[t],this},f.prototype.getHeader=function(t){return this._header[t.toLowerCase()]},f.prototype.type=function(t){return this.set("Content-Type",d.types[t]||t),this},f.prototype.accept=function(t){return this.set("Accept",d.types[t]||t),this},f.prototype.auth=function(t,e){var r=btoa(t+":"+e);return this.set("Authorization","Basic "+r),this},f.prototype.query=function(t){return"string"!=typeof t&&(t=a(t)),t&&this._query.push(t),this},f.prototype.field=function(t,e){return this._formData||(this._formData=new FormData),this._formData.append(t,e),this},f.prototype.attach=function(t,e,r){return this._formData||(this._formData=new FormData),this._formData.append(t,e,r),this},f.prototype.send=function(t){var e=s(t),r=this.getHeader("Content-Type");if(e&&s(this._data))for(var o in t)this._data[o]=t[o];else"string"==typeof t?(r||this.type("form"),r=this.getHeader("Content-Type"),this._data="application/x-www-form-urlencoded"==r?this._data?this._data+"&"+t:t:(this._data||"")+t):this._data=t;return e?(r||this.type("json"),this):this},f.prototype.callback=function(t,e){var r=this._callback;return this.clearTimeout(),2==r.length?r(t,e):t?this.emit("error",t):void r(e)},f.prototype.crossDomainError=function(){var t=new Error("Origin is not allowed by Access-Control-Allow-Origin");t.crossDomain=!0,this.callback(t)},f.prototype.timeoutError=function(){var t=this._timeout,e=new Error("timeout of "+t+"ms exceeded");e.timeout=t,this.callback(e)},f.prototype.withCredentials=function(){return this._withCredentials=!0,this},f.prototype.end=function(t){var e=this,r=this.xhr=n(),s=this._query.join("&"),a=this._timeout,c=this._formData||this._data;if(this._callback=t||o,r.onreadystatechange=function(){return 4==r.readyState?0==r.status?e.aborted?e.timeoutError():e.crossDomainError():void e.emit("end"):void 0},r.upload&&(r.upload.onprogress=function(t){t.percent=t.loaded/t.total*100,e.emit("progress",t)}),a&&!this._timer&&(this._timer=setTimeout(function(){e.abort()},a)),s&&(s=d.serializeObject(s),this.url+=~this.url.indexOf("?")?"&"+s:"?"+s),r.open(this.method,this.url,!0),this._withCredentials&&(r.withCredentials=!0),"GET"!=this.method&&"HEAD"!=this.method&&"string"!=typeof c&&!i(c)){var u=d.serialize[this.getHeader("Content-Type")];u&&(c=u(c))}for(var l in this.header)null!=this.header[l]&&r.setRequestHeader(l,this.header[l]);return this.emit("request",this),r.send(c),this},d.Request=f,d.get=function(t,e,r){var o=d("GET",t);return"function"==typeof e&&(r=e,e=null),e&&o.query(e),r&&o.end(r),o},d.head=function(t,e,r){var o=d("HEAD",t);return"function"==typeof e&&(r=e,e=null),e&&o.send(e),r&&o.end(r),o},d.del=function(t,e){var r=d("DELETE",t);return e&&r.end(e),r},d.patch=function(t,e,r){var o=d("PATCH",t);return"function"==typeof e&&(r=e,e=null),e&&o.send(e),r&&o.end(r),o},d.post=function(t,e,r){var o=d("POST",t);return"function"==typeof e&&(r=e,e=null),e&&o.send(e),r&&o.end(r),o},d.put=function(t,e,r){var o=d("PUT",t);return"function"==typeof e&&(r=e,e=null),e&&o.send(e),r&&o.end(r),o},e.exports=d},{emitter:20,reduce:21}],20:[function(t,e,r){function o(t){return t?i(t):void 0}function i(t){for(var e in o.prototype)t[e]=o.prototype[e];return t}e.exports=o,o.prototype.on=o.prototype.addEventListener=function(t,e){return this._callbacks=this._callbacks||{},(this._callbacks[t]=this._callbacks[t]||[]).push(e),this},o.prototype.once=function(t,e){function r(){o.off(t,r),e.apply(this,arguments)}var o=this;return this._callbacks=this._callbacks||{},r.fn=e,this.on(t,r),this},o.prototype.off=o.prototype.removeListener=o.prototype.removeAllListeners=o.prototype.removeEventListener=function(t,e){if(this._callbacks=this._callbacks||{},0==arguments.length)return this._callbacks={},this;var r=this._callbacks[t];if(!r)return this;if(1==arguments.length)return delete this._callbacks[t],this;for(var o,i=0;io;++o)r[o].apply(this,e)}return this},o.prototype.listeners=function(t){return this._callbacks=this._callbacks||{},this._callbacks[t]||[]},o.prototype.hasListeners=function(t){return!!this.listeners(t).length}},{}],21:[function(t,e,r){e.exports=function(t,e,r){for(var o=0,i=t.length,n=3==arguments.length?r:t[o++];i>o;)n=e.call(null,n,t[o],++o,t);return n}},{}],22:[function(t,e,r){e.exports={name:"deployr",version:"7.4.1",description:"Simplified JavaScript client library for making requests to DeployR.",keywords:["deployr","deployr.io","ajax","R","api","simple"],author:"DeployR - Revolution Analytics Inc.",contributors:["Sean Wells"],repository:{type:"git",url:"git://github.com/deployr/js-client-library.git"},homepage:"http://deployr.revolutionanalytics.com/documents/dev/client-jsdoc",scripts:{start:"gulp start",build:"gulp"},devDependencies:{browserify:"^9.0.3",gulp:"^3.8.11","gulp-connect":"^2.2.0","gulp-header":"^1.2.2","gulp-jshint":"^1.9.2","gulp-livereload":"^3.8.0","gulp-plumber":"^0.6.6","gulp-rename":"^1.2.2","gulp-uglify":"^1.2.0","gulp-util":"^3.0.4",tape:"^3.5.0","vinyl-source-stream":"^1.0.0"},dependencies:{"d.js":"^0.6.0",superagent:"^0.21.0",ws:"^0.4.32"},main:"deployr.js",engines:{node:">= 0.10.0"},license:"Apache 2.0 License",bugs:{url:"https://github.com/deployr/js-client-library/issues"},directories:{example:"examples",test:"test"}}},{}]},{},[1])(1)}); \ No newline at end of file