From 4d9838b2ee5008d23e00ab67a3ac65bdb46eae90 Mon Sep 17 00:00:00 2001 From: Jason Park <parkjs814@gmail.com> Date: Fri, 10 Jun 2016 02:04:19 +0900 Subject: [PATCH] redirect previously versioned scratch url to new one --- js/index.js | 12 +++++++++++- public/algorithm_visualizer.js | 11 ++++++++++- public/algorithm_visualizer.js.map | 2 +- public/algorithm_visualizer.min.js | 6 +++--- public/algorithm_visualizer.min.js.map | 2 +- 5 files changed, 26 insertions(+), 7 deletions(-) diff --git a/js/index.js b/js/index.js index 01cade6..d64fd1c 100644 --- a/js/index.js +++ b/js/index.js @@ -22,6 +22,8 @@ const { } = require('./utils'); const { + getHashValue, + getParameterByName, getPath } = require('./server/helpers'); @@ -71,5 +73,13 @@ $(() => { app.setWikiList(data.wikis); DOM.showWiki('Tracer'); - }) + }); + + var v1LoadedScratch = getHashValue('scratch-paper'); + var v2LoadedScratch = getParameterByName('scratch-paper'); + var vLoadedScratch = v1LoadedScratch || v2LoadedScratch; + if (vLoadedScratch) { + window.location.href = window.location.protocol + '//' + window.location.host + window.location.pathname + '#path=scratch/' + vLoadedScratch; + } + }); \ No newline at end of file diff --git a/public/algorithm_visualizer.js b/public/algorithm_visualizer.js index b1e9cff..7aa85b2 100644 --- a/public/algorithm_visualizer.js +++ b/public/algorithm_visualizer.js @@ -1170,6 +1170,8 @@ var isScratchPaper = _require.isScratchPaper; var _require2 = require('./server/helpers'); +var getHashValue = _require2.getHashValue; +var getParameterByName = _require2.getParameterByName; var getPath = _require2.getPath; // set global promise error handler @@ -1226,6 +1228,13 @@ $(function () { DOM.showWiki('Tracer'); }); + + var v1LoadedScratch = getHashValue('scratch-paper'); + var v2LoadedScratch = getParameterByName('scratch-paper'); + var vLoadedScratch = v1LoadedScratch || v2LoadedScratch; + if (vLoadedScratch) { + window.location.href = window.location.protocol + '//' + window.location.host + window.location.pathname + '#path=scratch/' + vLoadedScratch; + } }); },{"./app":3,"./app/constructor":2,"./dom":6,"./module":39,"./server":56,"./server/helpers":55,"./utils":70,"rsvp":72}],30:[function(require,module,exports){ @@ -5823,6 +5832,6 @@ process.umask = function() { return 0; }; }).call(this,require('_process'),typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) },{"_process":71}]},{},[29]) -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","js/app/cache.js","js/app/constructor.js","js/app/index.js","js/dom/add_categories.js","js/dom/add_files.js","js/dom/index.js","js/dom/loading_slider.js","js/dom/module_container.js","js/dom/setup/index.js","js/dom/setup/setup_dividers.js","js/dom/setup/setup_document.js","js/dom/setup/setup_files_bar.js","js/dom/setup/setup_interval.js","js/dom/setup/setup_module_container.js","js/dom/setup/setup_side_menu.js","js/dom/setup/setup_tab_container.js","js/dom/setup/setup_top_menu.js","js/dom/setup/setup_window.js","js/dom/show_algorithm.js","js/dom/show_description.js","js/dom/show_first_algorithm.js","js/dom/show_requested_algorithm.js","js/dom/show_wiki.js","js/dom/toast.js","js/dom/top_menu.js","js/editor/create.js","js/editor/executor.js","js/editor/index.js","js/index.js","js/module/data/array1d.js","js/module/data/array2d.js","js/module/data/coordinate_system.js","js/module/data/directed_graph.js","js/module/data/index.js","js/module/data/integer.js","js/module/data/undirected_graph.js","js/module/data/weighted_directed_graph.js","js/module/data/weighted_undirected_graph.js","js/module/index.js","js/module/tracer/array1d.js","js/module/tracer/array2d.js","js/module/tracer/chart.js","js/module/tracer/coordinate_system.js","js/module/tracer/directed_graph.js","js/module/tracer/index.js","js/module/tracer/log.js","js/module/tracer/tracer.js","js/module/tracer/undirected_graph.js","js/module/tracer/weighted_directed_graph.js","js/module/tracer/weighted_undirected_graph.js","js/server/ajax/get.js","js/server/ajax/get_json.js","js/server/ajax/post_json.js","js/server/ajax/request.js","js/server/helpers.js","js/server/index.js","js/server/load_algorithm.js","js/server/load_categories.js","js/server/load_file.js","js/server/load_scratch_paper.js","js/server/load_wiki.js","js/server/load_wiki_list.js","js/server/share_scratch_paper.js","js/tracer_manager/index.js","js/tracer_manager/manager.js","js/tracer_manager/util/from_json.js","js/tracer_manager/util/index.js","js/tracer_manager/util/refine_by_type.js","js/tracer_manager/util/to_json.js","js/utils/index.js","node_modules/process/browser.js","node_modules/rsvp/dist/rsvp.js"],"names":[],"mappings":"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lB,eAAkB,CAAC,QAAD,EAAW,SAAX,EAAyB;AAC/C,MAAI,eAAe,QAAf,CAAJ,EAA8B,OAAO,4BAAP;AAC9B,0BAAsB,QAAtB,SAAkC,SAAlC;AACD,CAHD;;AAKA,IAAM,aAAa,SAAb,UAAa,CAAC,QAAD,EAAW,SAAX,EAAsB,IAAtB,EAA+B;AAChD,MAAI,eAAe,QAAf,CAAJ,EAA8B,OAAO,4BAAP;AAC9B,0BAAsB,QAAtB,SAAkC,SAAlC,SAA+C,IAA/C;AACD,CAHD;;AAKA,OAAO,OAAP,GAAiB;AACf,gCADe;AAEf,kCAFe;AAGf;AAHe,CAAjB;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC9FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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})","'use strict';\n\nconst {\n  extend\n} = $;\n\nconst cache = {\n  lastFileUsed: '',\n  files: {}\n};\n\nconst assertFileName = (name) => {\n  if (!name) {\n    throw 'Missing file name';\n  }\n};\n\n\n/**\n * Global application cache\n */\nmodule.exports = {\n\n  getCachedFile(name) {\n    assertFileName(name);\n    return cache.files[name];\n  },\n\n  updateCachedFile(name, updates) {\n    assertFileName(name);\n    if (!cache.files[name]) {\n      cache.files[name] = {};\n    }\n    extend(cache.files[name], updates);\n  },\n\n  getLastFileUsed() {\n    return cache.lastFileUsed;\n  },\n\n  setLastFileUsed(file) {\n    cache.lastFileUsed = file;\n  }\n};","'use strict';\n\nconst Editor = require('../editor');\nconst TracerManager = require('../tracer_manager');\nconst DOM = require('../dom/setup');\n\nconst {\n  showLoadingSlider,\n  hideLoadingSlider\n} = require('../dom/loading_slider');\n\nconst Cache = require('./cache');\n\nconst state = {\n  isLoading: null,\n  editor: null,\n  tracerManager: null,\n  categories: null,\n  loadedScratch: null,\n  wikiList: null\n};\n\nconst initState = (tracerManager) => {\n  state.isLoading = false;\n  state.editor = new Editor(tracerManager);\n  state.tracerManager = tracerManager;\n  state.categories = {};\n  state.loadedScratch = null;\n  state.wikiList = [];\n};\n\n/**\n * Global application singleton.\n */\nconst App = function () {\n\n  this.getIsLoading = () => {\n    return state.isLoading;\n  };\n\n  this.setIsLoading = (loading) => {\n    state.isLoading = loading;\n    if (loading) {\n      showLoadingSlider();\n    } else {\n      hideLoadingSlider();\n    }\n  };\n\n  this.getEditor = () => {\n    return state.editor;\n  };\n\n  this.getCategories = () => {\n    return state.categories;\n  };\n\n  this.getCategory = (name) => {\n    return state.categories[name];\n  };\n\n  this.setCategories = (categories) => {\n    state.categories = categories;\n  };\n\n  this.updateCategory = (name, updates) => {\n    $.extend(state.categories[name], updates);\n  };\n\n  this.getTracerManager = () => {\n    return state.tracerManager;\n  };\n\n  this.getLoadedScratch = () => {\n    return state.loadedScratch;\n  };\n\n  this.setLoadedScratch = (loadedScratch) => {\n    state.loadedScratch = loadedScratch;\n  };\n\n  this.getWikiList = () => {\n    return state.wikiList;\n  };\n\n  this.setWikiList = (wikiList) => {\n    state.wikiList = wikiList;\n  };\n\n  this.hasWiki = (wiki) => {\n    return ~state.wikiList.indexOf(wiki);\n  };\n\n  const tracerManager = TracerManager.init();\n\n  initState(tracerManager);\n  DOM.setup(tracerManager);\n\n};\n\nApp.prototype = Cache;\n\nmodule.exports = App;\n","'use strict';\n\n/**\n * This is the main application instance.\n * Gets populated on page load. \n */\nmodule.exports = {};","'use strict';\n\nconst app = require('../app');\nconst Server = require('../server');\nconst showAlgorithm = require('./show_algorithm');\n\nconst {\n  each\n} = $;\n\nconst getAlgorithmDOM = (category, subList, algorithm) => {\n  return $('<button class=\"indent\">')\n    .append(subList[algorithm])\n    .attr('data-algorithm', algorithm)\n    .attr('data-category', category)\n    .click(function () {\n      Server.loadAlgorithm(category, algorithm).then((data) => {\n        showAlgorithm(category, algorithm, data);\n      });\n    });\n\n  $('#list').append($algorithm);\n};\n\nconst addCategoryToDOM = (category) => {\n\n  const {\n    name: categoryName,\n    list: categorySubList\n  } = app.getCategory(category);\n\n  const $category = $('<button class=\"category\">')\n    .append('<i class=\"fa fa-fw fa-caret-right\">')\n    .append(categoryName)\n    .attr('data-category', category);\n\n  $category.click(function () {\n    const $self = $(this);\n    $self.toggleClass('open');\n    $self.next().toggleClass('collapse');\n    $self.find('i.fa').toggleClass('fa-caret-right fa-caret-down');\n  });\n\n  const $algorithms = $('<div class=\"algorithms collapse\">');\n  $('#list').append($category).append($algorithms);\n\n  each(categorySubList, (algorithm) => {\n    const $algorithm = getAlgorithmDOM(category, categorySubList, algorithm);\n    $algorithms.append($algorithm);\n  });\n};\n\nmodule.exports = () => {\n  each(app.getCategories(), addCategoryToDOM);\n};\n","'use strict';\n\nconst Server = require('../server');\n\nconst {\n  each\n} = $;\n\nconst addFileToDOM = (category, algorithm, file, explanation) => {\n  var $file = $('<button>')\n    .append(file)\n    .attr('data-file', file)\n    .click(function () {\n      Server.loadFile(category, algorithm, file, explanation);\n      $('.files_bar > .wrapper > button').removeClass('active');\n      $(this).addClass('active');\n    });\n  $('.files_bar > .wrapper').append($file);\n  return $file;\n};\n\nmodule.exports = (category, algorithm, files, requestedFile) => {\n  $('.files_bar > .wrapper').empty();\n\n  each(files, (file, explanation) => {\n    var $file = addFileToDOM(category, algorithm, file, explanation);\n    if (requestedFile && requestedFile == file) $file.click();\n  });\n\n  if (!requestedFile) $('.files_bar > .wrapper > button').first().click();\n  $('.files_bar > .wrapper').scroll();\n};","'use strict';\n\nconst showAlgorithm = require('./show_algorithm');\nconst addCategories = require('./add_categories');\nconst showDescription = require('./show_description');\nconst addFiles = require('./add_files');\nconst showFirstAlgorithm = require('./show_first_algorithm');\nconst showRequestedAlgorithm = require('./show_requested_algorithm');\nconst showWiki = require('./show_wiki');\n\nmodule.exports = {\n  showAlgorithm,\n  addCategories,\n  showDescription,\n  addFiles,\n  showFirstAlgorithm,\n  showRequestedAlgorithm,\n  showWiki\n};","'use strict';\n\nconst showLoadingSlider = () => {\n  $('#loading-slider').removeClass('loaded');\n};\n\nconst hideLoadingSlider = () => {\n  $('#loading-slider').addClass('loaded');\n};\n\nmodule.exports = {\n  showLoadingSlider,\n  hideLoadingSlider\n};\n","'use strict';\n\nconst create = () => {\n  const $container = $('<section class=\"module_wrapper\">');\n  $('.module_container').append($container);\n  return $container;\n};\n\nmodule.exports = {\n  create\n};\n","'use strict';\n\nconst setupDividers = require('./setup_dividers');\nconst setupDocument = require('./setup_document');\nconst setupFilesBar = require('./setup_files_bar');\nconst setupInterval = require('./setup_interval');\nconst setupModuleContainer = require('./setup_module_container');\nconst setupTabContainer = require('./setup_tab_container');\nconst setupSideMenu = require('./setup_side_menu');\nconst setupTopMenu = require('./setup_top_menu');\nconst setupWindow = require('./setup_window');\n\n/**\n * Initializes elements once the app loads in the DOM.\n */\nconst setup = () => {\n\n  $('.btn input').click((e) => {\n    e.stopPropagation();\n  });\n\n  // dividers\n  setupDividers();\n\n  // document\n  setupDocument();\n\n  // files bar\n  setupFilesBar();\n\n  // interval\n  setupInterval();\n\n  // module container\n  setupModuleContainer();\n\n  // tab container\n  setupTabContainer();\n\n  // side menu\n  setupSideMenu();\n\n  // top menu\n  setupTopMenu();\n\n  // window\n  setupWindow();\n\n};\n\nmodule.exports = {\n  setup\n};\n","'use strict';\n\nconst app = require('../../app');\n\nconst addDividerToDom = (divider) => {\n  const [vertical, $first, $second] = divider;\n  const $parent = $first.parent();\n  const thickness = 5;\n\n  const $divider = $('<div class=\"divider\">');\n\n  let dragging = false;\n  if (vertical) {\n    $divider.addClass('vertical');\n\n    let _left = -thickness / 2;\n    $divider.css({\n      top: 0,\n      bottom: 0,\n      left: _left,\n      width: thickness\n    });\n\n    let x;\n    $divider.mousedown(({\n      pageX\n    }) => {\n      x = pageX;\n      dragging = true;\n    });\n\n    $(document).mousemove(({\n      pageX\n    }) => {\n      if (dragging) {\n        const new_left = $second.position().left + pageX - x;\n        let percent = new_left / $parent.width() * 100;\n        percent = Math.min(90, Math.max(10, percent));\n        $first.css('right', (100 - percent) + '%');\n        $second.css('left', percent + '%');\n        x = pageX;\n        app.getTracerManager().resize();\n        $('.files_bar > .wrapper').scroll();\n      }\n    });\n\n    $(document).mouseup(function(e) {\n      dragging = false;\n    });\n\n  } else {\n\n    $divider.addClass('horizontal');\n    const _top = -thickness / 2;\n    $divider.css({\n      top: _top,\n      height: thickness,\n      left: 0,\n      right: 0\n    });\n\n    let y;\n    $divider.mousedown(function({\n      pageY\n    }) {\n      y = pageY;\n      dragging = true;\n    });\n\n    $(document).mousemove(function({\n      pageY\n    }) {\n      if (dragging) {\n        const new_top = $second.position().top + pageY - y;\n        let percent = new_top / $parent.height() * 100;\n        percent = Math.min(90, Math.max(10, percent));\n        $first.css('bottom', (100 - percent) + '%');\n        $second.css('top', percent + '%');\n        y = pageY;\n        app.getTracerManager().resize();\n      }\n    });\n\n    $(document).mouseup(function(e) {\n      dragging = false;\n    });\n  }\n\n  $second.append($divider);\n};\n\nmodule.exports = () => {\n  const dividers = [\n    ['v', $('.sidemenu'), $('.workspace')],\n    ['v', $('.viewer_container'), $('.editor_container')],\n    ['h', $('.data_container'), $('.code_container')]\n  ];\n  for (let i = 0; i < dividers.length; i++) {\n    addDividerToDom(dividers[i]);\n  }\n};","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = () => {\n  $(document).on('click', 'a', function (e) {\n    const href = $(this).attr('href');\n    if (/^(https?:\\/\\/).+/.test(href)) {\n      e.preventDefault();\n      if (!window.open(href, '_blank')) {\n        alert('Please allow popups for this site');\n      }\n    }\n  });\n\n  $(document).mouseup(function (e) {\n    app.getTracerManager().command('mouseup', e);\n  });\n};\n","'use strict';\n\nconst definitelyBigger = (x, y) => x > (y + 2);\n\nmodule.exports = () => {\n\n  $('.files_bar > .btn-left').click(() => {\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const scrollLeft = $wrapper.scrollLeft();\n\n    $($wrapper.children('button').get().reverse()).each(function() {\n      const left = $(this).position().left;\n      const right = left + $(this).outerWidth();\n      if (0 > left) {\n        $wrapper.scrollLeft(scrollLeft + right - clipWidth);\n        return false;\n      }\n    });\n  });\n\n  $('.files_bar > .btn-right').click(() => {\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const scrollLeft = $wrapper.scrollLeft();\n\n    $wrapper.children('button').each(function() {\n      const left = $(this).position().left;\n      const right = left + $(this).outerWidth();\n      if (clipWidth < right) {\n        $wrapper.scrollLeft(scrollLeft + left);\n        return false;\n      }\n    });\n  });\n\n  $('.files_bar > .wrapper').scroll(function() {\n\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const $left = $wrapper.children('button:first-child');\n    const $right = $wrapper.children('button:last-child');\n    const left = $left.position().left;\n    const right = $right.position().left + $right.outerWidth();\n\n    if (definitelyBigger(0, left) && definitelyBigger(clipWidth, right)) {\n      const scrollLeft = $wrapper.scrollLeft();\n      $wrapper.scrollLeft(scrollLeft + clipWidth - right);\n      return;\n    }\n\n    const lefter = definitelyBigger(0, left);\n    const righter = definitelyBigger(right, clipWidth);\n    $wrapper.toggleClass('shadow-left', lefter);\n    $wrapper.toggleClass('shadow-right', righter);\n    $('.files_bar > .btn-left').attr('disabled', !lefter);\n    $('.files_bar > .btn-right').attr('disabled', !righter);\n  });\n}\n","'use strict';\n\nconst app = require('../../app');\nconst Toast = require('../toast');\n\nconst {\n  parseFloat\n} = Number;\n\nconst minInterval = 0.1;\nconst maxInterval = 10;\nconst startInterval = 0.5;\nconst stepInterval = 0.1;\n\nconst normalize = (sec) => {\n\n\n  let interval;\n  let message;\n  if (sec < minInterval) {\n    interval = minInterval;\n    message = `Interval of ${sec} seconds is too low. Setting to min allowed interval of ${minInterval} second(s).`;\n  } else if (sec > maxInterval) {\n    interval = maxInterval;\n    message = `Interval of ${sec} seconds is too high. Setting to max allowed interval of ${maxInterval} second(s).`;\n  } else {\n    interval = sec;\n    message = `Interval has been set to ${sec} second(s).`\n  }\n\n  return [interval, message];\n};\n\nmodule.exports = () => {\n\n  const $interval = $('#interval');\n  $interval.val(startInterval);\n  $interval.attr({\n    max: maxInterval,\n    min: minInterval,\n    step: stepInterval\n  });\n\n  $('#interval').on('change', function() {\n    const tracerManager = app.getTracerManager();\n    const [seconds, message] = normalize(parseFloat($(this).val()));\n\n    $(this).val(seconds);\n    tracerManager.interval = seconds * 1000;\n    Toast.showInfoToast(message);\n  });\n};\n","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = () => {\n\n  const $module_container = $('.module_container');\n\n  $module_container.on('mousedown', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousedown(e);\n  });\n\n  $module_container.on('mousemove', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousemove(e);\n  });\n\n  $module_container.on('DOMMouseScroll mousewheel', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousewheel(e);\n  });\n}\n","'use strict';\n\nconst app = require('../../app');\nconst Server = require('../../server');\nconst showAlgorithm = require('../show_algorithm');\n\nlet sidemenu_percent;\n\nmodule.exports = () => {\n  $('#navigation').click(() => {\n    const $sidemenu = $('.sidemenu');\n    const $workspace = $('.workspace');\n\n    $sidemenu.toggleClass('active');\n    $('.nav-dropdown').toggleClass('fa-caret-down fa-caret-up');\n\n    if ($sidemenu.hasClass('active')) {\n      $sidemenu.css('right', (100 - sidemenu_percent) + '%');\n      $workspace.css('left', sidemenu_percent + '%');\n\n    } else {\n      sidemenu_percent = $workspace.position().left / $('body').width() * 100;\n      $sidemenu.css('right', 0);\n      $workspace.css('left', 0);\n    }\n\n    app.getTracerManager().resize();\n  });\n\n  $('#documentation').click(function () {\n    $('#btn_doc').click();\n  });\n\n  $('#powered-by').click(() => {\n    $('#powered-by-list button').toggleClass('collapse');\n  });\n\n  $('#scratch-paper').click(() => {\n    const category = 'scratch';\n    const algorithm = app.getLoadedScratch();\n    Server.loadAlgorithm(category, algorithm).then((data) => {\n      showAlgorithm(category, algorithm, data);\n    });\n  });\n};","'use strict';\n\nmodule.exports = () => {\n  $('.tab_bar > button').click(function () {\n    $('.tab_bar > button').removeClass('active');\n    $('.tab_container > .tab').removeClass('active');\n    $(this).addClass('active');\n    $($(this).attr('data-target')).addClass('active');\n  });\n};","'use strict';\n\nconst app = require('../../app');\nconst Server = require('../../server');\nconst Toast = require('../toast');\nconst TopMenu = require('../top_menu');\n\nmodule.exports = () => {\n\n  // shared\n  $('#shared').mouseup(function () {\n    $(this).select();\n  });\n\n  $('#btn_share').click(function () {\n\n    const $icon = $(this).find('.fa-share');\n    $icon.addClass('fa-spin fa-spin-faster');\n\n    Server.shareScratchPaper().then((url) => {\n      $icon.removeClass('fa-spin fa-spin-faster');\n      $('#shared').removeClass('collapse');\n      $('#shared').val(url);\n      Toast.showInfoToast('Shareable link is created.');\n    });\n  });\n\n  // control\n\n  const $btnRun = $('#btn_run');\n  const $btnTrace = $('#btn_trace');\n  const $btnPause = $('#btn_pause');\n  const $btnPrev = $('#btn_prev');\n  const $btnNext = $('#btn_next');\n\n  // initially, control buttons are disabled\n  TopMenu.disableFlowControl();\n\n  $btnRun.click(() => {\n    $btnTrace.click();\n    $btnPause.removeClass('active');\n    $btnRun.addClass('active');\n    TopMenu.enableFlowControl();\n    var err = app.getEditor().execute();\n    if (err) {\n      console.error(err);\n      Toast.showErrorToast(err);\n      TopMenu.resetTopMenuButtons();\n    }\n  });\n\n  $btnPause.click(() => {\n    $btnRun.toggleClass('active');\n    $btnPause.toggleClass('active');\n    if (app.getTracerManager().isPause()) {\n      app.getTracerManager().resumeStep();\n    } else {\n      app.getTracerManager().pauseStep();\n    }\n  });\n\n  $btnPrev.click(() => {\n    $btnRun.removeClass('active');\n    $btnPause.addClass('active');\n    app.getTracerManager().pauseStep();\n    app.getTracerManager().prevStep();\n  });\n\n  $btnNext.click(() => {\n    $btnRun.removeClass('active');\n    $btnPause.addClass('active');\n    app.getTracerManager().pauseStep();\n    app.getTracerManager().nextStep();\n  });\n\n};\n","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = function() {\n  $(window).resize(function() {\n    app.getTracerManager().resize();\n  });\n};\n","'use strict';\n\nconst app = require('../app');\n\nconst {\n  isScratchPaper\n} = require('../utils');\n\nconst showDescription = require('./show_description');\nconst addFiles = require('./add_files');\n\nmodule.exports = (category, algorithm, data, requestedFile) => {\n  let $menu;\n  let category_name;\n  let algorithm_name;\n\n  if (isScratchPaper(category)) {\n    $menu = $('#scratch-paper');\n    category_name = 'Scratch Paper';\n    algorithm_name = algorithm ? 'Shared' : 'Temporary';\n  } else {\n    $menu = $(`[data-category=\"${category}\"][data-algorithm=\"${algorithm}\"]`);\n    const categoryObj = app.getCategory(category);\n    category_name = categoryObj.name;\n    algorithm_name = categoryObj.list[algorithm];\n  }\n\n  $('.sidemenu button').removeClass('active');\n  $menu.addClass('active');\n\n  $('#category').html(category_name);\n  $('#algorithm').html(algorithm_name);\n  $('#tab_desc > .wrapper').empty();\n  $('.files_bar > .wrapper').empty();\n  $('#explanation').html('');\n\n  app.setLastFileUsed(null);\n  app.getEditor().clearContent();\n\n  const {\n    files\n  } = data;\n\n  delete data.files;\n\n  showDescription(data);\n  addFiles(category, algorithm, files, requestedFile);\n};","'use strict';\n\nconst {\n  isArray\n} = Array;\n\nconst {\n  each\n} = $;\n\nmodule.exports = (data) => {\n  const $container = $('#tab_desc > .wrapper');\n  $container.empty();\n\n  each(data, (key, value) => {\n\n    if (key) {\n      $container.append($('<h3>').html(key));\n    }\n\n    if (typeof value === 'string') {\n      $container.append($('<p>').html(value));\n\n    } else if (isArray(value)) {\n\n      const $ul = $('<ul class=\"applications\">');\n      $container.append($ul);\n\n      value.forEach((li) => {\n        $ul.append($('<li>').html(li));\n      });\n\n    } else if (typeof value === 'object') {\n\n      const $ul = $('<ul class=\"complexities\">');\n      $container.append($ul);\n\n      each(value, (prop) => {\n        const $wrapper = $('<div class=\"complexity\">');\n        const $type = $('<span class=\"complexity-type\">').html(`${prop}: `);\n        const $value = $('<span class=\"complexity-value\">').html(`${value[prop]}`);\n\n        $wrapper.append($type).append($value);\n\n        $ul.append($('<li>').append($wrapper));\n      });\n    }\n  });\n};\n","'use strict';\n\n// click the first algorithm in the first category\nmodule.exports = () => {\n  $('#list .category').first().click();\n  $('#list .category + .algorithms > .indent').first().click();\n};\n","'use strict';\n\nconst Server = require('../server');\nconst showAlgorithm = require('./show_algorithm');\n\nmodule.exports = (category, algorithm, file) => {\n  $(`.category[data-category=\"${category}\"]`).click();\n  Server.loadAlgorithm(category, algorithm).then((data) => {\n    showAlgorithm(category, algorithm, data, file);\n  });\n};\n","'use strict';\n\nconst app = require('../app');\nconst Server = require('../server');\nconst converter = new showdown.Converter({tables: true});\n\nmodule.exports = (wiki) => {\n  Server.loadWiki(wiki).then((data) => {\n    $('#tab_doc > .wrapper').html(converter.makeHtml(`#${wiki}\\n${data}`));\n    $('#tab_doc').scrollTop(0);\n    $('#tab_doc > .wrapper a').click(function (e) {\n      const href = $(this).attr('href');\n      if (app.hasWiki(href)) {\n        e.preventDefault();\n        module.exports(href);\n      }\n    });\n  });\n};","'use strict';\n\nconst showToast = (data, type) => {\n  const $toast = $(`<div class=\"toast ${type}\">`).append(data);\n\n  $('.toast_container').append($toast);\n  setTimeout(() => {\n    $toast.fadeOut(() => {\n      $toast.remove();\n    });\n  }, 3000);\n};\n\nconst showErrorToast = (err) => {\n  showToast(err, 'error');\n};\n\nconst showInfoToast = (err) => {\n  showToast(err, 'info');\n};\n\nmodule.exports = {\n  showErrorToast,\n  showInfoToast\n};","'use strict';\n\nconst app = require('../app');\n\nconst flowControlBtns = [ $('#btn_pause'), $('#btn_prev'), $('#btn_next') ];\nconst setFlowControlState = (isDisabled) => {\n  flowControlBtns.forEach($btn => $btn.attr('disabled', isDisabled));\n};\n\nconst enableFlowControl = () => {\n  setFlowControlState(false);\n};\n\nconst disableFlowControl = () => {\n  setFlowControlState(true);\n};\n\nconst resetTopMenuButtons = () => {\n  $('.top-menu-buttons button').removeClass('active');\n  disableFlowControl();\n  app.getEditor().unhighlightLine();\n};\n\nconst setInterval = (val) => {\n  $('#interval').val(interval);\n};\n\nconst activateBtnPause = () => {\n  $('#btn_pause').addClass('active');\n};\n\nconst deactivateBtnPause = () => {\n  $('#btn_pause').removeClass('active');\n};\n\nmodule.exports = {\n  enableFlowControl,\n  disableFlowControl,\n  resetTopMenuButtons,\n  setInterval,\n  activateBtnPause,\n  deactivateBtnPause\n};\n","'use strict';\n\nmodule.exports = function(id) {\n  const editor = ace.edit(id);\n\n  editor.setOptions({\n    enableBasicAutocompletion: true,\n    enableSnippets: true,\n    enableLiveAutocompletion: true\n  });\n\n  editor.setTheme('ace/theme/tomorrow_night_eighties');\n  editor.session.setMode('ace/mode/javascript');\n  editor.$blockScrolling = Infinity;\n\n  return editor;\n};","'use strict';\n\nconst execute = (tracerManager, code, dataLines) => {\n  // all modules available to eval are obtained from window\n  try {\n    tracerManager.deallocateAll();\n    const lines = code.split('\\n');\n    const newLines = [];\n    lines.forEach((line, i) => {\n      newLines.push(line.replace(/(.+\\. *_wait *)(\\( *\\))/g, `$1(${i - dataLines})`));\n    });\n    eval(newLines.join('\\n'));\n    tracerManager.visualize();\n  } catch (err) {\n    return err;\n  } finally {\n    tracerManager.removeUnallocated();\n  }\n};\n\nconst executeData = (tracerManager, algoData) => {\n  return execute(tracerManager, algoData);\n};\n\nconst executeDataAndCode = (tracerManager, algoData, algoCode) => {\n  const dataLines = algoData.split('\\n').length;\n  return execute(tracerManager, `${algoData}\\n${algoCode}`, dataLines);\n};\n\nmodule.exports = {\n  executeData,\n  executeDataAndCode\n};","'use strict';\n\nconst app = require('../app');\nconst createEditor = require('./create');\nconst Executor = require('./executor');\nconst TopMenu = require('../dom/top_menu');\n\nfunction Editor(tracerManager) {\n  if (!tracerManager) {\n    throw 'Cannot create Editor. Missing the tracerManager';\n  }\n\n  ace.require('ace/ext/language_tools');\n  const Range = ace.require(\"ace/range\").Range;\n\n  this.dataEditor = createEditor('data');\n  this.codeEditor = createEditor('code');\n\n  // Setting data\n\n  this.setData = (data) => {\n    this.dataEditor.setValue(data, -1);\n  };\n\n  this.setCode = (code) => {\n    this.codeEditor.setValue(code, -1);\n  };\n\n  this.setContent = (({\n    data,\n    code\n  }) => {\n    this.setData(data);\n    this.setCode(code);\n  });\n\n  // Clearing data\n\n  this.clearData = () => {\n    this.dataEditor.setValue('');\n  };\n\n  this.clearCode = () => {\n    this.codeEditor.setValue('');\n  };\n\n  this.clearContent = () => {\n    this.clearData();\n    this.clearCode();\n  };\n\n  this.execute = () => {\n    const data = this.dataEditor.getValue();\n    const code = this.codeEditor.getValue();\n    return Executor.executeDataAndCode(tracerManager, data, code);\n  };\n\n  this.highlightLine = (lineNumber) => {\n    const session = this.codeEditor.getSession();\n    if (this.marker) session.removeMarker(this.marker);\n    this.marker = session.addMarker(new Range(lineNumber, 0, lineNumber, Infinity), \"executing\", \"line\", true);\n  };\n\n  this.unhighlightLine = () => {\n    const session = this.codeEditor.getSession();\n    if (this.marker) session.removeMarker(this.marker);\n  };\n\n  // listeners\n\n  this.dataEditor.on('change', () => {\n    const data = this.dataEditor.getValue();\n    const lastFileUsed = app.getLastFileUsed();\n    if (lastFileUsed) {\n      app.updateCachedFile(lastFileUsed, {\n        data\n      });\n    }\n    Executor.executeData(tracerManager, data);\n    TopMenu.resetTopMenuButtons();\n  });\n\n  this.codeEditor.on('change', () => {\n    const code = this.codeEditor.getValue();\n    const lastFileUsed = app.getLastFileUsed();\n    if (lastFileUsed) {\n      app.updateCachedFile(lastFileUsed, {\n        code\n      });\n    }\n    tracerManager.reset();\n    TopMenu.resetTopMenuButtons();\n  });\n}\n\nmodule.exports = Editor;","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('./app');\nconst AppConstructor = require('./app/constructor');\nconst DOM = require('./dom');\nconst Server = require('./server');\n\nconst modules = require('./module');\n\nconst {\n  extend\n} = $;\n\n$.ajaxSetup({\n  cache: false,\n  dataType: 'text'\n});\n\nconst {\n  isScratchPaper\n} = require('./utils');\n\nconst {\n  getPath\n} = require('./server/helpers');\n\n// set global promise error handler\nRSVP.on('error', function (reason) {\n  console.assert(false, reason);\n});\n\n$(() => {\n\n  // initialize the application and attach in to the instance module\n  const appConstructor = new AppConstructor();\n  extend(true, app, appConstructor);\n\n  // load modules to the global scope so they can be evaled\n  extend(true, window, modules);\n\n  Server.loadCategories().then((data) => {\n    app.setCategories(data);\n    DOM.addCategories();\n\n    // determine if the app is loading a pre-existing scratch-pad\n    // or the home page\n    const {\n      category,\n      algorithm,\n      file\n    } = getPath();\n    if (isScratchPaper(category)) {\n      if (algorithm) {\n        Server.loadScratchPaper(algorithm).then(({category, algorithm, data}) => {\n          DOM.showAlgorithm(category, algorithm, data);\n        });\n      } else {\n        Server.loadAlgorithm(category).then((data) => {\n          DOM.showAlgorithm(category, null, data);\n        });\n      }\n    } else if (category && algorithm) {\n      DOM.showRequestedAlgorithm(category, algorithm, file);\n    } else {\n      DOM.showFirstAlgorithm();\n    }\n  });\n\n  Server.loadWikiList().then((data) => {\n    app.setWikiList(data.wikis);\n\n    DOM.showWiki('Tracer');\n  })\n});","'use strict';\n\nconst Array2D = require('./array2d');\n\nconst random = (N, min, max) => {\n  return Array2D.random(1, N, min, max)[0];\n};\n\nconst randomSorted = (N, min, max)=> {\n  return Array2D.randomSorted(1, N, min, max)[0];\n};\n\nmodule.exports = {\n  random,\n  randomSorted\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, M, min, max) => {\n  if (!N) N = 10;\n  if (!M) M = 10;\n  if (min === undefined) min = 1;\n  if (max === undefined) max = 9;\n  var D = [];\n  for (var i = 0; i < N; i++) {\n    D.push([]);\n    for (var j = 0; j < M; j++) {\n      D[i].push(Integer.random(min, max));\n    }\n  }\n  return D;\n};\n\nconst randomSorted = (N, M, min, max) => {\n  return random(N, M, min, max).map(function (arr) {\n    return arr.sort(function (a, b) {\n      return a - b;\n    });\n  });\n};\n\nmodule.exports = {\n  random,\n  randomSorted\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, min, max) => {\n  if (!N) N = 7;\n  if (!min) min = 1;\n  if (!max) max = 10;\n  var C = new Array(N);\n  for (var i = 0; i < N; i++) C[i] = new Array(2);\n  for (var i = 0; i < N; i++)\n    for (var j = 0; j < C[i].length; j++)\n      C[i][j] = Integer.random(min, max);\n  return C;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst random = (N, ratio) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) {\n    G[i] = new Array(N);\n    for (var j = 0; j < N; j++) {\n      if (i != j) {\n        G[i][j] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\nconst Array1D = require('./array1d');\nconst Array2D = require('./array2d');\nconst CoordinateSystem = require('./coordinate_system');\nconst DirectedGraph = require('./directed_graph');\nconst UndirectedGraph = require('./undirected_graph');\nconst WeightedDirectedGraph = require('./weighted_directed_graph');\nconst WeightedUndirectedGraph = require('./weighted_undirected_graph');\n\nmodule.exports = {\n  Integer,\n  Array1D,\n  Array2D,\n  CoordinateSystem,\n  DirectedGraph,\n  UndirectedGraph,\n  WeightedDirectedGraph,\n  WeightedUndirectedGraph\n};","'use strict';\n\nconst random = (min, max) => {\n  return (Math.random() * (max - min + 1) | 0) + min;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst random = (N, ratio) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) G[i] = new Array(N);\n  for (var i = 0; i < N; i++) {\n    for (var j = 0; j < N; j++) {\n      if (i > j) {\n        G[i][j] = G[j][i] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, ratio, min, max) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  if (!min) min = 1;\n  if (!max) max = 5;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) {\n    G[i] = new Array(N);\n    for (var j = 0; j < N; j++) {\n      if (i != j && (Math.random() * (1 / ratio) | 0) == 0) {\n        G[i][j] = Integer.random(min, max);\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, ratio, min, max) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  if (!min) min = 1;\n  if (!max) max = 5;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) G[i] = new Array(N);\n  for (var i = 0; i < N; i++) {\n    for (var j = 0; j < N; j++) {\n      if (i > j && (Math.random() * (1 / ratio) | 0) == 0) {\n        G[i][j] = G[j][i] = Integer.random(min, max);\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nvar tracers = require('./tracer');\nvar datas = require('./data');\n\nconst {\n  extend\n} = $;\n\nmodule.exports = extend(true, {}, tracers, datas);","'use strict';\n\nconst Array2DTracer = require('./array2d');\n\nclass Array1DTracer extends Array2DTracer {\n  static getClassName() {\n    return 'Array1DTracer';\n  }\n\n  constructor(name) {\n    super(name);\n  }\n\n  _notify(idx, v) {\n    super._notify(0, idx, v);\n    return this;\n  }\n\n  _denotify(idx) {\n    super._denotify(0, idx);\n    return this;\n  }\n\n  _select(s, e) {\n    if (e === undefined) {\n      super._select(0, s);\n    } else {\n      super._selectRow(0, s, e);\n    }\n    return this;\n  }\n\n  _deselect(s, e) {\n    if (e === undefined) {\n      super._deselect(0, s);\n    } else {\n      super._deselectRow(0, s, e);\n    }\n    return this;\n  }\n\n  processStep(step, options) {\n    super.processStep(step, options);\n    if (this.chartTracer) {\n      const newStep = $.extend(true, {}, step);\n      newStep.capsule = this.chartTracer.capsule;\n      newStep.s = newStep.sy;\n      newStep.e = newStep.ey;\n      if (newStep.s === undefined) newStep.s = newStep.y;\n      delete newStep.x;\n      delete newStep.y;\n      delete newStep.sx;\n      delete newStep.sy;\n      delete newStep.ex;\n      delete newStep.ey;\n      this.chartTracer.processStep(newStep, options);\n    }\n  }\n\n  setData(D) {\n    return super.setData([D]);\n  }\n}\n\nmodule.exports = Array1DTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass Array2DTracer extends Tracer {\n  static getClassName() {\n    return 'Array2DTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.colorClass = {\n      selected: 'selected',\n      notified: 'notified'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  _notify(x, y, v) {\n    this.manager.pushStep(this.capsule, {\n      type: 'notify',\n      x: x,\n      y: y,\n      v: v\n    });\n    return this;\n  }\n\n  _denotify(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'denotify',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _select(sx, sy, ex, ey) {\n    this.pushSelectingStep('select', null, arguments);\n    return this;\n  }\n\n  _selectRow(x, sy, ey) {\n    this.pushSelectingStep('select', 'row', arguments);\n    return this;\n  }\n\n  _selectCol(y, sx, ex) {\n    this.pushSelectingStep('select', 'col', arguments);\n    return this;\n  }\n\n  _deselect(sx, sy, ex, ey) {\n    this.pushSelectingStep('deselect', null, arguments);\n    return this;\n  }\n\n  _deselectRow(x, sy, ey) {\n    this.pushSelectingStep('deselect', 'row', arguments);\n    return this;\n  }\n\n  _deselectCol(y, sx, ex) {\n    this.pushSelectingStep('deselect', 'col', arguments);\n    return this;\n  }\n\n  _separate(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'separate',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _separateRow(x) {\n    this._separate(x, -1);\n    return this;\n  }\n\n  _separateCol(y) {\n    this._separate(-1, y);\n    return this;\n  }\n\n  _deseparate(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'deseparate',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _deseparateRow(x) {\n    this._deseparate(x, -1);\n    return this;\n  }\n\n  _deseparateCol(y) {\n    this._deseparate(-1, y);\n    return this;\n  }\n\n  pushSelectingStep() {\n    var args = Array.prototype.slice.call(arguments);\n    var type = args.shift();\n    var mode = args.shift();\n    args = Array.prototype.slice.call(args.shift());\n    var coord;\n    switch (mode) {\n      case 'row':\n        coord = {\n          x: args[0],\n          sy: args[1],\n          ey: args[2]\n        };\n        break;\n      case 'col':\n        coord = {\n          y: args[0],\n          sx: args[1],\n          ex: args[2]\n        };\n        break;\n      default:\n        if (args[2] === undefined && args[3] === undefined) {\n          coord = {\n            x: args[0],\n            y: args[1]\n          };\n        } else {\n          coord = {\n            sx: args[0],\n            sy: args[1],\n            ex: args[2],\n            ey: args[3]\n          };\n        }\n    }\n    var step = {\n      type: type\n    };\n    $.extend(step, coord);\n    this.manager.pushStep(this.capsule, step);\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'notify':\n        if (step.v !== undefined) {\n          var $row = this.$table.find('.mtbl-row').eq(step.x);\n          var $col = $row.find('.mtbl-col').eq(step.y);\n          $col.text(refineByType(step.v));\n        }\n      case 'denotify':\n      case 'select':\n      case 'deselect':\n        var colorClass = step.type == 'select' || step.type == 'deselect' ? this.colorClass.selected : this.colorClass.notified;\n        var addClass = step.type == 'select' || step.type == 'notify';\n        var sx = step.sx;\n        var sy = step.sy;\n        var ex = step.ex;\n        var ey = step.ey;\n        if (sx === undefined) sx = step.x;\n        if (sy === undefined) sy = step.y;\n        if (ex === undefined) ex = step.x;\n        if (ey === undefined) ey = step.y;\n        this.paintColor(sx, sy, ex, ey, colorClass, addClass);\n        break;\n      case 'separate':\n        this.deseparate(step.x, step.y);\n        this.separate(step.x, step.y);\n        break;\n      case 'deseparate':\n        this.deseparate(step.x, step.y);\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  setData(D) {\n    this.viewX = this.viewY = 0;\n    this.paddingH = 6;\n    this.paddingV = 3;\n    this.fontSize = 16;\n\n    if (super.setData.apply(this, arguments)) {\n      this.$table.find('.mtbl-row').each(function (i) {\n        $(this).find('.mtbl-col').each(function (j) {\n          $(this).text(refineByType(D[i][j]));\n        });\n      });\n      return true;\n    }\n\n    this.$table.empty();\n    for (var i = 0; i < D.length; i++) {\n      var $row = $('<div class=\"mtbl-row\">');\n      this.$table.append($row);\n      for (var j = 0; j < D[i].length; j++) {\n        var $col = $('<div class=\"mtbl-col\">')\n          .css(this.getCellCss())\n          .text(refineByType(D[i][j]));\n        $row.append($col);\n      }\n    }\n    this.resize();\n\n    return false;\n  }\n\n  resize() {\n    super.resize();\n\n    this.refresh();\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearColor();\n    this.deseparateAll();\n  }\n\n  getCellCss() {\n    return {\n      padding: this.paddingV.toFixed(1) + 'px ' + this.paddingH.toFixed(1) + 'px',\n      'font-size': this.fontSize.toFixed(1) + 'px'\n    };\n  }\n\n  refresh() {\n    super.refresh();\n\n    var $parent = this.$table.parent();\n    var top = $parent.height() / 2 - this.$table.height() / 2 + this.viewY;\n    var left = $parent.width() / 2 - this.$table.width() / 2 + this.viewX;\n    this.$table.css('margin-top', top);\n    this.$table.css('margin-left', left);\n  }\n\n  mousedown(e) {\n    super.mousedown(e);\n\n    this.dragX = e.pageX;\n    this.dragY = e.pageY;\n    this.dragging = true;\n  }\n\n  mousemove(e) {\n    super.mousemove(e);\n\n    if (this.dragging) {\n      this.viewX += e.pageX - this.dragX;\n      this.viewY += e.pageY - this.dragY;\n      this.dragX = e.pageX;\n      this.dragY = e.pageY;\n      this.refresh();\n    }\n  }\n\n  mouseup(e) {\n    super.mouseup(e);\n\n    this.dragging = false;\n  }\n\n  mousewheel(e) {\n    super.mousewheel(e);\n\n    e.preventDefault();\n    e = e.originalEvent;\n    var delta = (e.wheelDelta !== undefined && e.wheelDelta) ||\n      (e.detail !== undefined && -e.detail);\n    var weight = 1.01;\n    var ratio = delta > 0 ? 1 / weight : weight;\n    if (this.fontSize < 4 && ratio < 1) return;\n    if (this.fontSize > 40 && ratio > 1) return;\n    this.paddingV *= ratio;\n    this.paddingH *= ratio;\n    this.fontSize *= ratio;\n    this.$table.find('.mtbl-col').css(this.getCellCss());\n    this.refresh();\n  }\n\n  paintColor(sx, sy, ex, ey, colorClass, addClass) {\n    for (var i = sx; i <= ex; i++) {\n      var $row = this.$table.find('.mtbl-row').eq(i);\n      for (var j = sy; j <= ey; j++) {\n        var $col = $row.find('.mtbl-col').eq(j);\n        if (addClass) $col.addClass(colorClass);\n        else $col.removeClass(colorClass);\n      }\n    }\n  }\n\n  clearColor() {\n    this.$table.find('.mtbl-col').removeClass(Object.keys(this.colorClass).join(' '));\n  }\n\n  separate(x, y) {\n    this.$table.find('.mtbl-row').each(function (i) {\n      var $row = $(this);\n      if (i == x) {\n        $row.after($('<div class=\"mtbl-empty-row\">').attr('data-row', i))\n      }\n      $row.find('.mtbl-col').each(function (j) {\n        var $col = $(this);\n        if (j == y) {\n          $col.after($('<div class=\"mtbl-empty-col\">').attr('data-col', j));\n        }\n      });\n    });\n  }\n\n  deseparate(x, y) {\n    this.$table.find('[data-row=' + x + ']').remove();\n    this.$table.find('[data-col=' + y + ']').remove();\n  }\n\n  deseparateAll() {\n    this.$table.find('.mtbl-empty-row, .mtbl-empty-col').remove();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$table = tracer.capsule.$table = $('<div class=\"mtbl-table\">');\n  tracer.$container.append(tracer.$table);\n};\n\nmodule.exports = Array2DTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nclass ChartTracer extends Tracer {\n  static getClassName() {\n    return 'ChartTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.color = {\n      selected: 'rgb(0, 0, 255)',\n      notified: 'rgb(255, 0, 0)',\n      default: 'rgb(136, 136, 136)'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (super.setData.apply(this, arguments)) {\n      this.chart.config.data.datasets[0].data = C;\n      this.chart.update();\n      return true;\n    }\n\n    var color = [];\n    for (var i = 0; i < C.length; i++) color.push(this.color.default);\n    this.chart.config.data = {\n      labels: C.map(String),\n      datasets: [{\n        backgroundColor: color,\n        data: C\n      }]\n    };\n    this.chart.update();\n  }\n\n  _notify(s, v) {\n    this.manager.pushStep(this.capsule, {\n      type: 'notify',\n      s: s,\n      v: v\n    });\n    return this;\n  }\n\n  _denotify(s) {\n    this.manager.pushStep(this.capsule, {\n      type: 'denotify',\n      s: s\n    });\n    return this;\n  }\n\n  _select(s, e) {\n    this.manager.pushStep(this.capsule, {\n      type: 'select',\n      s: s,\n      e: e\n    });\n    return this;\n  }\n\n  _deselect(s, e) {\n    this.manager.pushStep(this.capsule, {\n      type: 'deselect',\n      s: s,\n      e: e\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'notify':\n        if (step.v !== undefined) {\n          this.chart.config.data.datasets[0].data[step.s] = step.v;\n          this.chart.config.data.labels[step.s] = step.v.toString();\n        }\n      case 'denotify':\n      case 'select':\n      case 'deselect':\n        let color = step.type == 'notify' ? this.color.notified : step.type == 'select' ? this.color.selected : this.color.default;\n        if (step.e !== undefined)\n          for (var i = step.s; i <= step.e; i++)\n            this.chart.config.data.datasets[0].backgroundColor[i] = color;\n        else\n          this.chart.config.data.datasets[0].backgroundColor[step.s] = color;\n        this.chart.update();\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  resize() {\n    super.resize();\n\n    this.chart.resize();\n  }\n\n  clear() {\n    super.clear();\n\n    const data = this.chart.config.data;\n    if (data.datasets.length) {\n      const backgroundColor = data.datasets[0].backgroundColor;\n      for (let i = 0; i < backgroundColor.length; i++) {\n        backgroundColor[i] = this.color.default;\n      }\n      this.chart.update();\n    }\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$wrapper = tracer.capsule.$wrapper = $('<canvas class=\"mchrt-chart\">');\n  tracer.$container.append(tracer.$wrapper);\n  tracer.chart = tracer.capsule.chart = new Chart(tracer.$wrapper, {\n    type: 'bar',\n    data: {\n      labels: [],\n      datasets: []\n    },\n    options: {\n      scales: {\n        yAxes: [{\n          ticks: {\n            beginAtZero: true\n          }\n        }]\n      },\n      animation: false,\n      legend: false,\n      responsive: true,\n      maintainAspectRatio: false\n    }\n  });\n};\n\nmodule.exports = ChartTracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nclass CoordinateSystemTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'CoordinateSystemTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (Tracer.prototype.setData.apply(this, arguments)) return true;\n\n    this.graph.clear();\n    var nodes = [];\n    var edges = [];\n    for (var i = 0; i < C.length; i++)\n      nodes.push({\n        id: this.n(i),\n        x: C[i][0],\n        y: C[i][1],\n        label: '' + i,\n        size: 1,\n        color: this.color.default\n      });\n    this.graph.read({\n      nodes: nodes,\n      edges: edges\n    });\n    this.s.camera.goTo({\n      x: 0,\n      y: 0,\n      angle: 0,\n      ratio: 1\n    });\n    this.refresh();\n\n    return false;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          if (this.graph.edges(edgeId)) {\n            var edge = this.graph.edges(edgeId);\n            edge.color = color;\n            this.graph.dropEdge(edgeId).addEdge(edge);\n          } else {\n            this.graph.addEdge({\n              id: this.e(step.target, step.source),\n              source: this.n(step.source),\n              target: this.n(step.target),\n              color: color,\n              size: 1\n            });\n          }\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  e(v1, v2) {\n    if (v1 > v2) {\n      var temp = v1;\n      v1 = v2;\n      v2 = temp;\n    }\n    return 'e' + v1 + '_' + v2;\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#0ff';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n\n  drawEdge(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(\n      source[prefix + 'x'],\n      source[prefix + 'y']\n    );\n    context.lineTo(\n      target[prefix + 'x'],\n      target[prefix + 'y']\n    );\n    context.stroke();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = CoordinateSystemTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass DirectedGraphTracer extends Tracer {\n  static getClassName() {\n    return 'DirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.color = {\n      selected: '#0f0',\n      visited: '#f00',\n      left: '#000',\n      default: '#888'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  _setTreeData(G, root) {\n    this.manager.pushStep(this.capsule, {\n      type: 'setTreeData',\n      arguments: arguments\n    });\n    return this;\n  }\n\n  _visit(target, source) {\n    this.manager.pushStep(this.capsule, {\n      type: 'visit',\n      target: target,\n      source: source\n    });\n    return this;\n  }\n\n  _leave(target, source) {\n    this.manager.pushStep(this.capsule, {\n      type: 'leave',\n      target: target,\n      source: source\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'setTreeData':\n        this.setTreeData.apply(this, step.arguments);\n        break;\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          var edge = this.graph.edges(edgeId);\n          edge.color = color;\n          this.graph.dropEdge(edgeId).addEdge(edge);\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  setTreeData(G, root, undirected) {\n    var tracer = this;\n\n    root = root || 0;\n    var maxDepth = -1;\n\n    var chk = new Array(G.length);\n    var getDepth = function (node, depth) {\n      if (chk[node]) throw \"the given graph is not a tree because it forms a circuit\";\n      chk[node] = true;\n      if (maxDepth < depth) maxDepth = depth;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) getDepth(i, depth + 1);\n      }\n    };\n    getDepth(root, 1);\n\n    if (this.setData(G, undirected)) return true;\n\n    var place = function (node, x, y) {\n      var temp = tracer.graph.nodes(tracer.n(node));\n      temp.x = x;\n      temp.y = y;\n    };\n\n    var wgap = 1 / (maxDepth - 1);\n    var dfs = function (node, depth, top, bottom) {\n      place(node, top + bottom, depth * wgap);\n      var children = 0;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) children++;\n      }\n      var vgap = (bottom - top) / children;\n      var cnt = 0;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) dfs(i, depth + 1, top + vgap * cnt, top + vgap * ++cnt);\n      }\n    };\n    dfs(root, 0, 0, 1);\n\n    this.refresh();\n  }\n\n  setData(G, undirected) {\n    if (super.setData.apply(this, arguments)) return true;\n\n    this.graph.clear();\n    const nodes = [];\n    const edges = [];\n    const unitAngle = 2 * Math.PI / G.length;\n    let currentAngle = 0;\n    for (let i = 0; i < G.length; i++) {\n      currentAngle += unitAngle;\n      nodes.push({\n        id: this.n(i),\n        label: '' + i,\n        x: .5 + Math.sin(currentAngle) / 2,\n        y: .5 + Math.cos(currentAngle) / 2,\n        size: 1,\n        color: this.color.default,\n        weight: 0\n      });\n\n      if (undirected) {\n        for (let j = 0; j <= i; j++) {\n          const value = G[i][j] || G[j][i];\n          if (value) {\n            edges.push({\n              id: this.e(i, j),\n              source: this.n(i),\n              target: this.n(j),\n              color: this.color.default,\n              size: 1,\n              weight: refineByType(value)\n            });\n          }\n        }\n      } else {\n        for (let j = 0; j < G[i].length; j++) {\n          if (G[i][j]) {\n            edges.push({\n              id: this.e(i, j),\n              source: this.n(i),\n              target: this.n(j),\n              color: this.color.default,\n              size: 1,\n              weight: refineByType(G[i][j])\n            });\n          }\n        }\n      }\n    }\n\n    this.graph.read({\n      nodes: nodes,\n      edges: edges\n    });\n    this.s.camera.goTo({\n      x: 0,\n      y: 0,\n      angle: 0,\n      ratio: 1\n    });\n    this.refresh();\n\n    return false;\n  }\n\n  resize() {\n    super.resize();\n\n    this.s.renderers[0].resize();\n    this.refresh();\n  }\n\n  refresh() {\n    super.refresh();\n\n    this.s.refresh();\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearGraphColor();\n    this.refresh();\n  }\n\n  clearGraphColor() {\n    var tracer = this;\n\n    this.graph.nodes().forEach(function (node) {\n      node.color = tracer.color.default;\n    });\n    this.graph.edges().forEach(function (edge) {\n      edge.color = tracer.color.default;\n    });\n  }\n\n  n(v) {\n    return 'n' + v;\n  }\n\n  e(v1, v2) {\n    return 'e' + v1 + '_' + v2;\n  }\n\n  getColor(edge, source, target, settings) {\n    var color = edge.color,\n      edgeColor = settings('edgeColor'),\n      defaultNodeColor = settings('defaultNodeColor'),\n      defaultEdgeColor = settings('defaultEdgeColor');\n    if (!color)\n      switch (edgeColor) {\n        case 'source':\n          color = source.color || defaultNodeColor;\n          break;\n        case 'target':\n          color = target.color || defaultNodeColor;\n          break;\n        default:\n          color = defaultEdgeColor;\n          break;\n      }\n\n    return color;\n  }\n\n  drawLabel(node, context, settings) {\n    var fontSize,\n      prefix = settings('prefix') || '',\n      size = node[prefix + 'size'];\n\n    if (size < settings('labelThreshold'))\n      return;\n\n    if (!node.label || typeof node.label !== 'string')\n      return;\n\n    fontSize = (settings('labelSize') === 'fixed') ?\n      settings('defaultLabelSize') :\n    settings('labelSizeRatio') * size;\n\n    context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') +\n      fontSize + 'px ' + settings('font');\n    context.fillStyle = (settings('labelColor') === 'node') ?\n      (node.color || settings('defaultNodeColor')) :\n      settings('defaultLabelColor');\n\n    context.textAlign = 'center';\n    context.fillText(\n      node.label,\n      Math.round(node[prefix + 'x']),\n      Math.round(node[prefix + 'y'] + fontSize / 3)\n    );\n  }\n\n  drawArrow(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1,\n      tSize = target[prefix + 'size'],\n      sX = source[prefix + 'x'],\n      sY = source[prefix + 'y'],\n      tX = target[prefix + 'x'],\n      tY = target[prefix + 'y'],\n      angle = Math.atan2(tY - sY, tX - sX),\n      dist = 3;\n    sX += Math.sin(angle) * dist;\n    tX += Math.sin(angle) * dist;\n    sY += -Math.cos(angle) * dist;\n    tY += -Math.cos(angle) * dist;\n    var aSize = Math.max(size * 2.5, settings('minArrowSize')),\n      d = Math.sqrt(Math.pow(tX - sX, 2) + Math.pow(tY - sY, 2)),\n      aX = sX + (tX - sX) * (d - aSize - tSize) / d,\n      aY = sY + (tY - sY) * (d - aSize - tSize) / d,\n      vX = (tX - sX) * aSize / d,\n      vY = (tY - sY) * aSize / d;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(sX, sY);\n    context.lineTo(\n      aX,\n      aY\n    );\n    context.stroke();\n\n    context.fillStyle = color;\n    context.beginPath();\n    context.moveTo(aX + vX, aY + vY);\n    context.lineTo(aX + vY * 0.6, aY - vX * 0.6);\n    context.lineTo(aX - vY * 0.6, aY + vX * 0.6);\n    context.lineTo(aX + vX, aY + vY);\n    context.closePath();\n    context.fill();\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawArrow(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#ff0';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawArrow(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s = tracer.capsule.s = new sigma({\n    renderer: {\n      container: tracer.$container[0],\n      type: 'canvas'\n    },\n    settings: {\n      minArrowSize: 8,\n      defaultEdgeType: 'arrow',\n      maxEdgeSize: 2.5,\n      labelThreshold: 4,\n      font: 'Roboto',\n      defaultLabelColor: '#fff',\n      zoomMin: 0.6,\n      zoomMax: 1.2,\n      skipErrors: true,\n      minNodeSize: .5,\n      maxNodeSize: 12,\n      labelSize: 'proportional',\n      labelSizeRatio: 1.3,\n      funcLabelsDef(node, context, settings) {\n        tracer.drawLabel(node, context, settings);\n      },\n      funcHoversDef(node, context, settings, next) {\n        tracer.drawOnHover(node, context, settings, next);\n      },\n      funcEdgesArrow(edge, source, target, context, settings) {\n        var color = tracer.getColor(edge, source, target, settings);\n        tracer.drawArrow(edge, source, target, color, context, settings);\n      }\n    }\n  });\n  sigma.plugins.dragNodes(tracer.s, tracer.s.renderers[0]);\n  tracer.graph = tracer.capsule.graph = tracer.s.graph;\n};\n\nsigma.canvas.labels.def = function (node, context, settings) {\n  var func = settings('funcLabelsDef');\n  if (func) {\n    func(node, context, settings);\n  }\n};\nsigma.canvas.hovers.def = function (node, context, settings) {\n  var func = settings('funcHoversDef');\n  if (func) {\n    func(node, context, settings);\n  }\n};\nsigma.canvas.edges.def = function (edge, source, target, context, settings) {\n  var func = settings('funcEdgesDef');\n  if (func) {\n    func(edge, source, target, context, settings);\n  }\n};\nsigma.canvas.edges.arrow = function (edge, source, target, context, settings) {\n  var func = settings('funcEdgesArrow');\n  if (func) {\n    func(edge, source, target, context, settings);\n  }\n};\n\nmodule.exports = DirectedGraphTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\nconst LogTracer = require('./log');\nconst Array1DTracer = require('./array1d');\nconst Array2DTracer = require('./array2d');\nconst ChartTracer = require('./chart');\nconst CoordinateSystemTracer = require('./coordinate_system');\nconst DirectedGraphTracer = require('./directed_graph');\nconst UndirectedGraphTracer = require('./undirected_graph');\nconst WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nconst WeightedUndirectedGraphTracer = require('./weighted_undirected_graph');\n\nmodule.exports = {\n  Tracer,\n  LogTracer,\n  Array1DTracer,\n  Array2DTracer,\n  ChartTracer,\n  CoordinateSystemTracer,\n  DirectedGraphTracer,\n  UndirectedGraphTracer,\n  WeightedDirectedGraphTracer,\n  WeightedUndirectedGraphTracer\n};","'use strict';\n\nconst Tracer = require('./tracer');\n\nclass LogTracer extends Tracer {\n  static getClassName() {\n    return 'LogTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  _print(msg) {\n    this.manager.pushStep(this.capsule, {\n      type: 'print',\n      msg: msg\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'print':\n        this.print(step.msg);\n        break;\n    }\n  }\n\n  refresh() {\n    this.scrollToEnd(Math.min(50, this.interval));\n  }\n\n  clear() {\n    super.clear();\n\n    this.$wrapper.empty();\n  }\n\n  print(message) {\n    this.$wrapper.append($('<span>').append(message + '<br/>'));\n  }\n\n  scrollToEnd(duration) {\n    this.$container.animate({\n      scrollTop: this.$container[0].scrollHeight\n    }, duration);\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$wrapper = tracer.capsule.$wrapper = $('<div class=\"wrapper\">');\n  tracer.$container.append(tracer.$wrapper);\n};\n\nmodule.exports = LogTracer;\n","'use strict';\n\nconst app = require('../../app');\n\nconst {\n  toJSON,\n  fromJSON\n} = require('../../tracer_manager/util/index');\n\nclass Tracer {\n  static getClassName() {\n    return 'Tracer';\n  }\n\n  constructor(name) {\n    this.module = this.constructor;\n\n    this.manager = app.getTracerManager();\n    this.capsule = this.manager.allocate(this);\n    $.extend(this, this.capsule);\n\n    this.setName(name);\n  }\n\n  _setData(...args) {\n    this.manager.pushStep(this.capsule, {\n      type: 'setData',\n      args: toJSON(args)\n    });\n    return this;\n  }\n\n  _clear() {\n    this.manager.pushStep(this.capsule, {\n      type: 'clear'\n    });\n    return this;\n  }\n\n  _wait(line) {\n    this.manager.newStep(line);\n    return this;\n  }\n\n  processStep(step, options) {\n    const {\n      type,\n      args\n    } = step;\n\n    switch (type) {\n      case 'setData':\n        this.setData(...fromJSON(args));\n        break;\n      case 'clear':\n        this.clear();\n        break;\n    }\n  }\n\n  setName(name) {\n    let $name;\n    if (this.isNew) {\n      $name = $('<span class=\"name\">');\n      this.$container.append($name);\n    } else {\n      $name = this.$container.find('span.name');\n    }\n    $name.text(name || this.defaultName);\n  }\n\n  setData() {\n    const data = toJSON(arguments);\n    if (!this.isNew && this.lastData === data) {\n      return true;\n    }\n    this.lastData = this.capsule.lastData = data;\n    return false;\n  }\n\n  resize() {\n  }\n\n  refresh() {\n  }\n\n  clear() {\n  }\n\n  attach(tracer) {\n    switch (tracer.module) {\n      case LogTracer:\n        this.logTracer = tracer;\n        break;\n      case ChartTracer:\n        this.chartTracer = tracer;\n        break;\n    }\n    return this;\n  }\n\n  mousedown(e) {\n  }\n\n  mousemove(e) {\n  }\n\n  mouseup(e) {\n  }\n\n  mousewheel(e) {\n  }\n}\n\nmodule.exports = Tracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nclass UndirectedGraphTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'UndirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  setTreeData(G, root) {\n    return super.setTreeData(G, root, true);\n  }\n\n  setData(G) {\n    return super.setData(G, true);\n  }\n\n  e(v1, v2) {\n    if (v1 > v2) {\n      var temp = v1;\n      v1 = v2;\n      v2 = temp;\n    }\n    return 'e' + v1 + '_' + v2;\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#0ff';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n\n  drawEdge(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(\n      source[prefix + 'x'],\n      source[prefix + 'y']\n    );\n    context.lineTo(\n      target[prefix + 'x'],\n      target[prefix + 'y']\n    );\n    context.stroke();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = UndirectedGraphTracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass WeightedDirectedGraphTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'WeightedDirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  _weight(target, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'weight',\n      target: target,\n      weight: weight\n    });\n    return this;\n  }\n\n  _visit(target, source, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'visit',\n      target: target,\n      source: source,\n      weight: weight\n    });\n    return this;\n  }\n\n  _leave(target, source, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'leave',\n      target: target,\n      source: source,\n      weight: weight\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'weight':\n        var targetNode = this.graph.nodes(this.n(step.target));\n        if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n        break;\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? step.weight === undefined ? this.color.selected : this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          var edge = this.graph.edges(edgeId);\n          edge.color = color;\n          this.graph.dropEdge(edgeId).addEdge(edge);\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearWeights();\n  }\n\n  clearWeights() {\n    this.graph.nodes().forEach(function (node) {\n      node.weight = 0;\n    });\n  }\n\n  drawEdgeWeight(edge, source, target, color, context, settings) {\n    if (source == target)\n      return;\n\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    if (size < settings('edgeLabelThreshold'))\n      return;\n\n    if (0 === settings('edgeLabelSizePowRatio'))\n      throw '\"edgeLabelSizePowRatio\" must not be 0.';\n\n    var fontSize,\n      x = (source[prefix + 'x'] + target[prefix + 'x']) / 2,\n      y = (source[prefix + 'y'] + target[prefix + 'y']) / 2,\n      dX = target[prefix + 'x'] - source[prefix + 'x'],\n      dY = target[prefix + 'y'] - source[prefix + 'y'],\n      angle = Math.atan2(dY, dX);\n\n    fontSize = (settings('edgeLabelSize') === 'fixed') ?\n      settings('defaultEdgeLabelSize') :\n    settings('defaultEdgeLabelSize') *\n    size *\n    Math.pow(size, -1 / settings('edgeLabelSizePowRatio'));\n\n    context.save();\n\n    if (edge.active) {\n      context.font = [\n        settings('activeFontStyle'),\n        fontSize + 'px',\n        settings('activeFont') || settings('font')\n      ].join(' ');\n\n      context.fillStyle = color;\n    } else {\n      context.font = [\n        settings('fontStyle'),\n        fontSize + 'px',\n        settings('font')\n      ].join(' ');\n\n      context.fillStyle = color;\n    }\n\n    context.textAlign = 'center';\n    context.textBaseline = 'alphabetic';\n\n    context.translate(x, y);\n    context.rotate(angle);\n    context.fillText(\n      edge.weight,\n      0,\n      (-size / 2) - 3\n    );\n\n    context.restore();\n  }\n\n  drawNodeWeight(node, context, settings) {\n    var fontSize,\n      prefix = settings('prefix') || '',\n      size = node[prefix + 'size'];\n\n    if (size < settings('labelThreshold'))\n      return;\n\n    fontSize = (settings('labelSize') === 'fixed') ?\n      settings('defaultLabelSize') :\n    settings('labelSizeRatio') * size;\n\n    context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') +\n      fontSize + 'px ' + settings('font');\n    context.fillStyle = (settings('labelColor') === 'node') ?\n      (node.color || settings('defaultNodeColor')) :\n      settings('defaultLabelColor');\n\n    context.textAlign = 'left';\n    context.fillText(\n      node.weight,\n      Math.round(node[prefix + 'x'] + size * 1.5),\n      Math.round(node[prefix + 'y'] + fontSize / 3)\n    );\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    edgeLabelSize: 'proportional',\n    defaultEdgeLabelSize: 20,\n    edgeLabelSizePowRatio: 0.8,\n    funcLabelsDef(node, context, settings) {\n      tracer.drawNodeWeight(node, context, settings);\n      tracer.drawLabel(node, context, settings);\n    },\n    funcHoversDef(node, context, settings) {\n      tracer.drawOnHover(node, context, settings, tracer.drawEdgeWeight);\n    },\n    funcEdgesArrow(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawArrow(edge, source, target, color, context, settings);\n      tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = WeightedDirectedGraphTracer;\n","'use strict';\n\nconst WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nconst UndirectedGraphTracer = require('./undirected_graph');\n\nclass WeightedUndirectedGraphTracer extends WeightedDirectedGraphTracer {\n  static getClassName() {\n    return 'WeightedUndirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.e = UndirectedGraphTracer.prototype.e;\n    this.drawOnHover = UndirectedGraphTracer.prototype.drawOnHover;\n    this.drawEdge = UndirectedGraphTracer.prototype.drawEdge;\n\n    if (this.isNew) initView(this);\n  }\n\n  setTreeData(G, root) {\n    return super.setTreeData(G, root, true);\n  }\n\n  setData(G) {\n    return super.setData(G, true);\n  }\n\n  drawEdgeWeight(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '';\n    if (source[prefix + 'x'] > target[prefix + 'x']) {\n      var temp = source;\n      source = target;\n      target = temp;\n    }\n    WeightedDirectedGraphTracer.prototype.drawEdgeWeight.call(this, edge, source, target, color, context, settings);\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n      tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = WeightedUndirectedGraphTracer;\n","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = (url) => {\n  return request(url, {\n    type: 'GET'\n  });\n};","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = function(url) {\n  return request(url, {\n    dataType: 'json',\n    type: 'GET'\n  });\n};","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = function(url, data) {\n  return request(url, {\n    dataType: 'json',\n    type: 'POST',\n    data: JSON.stringify(data),\n  });\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../../app');\n\nconst {\n  ajax,\n  extend\n} = $;\n\nconst defaults = {\n\n};\n\nmodule.exports = function(url, options = {}) {\n  app.setIsLoading(true);\n\n  return new RSVP.Promise((resolve, reject) => {\n    const callbacks = {\n      success(response) {\n        app.setIsLoading(false);\n        resolve(response);\n      },\n      error(reason) {\n        app.setIsLoading(false);\n        reject(reason);\n      }\n    };\n\n    const opts = extend({}, defaults, options, callbacks, {\n      url\n    });\n\n    ajax(opts);\n  });\n};","'use strict';\n\nconst app = require('../app');\nconst Toast = require('../dom/toast');\n\nconst checkLoading = () => {\n  if (app.getIsLoading()) {\n    Toast.showErrorToast('Wait until it completes loading of previous file.');\n    return true;\n  }\n  return false;\n};\n\nconst getParameterByName = (name) => {\n  const url = window.location.href;\n  const regex = new RegExp(`[?&]${name}(=([^&#]*)|&|#|$)`);\n\n  const results = regex.exec(url);\n\n  if (!results || results.length !== 3) {\n    return null;\n  }\n\n  const [, , id] = results;\n\n  return id;\n};\n\nconst getHashValue = (key)=> {\n  if (!key) return null;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n  for (let i = 0; i < params.length; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      return pair[1];\n    }\n  }\n  return null;\n};\n\nconst setHashValue = (key, value)=> {\n  if (!key || !value) return;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n\n  let found = false;\n  for (let i = 0; i < params.length && !found; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      pair[1] = value;\n      params[i] = pair.join('=');\n      found = true;\n    }\n  }\n  if (!found) {\n    params.push([key, value].join('='));\n  }\n\n  const newHash = params.join('&');\n  window.location.hash = `#${newHash}`;\n};\n\nconst removeHashValue = (key) => {\n  if (!key) return;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n\n  for (let i = 0; i < params.length; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      params.splice(i, 1);\n      break;\n    }\n  }\n\n  const newHash = params.join('&');\n  window.location.hash = `#${newHash}`;\n};\n\nconst setPath = (category, algorithm, file) => {\n  const path = category ? category + (algorithm ? `/${algorithm}` + (file ? `/${file}` : '') : '') : '';\n  setHashValue('path', path);\n};\n\nconst getPath = () => {\n  const hash = getHashValue('path');\n  if (hash) {\n    const [ category, algorithm, file ] = hash.split('/');\n    return { category, algorithm, file };\n  } else {\n    return false;\n  }\n};\n\nmodule.exports = {\n  checkLoading,\n  getParameterByName,\n  getHashValue,\n  setHashValue,\n  removeHashValue,\n  setPath,\n  getPath\n};\n","'use strict';\n\nconst loadAlgorithm = require('./load_algorithm');\nconst loadCategories = require('./load_categories');\nconst loadFile = require('./load_file');\nconst loadScratchPaper = require('./load_scratch_paper');\nconst shareScratchPaper = require('./share_scratch_paper');\nconst loadWikiList = require('./load_wiki_list');\nconst loadWiki = require('./load_wiki');\n\nmodule.exports = {\n  loadAlgorithm,\n  loadCategories,\n  loadFile,\n  loadScratchPaper,\n  shareScratchPaper,\n  loadWikiList,\n  loadWiki\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nconst {\n  getAlgorithmDir\n} = require('../utils');\n\nmodule.exports = (category, algorithm) => {\n  const dir = getAlgorithmDir(category, algorithm);\n  return getJSON(`${dir}desc.json`);\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nmodule.exports = () => {\n  return getJSON('./algorithm/category.json');\n};","'use strict';\n\nconst RSVP = require('rsvp');\n\nconst app = require('../app');\n\nconst {\n  getFileDir,\n  isScratchPaper\n} = require('../utils');\n\nconst {\n  checkLoading,\n  setPath\n} = require('./helpers');\n\nconst get = require('./ajax/get');\n\nconst loadDataAndCode = (dir) => {\n  return RSVP.hash({\n    data: get(`${dir}data.js`),\n    code: get(`${dir}code.js`)\n  });\n};\n\nconst loadFileAndUpdateContent = (dir) => {\n  app.getEditor().clearContent();\n\n  return loadDataAndCode(dir).then((content) => {\n    app.updateCachedFile(dir, content);\n    app.getEditor().setContent(content);\n  });\n};\n\nconst cachedContentExists = (cachedFile) => {\n  return cachedFile &&\n    cachedFile.data !== undefined &&\n    cachedFile.code !== undefined;\n};\n\nmodule.exports = (category, algorithm, file, explanation) => {\n  return new RSVP.Promise((resolve, reject) => {\n    if (checkLoading()) {\n      reject();\n    } else {\n      if (isScratchPaper(category)) {\n        setPath(category, app.getLoadedScratch());\n      } else {\n        setPath(category, algorithm, file);\n      }\n      $('#explanation').html(explanation);\n\n      let dir = getFileDir(category, algorithm, file);\n      app.setLastFileUsed(dir);\n      const cachedFile = app.getCachedFile(dir);\n\n      if (cachedContentExists(cachedFile)) {\n        app.getEditor().setContent(cachedFile);\n        resolve();\n      } else {\n        loadFileAndUpdateContent(dir).then(resolve, reject);\n      }\n    }\n  });\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../app');\n\nconst {\n  getFileDir\n} = require('../utils');\n\nconst getJSON = require('./ajax/get_json');\nconst loadAlgorithm = require('./load_algorithm');\n\nconst extractGistCode = (files, name) => files[`${name}.js`].content;\n\nmodule.exports = (gistID) => {\n  return new RSVP.Promise((resolve, reject) => {\n    app.setLoadedScratch(gistID);\n\n    getJSON(`https://api.github.com/gists/${gistID}`).then(({\n      files\n    }) => {\n\n      const category = 'scratch';\n      const algorithm = gistID;\n\n      loadAlgorithm(category, algorithm).then((data) => {\n\n        const algoData = extractGistCode(files, 'data');\n        const algoCode = extractGistCode(files, 'code');\n\n        // update scratch paper algo code with the loaded gist code\n        const dir = getFileDir(category, algorithm, 'scratch_paper');\n        app.updateCachedFile(dir, {\n          data: algoData,\n          code: algoCode,\n          'CREDIT.md': 'Shared by an anonymous user from http://parkjs814.github.io/AlgorithmVisualizer'\n        });\n\n        resolve({\n          category,\n          algorithm,\n          data\n        });\n      });\n    });\n  });\n\n};","'use strict';\n\nconst get = require('./ajax/get');\n\nmodule.exports = (wiki) => {\n  return get(`./AlgorithmVisualizer.wiki/${wiki}.md`);\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nmodule.exports = () => {\n  return getJSON('./wiki.json');\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../app');\n\nconst postJSON = require('./ajax/post_json');\n\nconst {\n  setPath\n} = require('./helpers');\n\nmodule.exports = () => {\n  return new RSVP.Promise((resolve, reject) => {\n\n    const {\n      dataEditor,\n      codeEditor\n    } = app.getEditor();\n\n    const gist = {\n      'description': 'temp',\n      'public': true,\n      'files': {\n        'data.js': {\n          'content': dataEditor.getValue()\n        },\n        'code.js': {\n          'content': codeEditor.getValue()\n        }\n      }\n    };\n\n    postJSON('https://api.github.com/gists', gist).then(({\n      id\n    }) => {\n      app.setLoadedScratch(id);\n      setPath('scratch', id);\n      const {\n        href\n      } = location;\n      $('#algorithm').html('Shared');\n      resolve(href);\n    });\n  });\n};","'use strict';\n\nconst TracerManager = require('./manager');\nconst Tracer = require('../module/tracer/tracer');\n\nmodule.exports = {\n\n  init() {\n    const tm = new TracerManager();\n    Tracer.prototype.manager = tm;\n    return tm;\n  }\n\n};","'use strict';\n\nconst app = require('../app');\nconst ModuleContainer = require('../dom/module_container');\nconst TopMenu = require('../dom/top_menu');\n\nconst {\n  each,\n  extend,\n  grep\n} = $;\n\nconst stepLimit = 1e6;\n\nconst TracerManager = function () {\n  this.timer = null;\n  this.pause = false;\n  this.capsules = [];\n  this.interval = 500;\n};\n\nTracerManager.prototype = {\n\n  add(tracer) {\n\n    const $container = ModuleContainer.create();\n\n    const capsule = {\n      module: tracer.module,\n      tracer,\n      allocated: true,\n      defaultName: null,\n      $container,\n      isNew: true\n    };\n\n    this.capsules.push(capsule);\n    return capsule;\n  },\n\n  allocate(newTracer) {\n    let selectedCapsule = null;\n    let count = 0;\n\n    each(this.capsules, (i, capsule) => {\n      if (capsule.module === newTracer.module) {\n        count++;\n        if (!capsule.allocated) {\n          capsule.tracer = newTracer;\n          capsule.allocated = true;\n          capsule.isNew = false;\n          selectedCapsule = capsule;\n          return false;\n        }\n      }\n    });\n\n    if (selectedCapsule === null) {\n      count++;\n      selectedCapsule = this.add(newTracer);\n    }\n\n    const className = newTracer.module.getClassName();\n    selectedCapsule.defaultName = `${className} ${count}`;\n    selectedCapsule.order = this.order++;\n    return selectedCapsule;\n  },\n\n  deallocateAll() {\n    this.order = 0;\n    this.reset();\n    each(this.capsules, (i, capsule) => {\n      capsule.allocated = false;\n    });\n  },\n\n  removeUnallocated() {\n    let changed = false;\n\n    this.capsules = grep(this.capsules, (capsule) => {\n      let removed = !capsule.allocated;\n\n      if (capsule.isNew || removed) {\n        changed = true;\n      }\n      if (removed) {\n        capsule.$container.remove();\n      }\n\n      return !removed;\n    });\n\n    if (changed) {\n      this.place();\n    }\n  },\n\n  place() {\n    const {\n      capsules\n    } = this;\n\n    each(capsules, (i, capsule) => {\n      let width = 100;\n      let height = (100 / capsules.length);\n      let top = height * capsule.order;\n\n      capsule.$container.css({\n        top: `${top}%`,\n        width: `${width}%`,\n        height: `${height}%`\n      });\n\n      capsule.tracer.resize();\n    });\n  },\n\n  resize() {\n    this.command('resize');\n  },\n\n  isPause() {\n    return this.pause;\n  },\n\n  setInterval(interval) {\n    TopMenu.setInterval(interval);\n  },\n\n  reset() {\n    this.traces = [];\n    this.traceIndex = -1;\n    this.stepCnt = 0;\n    if (this.timer) {\n      clearTimeout(this.timer);\n    }\n    this.command('clear');\n  },\n\n  pushStep(capsule, step) {\n    if (this.stepCnt++ > stepLimit) throw \"Tracer's stack overflow\";\n    let len = this.traces.length;\n    if (len == 0) len += this.newStep();\n    const last = this.traces[len - 1];\n    last.push(extend(step, {\n      capsule\n    }));\n  },\n\n  newStep(line = -1) {\n    let len = this.traces.length;\n    if (len > 0 && ~line) {\n      this.traces[len - 1].push(line);\n    }\n    return this.traces.push([]);\n  },\n\n  pauseStep() {\n    if (this.traceIndex < 0) return;\n    this.pause = true;\n    if (this.timer) {\n      clearTimeout(this.timer);\n    }\n    TopMenu.activateBtnPause();\n  },\n\n  resumeStep() {\n    this.pause = false;\n    this.step(this.traceIndex + 1);\n    TopMenu.deactivateBtnPause();\n  },\n\n  step(i, options = {}) {\n    const tracer = this;\n\n    if (isNaN(i) || i >= this.traces.length || i < 0) return;\n\n    this.traceIndex = i;\n    const trace = this.traces[i];\n    trace.forEach((step) => {\n      if (typeof step === 'number') {\n        app.getEditor().highlightLine(step);\n        return;\n      }\n      step.capsule.tracer.processStep(step, options);\n    });\n\n    if (!options.virtual) {\n      this.command('refresh');\n    }\n\n    if (this.pause) return;\n\n    this.timer = setTimeout(() => {\n      if (!tracer.nextStep(options)) {\n        TopMenu.resetTopMenuButtons();\n      }\n    }, this.interval);\n  },\n\n  prevStep(options = {}) {\n    this.command('clear');\n\n    const finalIndex = this.traceIndex - 1;\n    if (finalIndex < 0) {\n      this.traceIndex = -1;\n      this.command('refresh');\n      return false;\n    }\n\n    for (let i = 0; i < finalIndex; i++) {\n      this.step(i, extend(options, {\n        virtual: true\n      }));\n    }\n\n    this.step(finalIndex);\n    return true;\n  },\n\n  nextStep(options = {}) {\n    const finalIndex = this.traceIndex + 1;\n    if (finalIndex >= this.traces.length) {\n      this.traceIndex = this.traces.length - 1;\n      return false;\n    }\n\n    this.step(finalIndex, options);\n    return true;\n  },\n\n  visualize() {\n    this.traceIndex = -1;\n    this.resumeStep();\n  },\n\n  command(...args) {\n    const functionName = args.shift();\n    each(this.capsules, (i, capsule) => {\n      if (capsule.allocated) {\n        capsule.tracer.module.prototype[functionName].apply(capsule.tracer, args);\n      }\n    });\n  },\n\n  findOwner(container) {\n    let selectedCapsule = null;\n    each(this.capsules, (i, capsule) => {\n      if (capsule.$container[0] === container) {\n        selectedCapsule = capsule;\n        return false;\n      }\n    });\n    return selectedCapsule.tracer;\n  }\n};\n\nmodule.exports = TracerManager;\n","'use strict';\n\nconst {\n  parse\n} = JSON;\n\nconst fromJSON = (obj) => {\n  return parse(obj, (key, value) => {\n    return value === 'Infinity' ? Infinity : value;\n  });\n};\n\nmodule.exports = fromJSON;\n","'use strict';\n\nconst toJSON = require('./to_json');\nconst fromJSON = require('./from_json');\nconst refineByType = require('./refine_by_type');\n\nmodule.exports = {\n  toJSON,\n  fromJSON,\n  refineByType\n};\n","'use strict';\n\nconst refineByType = (item) => {\n  switch (typeof(item)) {\n    case 'number':\n      return refineNumber(item);\n    case 'boolean':\n      return refineBoolean(item);\n    default:\n      return refineString(item);\n  }\n};\n\nconst refineString = (str) => {\n  return str === '' ? ' ' : str;\n};\n\nconst refineNumber = (num) => {\n  return num === Infinity ? '∞' : num;\n};\n\nconst refineBoolean = (bool) => {\n  return bool ? 'T' : 'F';\n};\n\nmodule.exports = refineByType;\n","'use strict';\n\nconst {\n  stringify\n} = JSON;\n\nconst toJSON = (obj) => {\n  return stringify(obj, (key, value) => {\n    return value === Infinity ? 'Infinity' : value;\n  });\n};\n\nmodule.exports = toJSON;\n","'use strict';\n\nconst isScratchPaper = (category, algorithm) => {\n  return category == 'scratch';\n};\n\nconst getAlgorithmDir = (category, algorithm) => {\n  if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n  return `./algorithm/${category}/${algorithm}/`;\n};\n\nconst getFileDir = (category, algorithm, file) => {\n  if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n  return `./algorithm/${category}/${algorithm}/${file}/`;\n};\n\nmodule.exports = {\n  isScratchPaper,\n  getAlgorithmDir,\n  getFileDir\n};","// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = setTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    clearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        setTimeout(drainQueue, 0);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\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\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","/*!\n * @overview RSVP - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors\n * @license   Licensed under MIT license\n *            See https://raw.githubusercontent.com/tildeio/rsvp.js/master/LICENSE\n * @version   3.2.1\n */\n\n(function() {\n    \"use strict\";\n    function lib$rsvp$utils$$objectOrFunction(x) {\n      return typeof x === 'function' || (typeof x === 'object' && x !== null);\n    }\n\n    function lib$rsvp$utils$$isFunction(x) {\n      return typeof x === 'function';\n    }\n\n    function lib$rsvp$utils$$isMaybeThenable(x) {\n      return typeof x === 'object' && x !== null;\n    }\n\n    var lib$rsvp$utils$$_isArray;\n    if (!Array.isArray) {\n      lib$rsvp$utils$$_isArray = function (x) {\n        return Object.prototype.toString.call(x) === '[object Array]';\n      };\n    } else {\n      lib$rsvp$utils$$_isArray = Array.isArray;\n    }\n\n    var lib$rsvp$utils$$isArray = lib$rsvp$utils$$_isArray;\n\n    var lib$rsvp$utils$$now = Date.now || function() { return new Date().getTime(); };\n\n    function lib$rsvp$utils$$F() { }\n\n    var lib$rsvp$utils$$o_create = (Object.create || function (o) {\n      if (arguments.length > 1) {\n        throw new Error('Second argument not supported');\n      }\n      if (typeof o !== 'object') {\n        throw new TypeError('Argument must be an object');\n      }\n      lib$rsvp$utils$$F.prototype = o;\n      return new lib$rsvp$utils$$F();\n    });\n    function lib$rsvp$events$$indexOf(callbacks, callback) {\n      for (var i=0, l=callbacks.length; i<l; i++) {\n        if (callbacks[i] === callback) { return i; }\n      }\n\n      return -1;\n    }\n\n    function lib$rsvp$events$$callbacksFor(object) {\n      var callbacks = object._promiseCallbacks;\n\n      if (!callbacks) {\n        callbacks = object._promiseCallbacks = {};\n      }\n\n      return callbacks;\n    }\n\n    var lib$rsvp$events$$default = {\n\n      /**\n        `RSVP.EventTarget.mixin` extends an object with EventTarget methods. For\n        Example:\n\n        ```javascript\n        var object = {};\n\n        RSVP.EventTarget.mixin(object);\n\n        object.on('finished', function(event) {\n          // handle event\n        });\n\n        object.trigger('finished', { detail: value });\n        ```\n\n        `EventTarget.mixin` also works with prototypes:\n\n        ```javascript\n        var Person = function() {};\n        RSVP.EventTarget.mixin(Person.prototype);\n\n        var yehuda = new Person();\n        var tom = new Person();\n\n        yehuda.on('poke', function(event) {\n          console.log('Yehuda says OW');\n        });\n\n        tom.on('poke', function(event) {\n          console.log('Tom says OW');\n        });\n\n        yehuda.trigger('poke');\n        tom.trigger('poke');\n        ```\n\n        @method mixin\n        @for RSVP.EventTarget\n        @private\n        @param {Object} object object to extend with EventTarget methods\n      */\n      'mixin': function(object) {\n        object['on']      = this['on'];\n        object['off']     = this['off'];\n        object['trigger'] = this['trigger'];\n        object._promiseCallbacks = undefined;\n        return object;\n      },\n\n      /**\n        Registers a callback to be executed when `eventName` is triggered\n\n        ```javascript\n        object.on('event', function(eventInfo){\n          // handle the event\n        });\n\n        object.trigger('event');\n        ```\n\n        @method on\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName name of the event to listen for\n        @param {Function} callback function to be called when the event is triggered.\n      */\n      'on': function(eventName, callback) {\n        if (typeof callback !== 'function') {\n          throw new TypeError('Callback must be a function');\n        }\n\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks;\n\n        callbacks = allCallbacks[eventName];\n\n        if (!callbacks) {\n          callbacks = allCallbacks[eventName] = [];\n        }\n\n        if (lib$rsvp$events$$indexOf(callbacks, callback) === -1) {\n          callbacks.push(callback);\n        }\n      },\n\n      /**\n        You can use `off` to stop firing a particular callback for an event:\n\n        ```javascript\n        function doStuff() { // do stuff! }\n        object.on('stuff', doStuff);\n\n        object.trigger('stuff'); // doStuff will be called\n\n        // Unregister ONLY the doStuff callback\n        object.off('stuff', doStuff);\n        object.trigger('stuff'); // doStuff will NOT be called\n        ```\n\n        If you don't pass a `callback` argument to `off`, ALL callbacks for the\n        event will not be executed when the event fires. For example:\n\n        ```javascript\n        var callback1 = function(){};\n        var callback2 = function(){};\n\n        object.on('stuff', callback1);\n        object.on('stuff', callback2);\n\n        object.trigger('stuff'); // callback1 and callback2 will be executed.\n\n        object.off('stuff');\n        object.trigger('stuff'); // callback1 and callback2 will not be executed!\n        ```\n\n        @method off\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName event to stop listening to\n        @param {Function} callback optional argument. If given, only the function\n        given will be removed from the event's callback queue. If no `callback`\n        argument is given, all callbacks will be removed from the event's callback\n        queue.\n      */\n      'off': function(eventName, callback) {\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, index;\n\n        if (!callback) {\n          allCallbacks[eventName] = [];\n          return;\n        }\n\n        callbacks = allCallbacks[eventName];\n\n        index = lib$rsvp$events$$indexOf(callbacks, callback);\n\n        if (index !== -1) { callbacks.splice(index, 1); }\n      },\n\n      /**\n        Use `trigger` to fire custom events. For example:\n\n        ```javascript\n        object.on('foo', function(){\n          console.log('foo event happened!');\n        });\n        object.trigger('foo');\n        // 'foo event happened!' logged to the console\n        ```\n\n        You can also pass a value as a second argument to `trigger` that will be\n        passed as an argument to all event listeners for the event:\n\n        ```javascript\n        object.on('foo', function(value){\n          console.log(value.name);\n        });\n\n        object.trigger('foo', { name: 'bar' });\n        // 'bar' logged to the console\n        ```\n\n        @method trigger\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName name of the event to be triggered\n        @param {*} options optional value to be passed to any event handlers for\n        the given `eventName`\n      */\n      'trigger': function(eventName, options, label) {\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, callback;\n\n        if (callbacks = allCallbacks[eventName]) {\n          // Don't cache the callbacks.length since it may grow\n          for (var i=0; i<callbacks.length; i++) {\n            callback = callbacks[i];\n\n            callback(options, label);\n          }\n        }\n      }\n    };\n\n    var lib$rsvp$config$$config = {\n      instrument: false\n    };\n\n    lib$rsvp$events$$default['mixin'](lib$rsvp$config$$config);\n\n    function lib$rsvp$config$$configure(name, value) {\n      if (name === 'onerror') {\n        // handle for legacy users that expect the actual\n        // error to be passed to their function added via\n        // `RSVP.configure('onerror', someFunctionHere);`\n        lib$rsvp$config$$config['on']('error', value);\n        return;\n      }\n\n      if (arguments.length === 2) {\n        lib$rsvp$config$$config[name] = value;\n      } else {\n        return lib$rsvp$config$$config[name];\n      }\n    }\n\n    var lib$rsvp$instrument$$queue = [];\n\n    function lib$rsvp$instrument$$scheduleFlush() {\n      setTimeout(function() {\n        var entry;\n        for (var i = 0; i < lib$rsvp$instrument$$queue.length; i++) {\n          entry = lib$rsvp$instrument$$queue[i];\n\n          var payload = entry.payload;\n\n          payload.guid = payload.key + payload.id;\n          payload.childGuid = payload.key + payload.childId;\n          if (payload.error) {\n            payload.stack = payload.error.stack;\n          }\n\n          lib$rsvp$config$$config['trigger'](entry.name, entry.payload);\n        }\n        lib$rsvp$instrument$$queue.length = 0;\n      }, 50);\n    }\n\n    function lib$rsvp$instrument$$instrument(eventName, promise, child) {\n      if (1 === lib$rsvp$instrument$$queue.push({\n        name: eventName,\n        payload: {\n          key: promise._guidKey,\n          id:  promise._id,\n          eventName: eventName,\n          detail: promise._result,\n          childId: child && child._id,\n          label: promise._label,\n          timeStamp: lib$rsvp$utils$$now(),\n          error: lib$rsvp$config$$config[\"instrument-with-stack\"] ? new Error(promise._label) : null\n        }})) {\n          lib$rsvp$instrument$$scheduleFlush();\n        }\n      }\n    var lib$rsvp$instrument$$default = lib$rsvp$instrument$$instrument;\n    function lib$rsvp$then$$then(onFulfillment, onRejection, label) {\n      var parent = this;\n      var state = parent._state;\n\n      if (state === lib$rsvp$$internal$$FULFILLED && !onFulfillment || state === lib$rsvp$$internal$$REJECTED && !onRejection) {\n        lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, parent);\n        return parent;\n      }\n\n      parent._onError = null;\n\n      var child = new parent.constructor(lib$rsvp$$internal$$noop, label);\n      var result = parent._result;\n\n      lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, child);\n\n      if (state) {\n        var callback = arguments[state - 1];\n        lib$rsvp$config$$config.async(function(){\n          lib$rsvp$$internal$$invokeCallback(state, child, callback, result);\n        });\n      } else {\n        lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection);\n      }\n\n      return child;\n    }\n    var lib$rsvp$then$$default = lib$rsvp$then$$then;\n    function lib$rsvp$promise$resolve$$resolve(object, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n\n      if (object && typeof object === 'object' && object.constructor === Constructor) {\n        return object;\n      }\n\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      lib$rsvp$$internal$$resolve(promise, object);\n      return promise;\n    }\n    var lib$rsvp$promise$resolve$$default = lib$rsvp$promise$resolve$$resolve;\n    function lib$rsvp$enumerator$$makeSettledResult(state, position, value) {\n      if (state === lib$rsvp$$internal$$FULFILLED) {\n        return {\n          state: 'fulfilled',\n          value: value\n        };\n      } else {\n         return {\n          state: 'rejected',\n          reason: value\n        };\n      }\n    }\n\n    function lib$rsvp$enumerator$$Enumerator(Constructor, input, abortOnReject, label) {\n      this._instanceConstructor = Constructor;\n      this.promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      this._abortOnReject = abortOnReject;\n\n      if (this._validateInput(input)) {\n        this._input     = input;\n        this.length     = input.length;\n        this._remaining = input.length;\n\n        this._init();\n\n        if (this.length === 0) {\n          lib$rsvp$$internal$$fulfill(this.promise, this._result);\n        } else {\n          this.length = this.length || 0;\n          this._enumerate();\n          if (this._remaining === 0) {\n            lib$rsvp$$internal$$fulfill(this.promise, this._result);\n          }\n        }\n      } else {\n        lib$rsvp$$internal$$reject(this.promise, this._validationError());\n      }\n    }\n\n    var lib$rsvp$enumerator$$default = lib$rsvp$enumerator$$Enumerator;\n\n    lib$rsvp$enumerator$$Enumerator.prototype._validateInput = function(input) {\n      return lib$rsvp$utils$$isArray(input);\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._validationError = function() {\n      return new Error('Array Methods must be provided an Array');\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._init = function() {\n      this._result = new Array(this.length);\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._enumerate = function() {\n      var length     = this.length;\n      var promise    = this.promise;\n      var input      = this._input;\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        this._eachEntry(input[i], i);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._settleMaybeThenable = function(entry, i) {\n      var c = this._instanceConstructor;\n      var resolve = c.resolve;\n\n      if (resolve === lib$rsvp$promise$resolve$$default) {\n        var then = lib$rsvp$$internal$$getThen(entry);\n\n        if (then === lib$rsvp$then$$default &&\n            entry._state !== lib$rsvp$$internal$$PENDING) {\n          entry._onError = null;\n          this._settledAt(entry._state, i, entry._result);\n        } else if (typeof then !== 'function') {\n          this._remaining--;\n          this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n        } else if (c === lib$rsvp$promise$$default) {\n          var promise = new c(lib$rsvp$$internal$$noop);\n          lib$rsvp$$internal$$handleMaybeThenable(promise, entry, then);\n          this._willSettleAt(promise, i);\n        } else {\n          this._willSettleAt(new c(function(resolve) { resolve(entry); }), i);\n        }\n      } else {\n        this._willSettleAt(resolve(entry), i);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._eachEntry = function(entry, i) {\n      if (lib$rsvp$utils$$isMaybeThenable(entry)) {\n        this._settleMaybeThenable(entry, i);\n      } else {\n        this._remaining--;\n        this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._settledAt = function(state, i, value) {\n      var promise = this.promise;\n\n      if (promise._state === lib$rsvp$$internal$$PENDING) {\n        this._remaining--;\n\n        if (this._abortOnReject && state === lib$rsvp$$internal$$REJECTED) {\n          lib$rsvp$$internal$$reject(promise, value);\n        } else {\n          this._result[i] = this._makeResult(state, i, value);\n        }\n      }\n\n      if (this._remaining === 0) {\n        lib$rsvp$$internal$$fulfill(promise, this._result);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._makeResult = function(state, i, value) {\n      return value;\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._willSettleAt = function(promise, i) {\n      var enumerator = this;\n\n      lib$rsvp$$internal$$subscribe(promise, undefined, function(value) {\n        enumerator._settledAt(lib$rsvp$$internal$$FULFILLED, i, value);\n      }, function(reason) {\n        enumerator._settledAt(lib$rsvp$$internal$$REJECTED, i, reason);\n      });\n    };\n    function lib$rsvp$promise$all$$all(entries, label) {\n      return new lib$rsvp$enumerator$$default(this, entries, true /* abort on reject */, label).promise;\n    }\n    var lib$rsvp$promise$all$$default = lib$rsvp$promise$all$$all;\n    function lib$rsvp$promise$race$$race(entries, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n\n      if (!lib$rsvp$utils$$isArray(entries)) {\n        lib$rsvp$$internal$$reject(promise, new TypeError('You must pass an array to race.'));\n        return promise;\n      }\n\n      var length = entries.length;\n\n      function onFulfillment(value) {\n        lib$rsvp$$internal$$resolve(promise, value);\n      }\n\n      function onRejection(reason) {\n        lib$rsvp$$internal$$reject(promise, reason);\n      }\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        lib$rsvp$$internal$$subscribe(Constructor.resolve(entries[i]), undefined, onFulfillment, onRejection);\n      }\n\n      return promise;\n    }\n    var lib$rsvp$promise$race$$default = lib$rsvp$promise$race$$race;\n    function lib$rsvp$promise$reject$$reject(reason, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      lib$rsvp$$internal$$reject(promise, reason);\n      return promise;\n    }\n    var lib$rsvp$promise$reject$$default = lib$rsvp$promise$reject$$reject;\n\n    var lib$rsvp$promise$$guidKey = 'rsvp_' + lib$rsvp$utils$$now() + '-';\n    var lib$rsvp$promise$$counter = 0;\n\n    function lib$rsvp$promise$$needsResolver() {\n      throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n    }\n\n    function lib$rsvp$promise$$needsNew() {\n      throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n    }\n\n    function lib$rsvp$promise$$Promise(resolver, label) {\n      this._id = lib$rsvp$promise$$counter++;\n      this._label = label;\n      this._state = undefined;\n      this._result = undefined;\n      this._subscribers = [];\n\n      lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('created', this);\n\n      if (lib$rsvp$$internal$$noop !== resolver) {\n        typeof resolver !== 'function' && lib$rsvp$promise$$needsResolver();\n        this instanceof lib$rsvp$promise$$Promise ? lib$rsvp$$internal$$initializePromise(this, resolver) : lib$rsvp$promise$$needsNew();\n      }\n    }\n\n    var lib$rsvp$promise$$default = lib$rsvp$promise$$Promise;\n\n    // deprecated\n    lib$rsvp$promise$$Promise.cast = lib$rsvp$promise$resolve$$default;\n    lib$rsvp$promise$$Promise.all = lib$rsvp$promise$all$$default;\n    lib$rsvp$promise$$Promise.race = lib$rsvp$promise$race$$default;\n    lib$rsvp$promise$$Promise.resolve = lib$rsvp$promise$resolve$$default;\n    lib$rsvp$promise$$Promise.reject = lib$rsvp$promise$reject$$default;\n\n    lib$rsvp$promise$$Promise.prototype = {\n      constructor: lib$rsvp$promise$$Promise,\n\n      _guidKey: lib$rsvp$promise$$guidKey,\n\n      _onError: function (reason) {\n        var promise = this;\n        lib$rsvp$config$$config.after(function() {\n          if (promise._onError) {\n            lib$rsvp$config$$config['trigger']('error', reason, promise._label);\n          }\n        });\n      },\n\n    /**\n      The primary way of interacting with a promise is through its `then` method,\n      which registers callbacks to receive either a promise's eventual value or the\n      reason why the promise cannot be fulfilled.\n\n      ```js\n      findUser().then(function(user){\n        // user is available\n      }, function(reason){\n        // user is unavailable, and you are given the reason why\n      });\n      ```\n\n      Chaining\n      --------\n\n      The return value of `then` is itself a promise.  This second, 'downstream'\n      promise is resolved with the return value of the first promise's fulfillment\n      or rejection handler, or rejected if the handler throws an exception.\n\n      ```js\n      findUser().then(function (user) {\n        return user.name;\n      }, function (reason) {\n        return 'default name';\n      }).then(function (userName) {\n        // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n        // will be `'default name'`\n      });\n\n      findUser().then(function (user) {\n        throw new Error('Found user, but still unhappy');\n      }, function (reason) {\n        throw new Error('`findUser` rejected and we're unhappy');\n      }).then(function (value) {\n        // never reached\n      }, function (reason) {\n        // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n        // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n      });\n      ```\n      If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n\n      ```js\n      findUser().then(function (user) {\n        throw new PedagogicalException('Upstream error');\n      }).then(function (value) {\n        // never reached\n      }).then(function (value) {\n        // never reached\n      }, function (reason) {\n        // The `PedgagocialException` is propagated all the way down to here\n      });\n      ```\n\n      Assimilation\n      ------------\n\n      Sometimes the value you want to propagate to a downstream promise can only be\n      retrieved asynchronously. This can be achieved by returning a promise in the\n      fulfillment or rejection handler. The downstream promise will then be pending\n      until the returned promise is settled. This is called *assimilation*.\n\n      ```js\n      findUser().then(function (user) {\n        return findCommentsByAuthor(user);\n      }).then(function (comments) {\n        // The user's comments are now available\n      });\n      ```\n\n      If the assimliated promise rejects, then the downstream promise will also reject.\n\n      ```js\n      findUser().then(function (user) {\n        return findCommentsByAuthor(user);\n      }).then(function (comments) {\n        // If `findCommentsByAuthor` fulfills, we'll have the value here\n      }, function (reason) {\n        // If `findCommentsByAuthor` rejects, we'll have the reason here\n      });\n      ```\n\n      Simple Example\n      --------------\n\n      Synchronous Example\n\n      ```javascript\n      var result;\n\n      try {\n        result = findResult();\n        // success\n      } catch(reason) {\n        // failure\n      }\n      ```\n\n      Errback Example\n\n      ```js\n      findResult(function(result, err){\n        if (err) {\n          // failure\n        } else {\n          // success\n        }\n      });\n      ```\n\n      Promise Example;\n\n      ```javascript\n      findResult().then(function(result){\n        // success\n      }, function(reason){\n        // failure\n      });\n      ```\n\n      Advanced Example\n      --------------\n\n      Synchronous Example\n\n      ```javascript\n      var author, books;\n\n      try {\n        author = findAuthor();\n        books  = findBooksByAuthor(author);\n        // success\n      } catch(reason) {\n        // failure\n      }\n      ```\n\n      Errback Example\n\n      ```js\n\n      function foundBooks(books) {\n\n      }\n\n      function failure(reason) {\n\n      }\n\n      findAuthor(function(author, err){\n        if (err) {\n          failure(err);\n          // failure\n        } else {\n          try {\n            findBoooksByAuthor(author, function(books, err) {\n              if (err) {\n                failure(err);\n              } else {\n                try {\n                  foundBooks(books);\n                } catch(reason) {\n                  failure(reason);\n                }\n              }\n            });\n          } catch(error) {\n            failure(err);\n          }\n          // success\n        }\n      });\n      ```\n\n      Promise Example;\n\n      ```javascript\n      findAuthor().\n        then(findBooksByAuthor).\n        then(function(books){\n          // found books\n      }).catch(function(reason){\n        // something went wrong\n      });\n      ```\n\n      @method then\n      @param {Function} onFulfillment\n      @param {Function} onRejection\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      then: lib$rsvp$then$$default,\n\n    /**\n      `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n      as the catch block of a try/catch statement.\n\n      ```js\n      function findAuthor(){\n        throw new Error('couldn't find that author');\n      }\n\n      // synchronous\n      try {\n        findAuthor();\n      } catch(reason) {\n        // something went wrong\n      }\n\n      // async with promises\n      findAuthor().catch(function(reason){\n        // something went wrong\n      });\n      ```\n\n      @method catch\n      @param {Function} onRejection\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      'catch': function(onRejection, label) {\n        return this.then(undefined, onRejection, label);\n      },\n\n    /**\n      `finally` will be invoked regardless of the promise's fate just as native\n      try/catch/finally behaves\n\n      Synchronous example:\n\n      ```js\n      findAuthor() {\n        if (Math.random() > 0.5) {\n          throw new Error();\n        }\n        return new Author();\n      }\n\n      try {\n        return findAuthor(); // succeed or fail\n      } catch(error) {\n        return findOtherAuther();\n      } finally {\n        // always runs\n        // doesn't affect the return value\n      }\n      ```\n\n      Asynchronous example:\n\n      ```js\n      findAuthor().catch(function(reason){\n        return findOtherAuther();\n      }).finally(function(){\n        // author was either found, or not\n      });\n      ```\n\n      @method finally\n      @param {Function} callback\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      'finally': function(callback, label) {\n        var promise = this;\n        var constructor = promise.constructor;\n\n        return promise.then(function(value) {\n          return constructor.resolve(callback()).then(function() {\n            return value;\n          });\n        }, function(reason) {\n          return constructor.resolve(callback()).then(function() {\n            return constructor.reject(reason);\n          });\n        }, label);\n      }\n    };\n    function  lib$rsvp$$internal$$withOwnPromise() {\n      return new TypeError('A promises callback cannot return that same promise.');\n    }\n\n    function lib$rsvp$$internal$$noop() {}\n\n    var lib$rsvp$$internal$$PENDING   = void 0;\n    var lib$rsvp$$internal$$FULFILLED = 1;\n    var lib$rsvp$$internal$$REJECTED  = 2;\n\n    var lib$rsvp$$internal$$GET_THEN_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n    function lib$rsvp$$internal$$getThen(promise) {\n      try {\n        return promise.then;\n      } catch(error) {\n        lib$rsvp$$internal$$GET_THEN_ERROR.error = error;\n        return lib$rsvp$$internal$$GET_THEN_ERROR;\n      }\n    }\n\n    function lib$rsvp$$internal$$tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n      try {\n        then.call(value, fulfillmentHandler, rejectionHandler);\n      } catch(e) {\n        return e;\n      }\n    }\n\n    function lib$rsvp$$internal$$handleForeignThenable(promise, thenable, then) {\n      lib$rsvp$config$$config.async(function(promise) {\n        var sealed = false;\n        var error = lib$rsvp$$internal$$tryThen(then, thenable, function(value) {\n          if (sealed) { return; }\n          sealed = true;\n          if (thenable !== value) {\n            lib$rsvp$$internal$$resolve(promise, value, undefined);\n          } else {\n            lib$rsvp$$internal$$fulfill(promise, value);\n          }\n        }, function(reason) {\n          if (sealed) { return; }\n          sealed = true;\n\n          lib$rsvp$$internal$$reject(promise, reason);\n        }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n        if (!sealed && error) {\n          sealed = true;\n          lib$rsvp$$internal$$reject(promise, error);\n        }\n      }, promise);\n    }\n\n    function lib$rsvp$$internal$$handleOwnThenable(promise, thenable) {\n      if (thenable._state === lib$rsvp$$internal$$FULFILLED) {\n        lib$rsvp$$internal$$fulfill(promise, thenable._result);\n      } else if (thenable._state === lib$rsvp$$internal$$REJECTED) {\n        thenable._onError = null;\n        lib$rsvp$$internal$$reject(promise, thenable._result);\n      } else {\n        lib$rsvp$$internal$$subscribe(thenable, undefined, function(value) {\n          if (thenable !== value) {\n            lib$rsvp$$internal$$resolve(promise, value, undefined);\n          } else {\n            lib$rsvp$$internal$$fulfill(promise, value);\n          }\n        }, function(reason) {\n          lib$rsvp$$internal$$reject(promise, reason);\n        });\n      }\n    }\n\n    function lib$rsvp$$internal$$handleMaybeThenable(promise, maybeThenable, then) {\n      if (maybeThenable.constructor === promise.constructor &&\n          then === lib$rsvp$then$$default &&\n          constructor.resolve === lib$rsvp$promise$resolve$$default) {\n        lib$rsvp$$internal$$handleOwnThenable(promise, maybeThenable);\n      } else {\n        if (then === lib$rsvp$$internal$$GET_THEN_ERROR) {\n          lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$GET_THEN_ERROR.error);\n        } else if (then === undefined) {\n          lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n        } else if (lib$rsvp$utils$$isFunction(then)) {\n          lib$rsvp$$internal$$handleForeignThenable(promise, maybeThenable, then);\n        } else {\n          lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n        }\n      }\n    }\n\n    function lib$rsvp$$internal$$resolve(promise, value) {\n      if (promise === value) {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      } else if (lib$rsvp$utils$$objectOrFunction(value)) {\n        lib$rsvp$$internal$$handleMaybeThenable(promise, value, lib$rsvp$$internal$$getThen(value));\n      } else {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      }\n    }\n\n    function lib$rsvp$$internal$$publishRejection(promise) {\n      if (promise._onError) {\n        promise._onError(promise._result);\n      }\n\n      lib$rsvp$$internal$$publish(promise);\n    }\n\n    function lib$rsvp$$internal$$fulfill(promise, value) {\n      if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n\n      promise._result = value;\n      promise._state = lib$rsvp$$internal$$FULFILLED;\n\n      if (promise._subscribers.length === 0) {\n        if (lib$rsvp$config$$config.instrument) {\n          lib$rsvp$instrument$$default('fulfilled', promise);\n        }\n      } else {\n        lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, promise);\n      }\n    }\n\n    function lib$rsvp$$internal$$reject(promise, reason) {\n      if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n      promise._state = lib$rsvp$$internal$$REJECTED;\n      promise._result = reason;\n      lib$rsvp$config$$config.async(lib$rsvp$$internal$$publishRejection, promise);\n    }\n\n    function lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection) {\n      var subscribers = parent._subscribers;\n      var length = subscribers.length;\n\n      parent._onError = null;\n\n      subscribers[length] = child;\n      subscribers[length + lib$rsvp$$internal$$FULFILLED] = onFulfillment;\n      subscribers[length + lib$rsvp$$internal$$REJECTED]  = onRejection;\n\n      if (length === 0 && parent._state) {\n        lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, parent);\n      }\n    }\n\n    function lib$rsvp$$internal$$publish(promise) {\n      var subscribers = promise._subscribers;\n      var settled = promise._state;\n\n      if (lib$rsvp$config$$config.instrument) {\n        lib$rsvp$instrument$$default(settled === lib$rsvp$$internal$$FULFILLED ? 'fulfilled' : 'rejected', promise);\n      }\n\n      if (subscribers.length === 0) { return; }\n\n      var child, callback, detail = promise._result;\n\n      for (var i = 0; i < subscribers.length; i += 3) {\n        child = subscribers[i];\n        callback = subscribers[i + settled];\n\n        if (child) {\n          lib$rsvp$$internal$$invokeCallback(settled, child, callback, detail);\n        } else {\n          callback(detail);\n        }\n      }\n\n      promise._subscribers.length = 0;\n    }\n\n    function lib$rsvp$$internal$$ErrorObject() {\n      this.error = null;\n    }\n\n    var lib$rsvp$$internal$$TRY_CATCH_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n    function lib$rsvp$$internal$$tryCatch(callback, detail) {\n      try {\n        return callback(detail);\n      } catch(e) {\n        lib$rsvp$$internal$$TRY_CATCH_ERROR.error = e;\n        return lib$rsvp$$internal$$TRY_CATCH_ERROR;\n      }\n    }\n\n    function lib$rsvp$$internal$$invokeCallback(settled, promise, callback, detail) {\n      var hasCallback = lib$rsvp$utils$$isFunction(callback),\n          value, error, succeeded, failed;\n\n      if (hasCallback) {\n        value = lib$rsvp$$internal$$tryCatch(callback, detail);\n\n        if (value === lib$rsvp$$internal$$TRY_CATCH_ERROR) {\n          failed = true;\n          error = value.error;\n          value = null;\n        } else {\n          succeeded = true;\n        }\n\n        if (promise === value) {\n          lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$withOwnPromise());\n          return;\n        }\n\n      } else {\n        value = detail;\n        succeeded = true;\n      }\n\n      if (promise._state !== lib$rsvp$$internal$$PENDING) {\n        // noop\n      } else if (hasCallback && succeeded) {\n        lib$rsvp$$internal$$resolve(promise, value);\n      } else if (failed) {\n        lib$rsvp$$internal$$reject(promise, error);\n      } else if (settled === lib$rsvp$$internal$$FULFILLED) {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      } else if (settled === lib$rsvp$$internal$$REJECTED) {\n        lib$rsvp$$internal$$reject(promise, value);\n      }\n    }\n\n    function lib$rsvp$$internal$$initializePromise(promise, resolver) {\n      var resolved = false;\n      try {\n        resolver(function resolvePromise(value){\n          if (resolved) { return; }\n          resolved = true;\n          lib$rsvp$$internal$$resolve(promise, value);\n        }, function rejectPromise(reason) {\n          if (resolved) { return; }\n          resolved = true;\n          lib$rsvp$$internal$$reject(promise, reason);\n        });\n      } catch(e) {\n        lib$rsvp$$internal$$reject(promise, e);\n      }\n    }\n\n    function lib$rsvp$all$settled$$AllSettled(Constructor, entries, label) {\n      this._superConstructor(Constructor, entries, false /* don't abort on reject */, label);\n    }\n\n    lib$rsvp$all$settled$$AllSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n    lib$rsvp$all$settled$$AllSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$all$settled$$AllSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n    lib$rsvp$all$settled$$AllSettled.prototype._validationError = function() {\n      return new Error('allSettled must be called with an array');\n    };\n\n    function lib$rsvp$all$settled$$allSettled(entries, label) {\n      return new lib$rsvp$all$settled$$AllSettled(lib$rsvp$promise$$default, entries, label).promise;\n    }\n    var lib$rsvp$all$settled$$default = lib$rsvp$all$settled$$allSettled;\n    function lib$rsvp$all$$all(array, label) {\n      return lib$rsvp$promise$$default.all(array, label);\n    }\n    var lib$rsvp$all$$default = lib$rsvp$all$$all;\n    var lib$rsvp$asap$$len = 0;\n    var lib$rsvp$asap$$toString = {}.toString;\n    var lib$rsvp$asap$$vertxNext;\n    function lib$rsvp$asap$$asap(callback, arg) {\n      lib$rsvp$asap$$queue[lib$rsvp$asap$$len] = callback;\n      lib$rsvp$asap$$queue[lib$rsvp$asap$$len + 1] = arg;\n      lib$rsvp$asap$$len += 2;\n      if (lib$rsvp$asap$$len === 2) {\n        // If len is 1, that means that we need to schedule an async flush.\n        // If additional callbacks are queued before the queue is flushed, they\n        // will be processed by this flush that we are scheduling.\n        lib$rsvp$asap$$scheduleFlush();\n      }\n    }\n\n    var lib$rsvp$asap$$default = lib$rsvp$asap$$asap;\n\n    var lib$rsvp$asap$$browserWindow = (typeof window !== 'undefined') ? window : undefined;\n    var lib$rsvp$asap$$browserGlobal = lib$rsvp$asap$$browserWindow || {};\n    var lib$rsvp$asap$$BrowserMutationObserver = lib$rsvp$asap$$browserGlobal.MutationObserver || lib$rsvp$asap$$browserGlobal.WebKitMutationObserver;\n    var lib$rsvp$asap$$isNode = typeof self === 'undefined' &&\n      typeof process !== 'undefined' && {}.toString.call(process) === '[object process]';\n\n    // test for web worker but not in IE10\n    var lib$rsvp$asap$$isWorker = typeof Uint8ClampedArray !== 'undefined' &&\n      typeof importScripts !== 'undefined' &&\n      typeof MessageChannel !== 'undefined';\n\n    // node\n    function lib$rsvp$asap$$useNextTick() {\n      var nextTick = process.nextTick;\n      // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n      // setImmediate should be used instead instead\n      var version = process.versions.node.match(/^(?:(\\d+)\\.)?(?:(\\d+)\\.)?(\\*|\\d+)$/);\n      if (Array.isArray(version) && version[1] === '0' && version[2] === '10') {\n        nextTick = setImmediate;\n      }\n      return function() {\n        nextTick(lib$rsvp$asap$$flush);\n      };\n    }\n\n    // vertx\n    function lib$rsvp$asap$$useVertxTimer() {\n      return function() {\n        lib$rsvp$asap$$vertxNext(lib$rsvp$asap$$flush);\n      };\n    }\n\n    function lib$rsvp$asap$$useMutationObserver() {\n      var iterations = 0;\n      var observer = new lib$rsvp$asap$$BrowserMutationObserver(lib$rsvp$asap$$flush);\n      var node = document.createTextNode('');\n      observer.observe(node, { characterData: true });\n\n      return function() {\n        node.data = (iterations = ++iterations % 2);\n      };\n    }\n\n    // web worker\n    function lib$rsvp$asap$$useMessageChannel() {\n      var channel = new MessageChannel();\n      channel.port1.onmessage = lib$rsvp$asap$$flush;\n      return function () {\n        channel.port2.postMessage(0);\n      };\n    }\n\n    function lib$rsvp$asap$$useSetTimeout() {\n      return function() {\n        setTimeout(lib$rsvp$asap$$flush, 1);\n      };\n    }\n\n    var lib$rsvp$asap$$queue = new Array(1000);\n    function lib$rsvp$asap$$flush() {\n      for (var i = 0; i < lib$rsvp$asap$$len; i+=2) {\n        var callback = lib$rsvp$asap$$queue[i];\n        var arg = lib$rsvp$asap$$queue[i+1];\n\n        callback(arg);\n\n        lib$rsvp$asap$$queue[i] = undefined;\n        lib$rsvp$asap$$queue[i+1] = undefined;\n      }\n\n      lib$rsvp$asap$$len = 0;\n    }\n\n    function lib$rsvp$asap$$attemptVertex() {\n      try {\n        var r = require;\n        var vertx = r('vertx');\n        lib$rsvp$asap$$vertxNext = vertx.runOnLoop || vertx.runOnContext;\n        return lib$rsvp$asap$$useVertxTimer();\n      } catch(e) {\n        return lib$rsvp$asap$$useSetTimeout();\n      }\n    }\n\n    var lib$rsvp$asap$$scheduleFlush;\n    // Decide what async method to use to triggering processing of queued callbacks:\n    if (lib$rsvp$asap$$isNode) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useNextTick();\n    } else if (lib$rsvp$asap$$BrowserMutationObserver) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMutationObserver();\n    } else if (lib$rsvp$asap$$isWorker) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMessageChannel();\n    } else if (lib$rsvp$asap$$browserWindow === undefined && typeof require === 'function') {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$attemptVertex();\n    } else {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useSetTimeout();\n    }\n    function lib$rsvp$defer$$defer(label) {\n      var deferred = {};\n\n      deferred['promise'] = new lib$rsvp$promise$$default(function(resolve, reject) {\n        deferred['resolve'] = resolve;\n        deferred['reject'] = reject;\n      }, label);\n\n      return deferred;\n    }\n    var lib$rsvp$defer$$default = lib$rsvp$defer$$defer;\n    function lib$rsvp$filter$$filter(promises, filterFn, label) {\n      return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n        if (!lib$rsvp$utils$$isFunction(filterFn)) {\n          throw new TypeError(\"You must pass a function as filter's second argument.\");\n        }\n\n        var length = values.length;\n        var filtered = new Array(length);\n\n        for (var i = 0; i < length; i++) {\n          filtered[i] = filterFn(values[i]);\n        }\n\n        return lib$rsvp$promise$$default.all(filtered, label).then(function(filtered) {\n          var results = new Array(length);\n          var newLength = 0;\n\n          for (var i = 0; i < length; i++) {\n            if (filtered[i]) {\n              results[newLength] = values[i];\n              newLength++;\n            }\n          }\n\n          results.length = newLength;\n\n          return results;\n        });\n      });\n    }\n    var lib$rsvp$filter$$default = lib$rsvp$filter$$filter;\n\n    function lib$rsvp$promise$hash$$PromiseHash(Constructor, object, label) {\n      this._superConstructor(Constructor, object, true, label);\n    }\n\n    var lib$rsvp$promise$hash$$default = lib$rsvp$promise$hash$$PromiseHash;\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n    lib$rsvp$promise$hash$$PromiseHash.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$promise$hash$$PromiseHash.prototype._init = function() {\n      this._result = {};\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._validateInput = function(input) {\n      return input && typeof input === 'object';\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._validationError = function() {\n      return new Error('Promise.hash must be called with an object');\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._enumerate = function() {\n      var enumerator = this;\n      var promise    = enumerator.promise;\n      var input      = enumerator._input;\n      var results    = [];\n\n      for (var key in input) {\n        if (promise._state === lib$rsvp$$internal$$PENDING && Object.prototype.hasOwnProperty.call(input, key)) {\n          results.push({\n            position: key,\n            entry: input[key]\n          });\n        }\n      }\n\n      var length = results.length;\n      enumerator._remaining = length;\n      var result;\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        result = results[i];\n        enumerator._eachEntry(result.entry, result.position);\n      }\n    };\n\n    function lib$rsvp$hash$settled$$HashSettled(Constructor, object, label) {\n      this._superConstructor(Constructor, object, false, label);\n    }\n\n    lib$rsvp$hash$settled$$HashSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$promise$hash$$default.prototype);\n    lib$rsvp$hash$settled$$HashSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$hash$settled$$HashSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n\n    lib$rsvp$hash$settled$$HashSettled.prototype._validationError = function() {\n      return new Error('hashSettled must be called with an object');\n    };\n\n    function lib$rsvp$hash$settled$$hashSettled(object, label) {\n      return new lib$rsvp$hash$settled$$HashSettled(lib$rsvp$promise$$default, object, label).promise;\n    }\n    var lib$rsvp$hash$settled$$default = lib$rsvp$hash$settled$$hashSettled;\n    function lib$rsvp$hash$$hash(object, label) {\n      return new lib$rsvp$promise$hash$$default(lib$rsvp$promise$$default, object, label).promise;\n    }\n    var lib$rsvp$hash$$default = lib$rsvp$hash$$hash;\n    function lib$rsvp$map$$map(promises, mapFn, label) {\n      return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n        if (!lib$rsvp$utils$$isFunction(mapFn)) {\n          throw new TypeError(\"You must pass a function as map's second argument.\");\n        }\n\n        var length = values.length;\n        var results = new Array(length);\n\n        for (var i = 0; i < length; i++) {\n          results[i] = mapFn(values[i]);\n        }\n\n        return lib$rsvp$promise$$default.all(results, label);\n      });\n    }\n    var lib$rsvp$map$$default = lib$rsvp$map$$map;\n\n    function lib$rsvp$node$$Result() {\n      this.value = undefined;\n    }\n\n    var lib$rsvp$node$$ERROR = new lib$rsvp$node$$Result();\n    var lib$rsvp$node$$GET_THEN_ERROR = new lib$rsvp$node$$Result();\n\n    function lib$rsvp$node$$getThen(obj) {\n      try {\n       return obj.then;\n      } catch(error) {\n        lib$rsvp$node$$ERROR.value= error;\n        return lib$rsvp$node$$ERROR;\n      }\n    }\n\n\n    function lib$rsvp$node$$tryApply(f, s, a) {\n      try {\n        f.apply(s, a);\n      } catch(error) {\n        lib$rsvp$node$$ERROR.value = error;\n        return lib$rsvp$node$$ERROR;\n      }\n    }\n\n    function lib$rsvp$node$$makeObject(_, argumentNames) {\n      var obj = {};\n      var name;\n      var i;\n      var length = _.length;\n      var args = new Array(length);\n\n      for (var x = 0; x < length; x++) {\n        args[x] = _[x];\n      }\n\n      for (i = 0; i < argumentNames.length; i++) {\n        name = argumentNames[i];\n        obj[name] = args[i + 1];\n      }\n\n      return obj;\n    }\n\n    function lib$rsvp$node$$arrayResult(_) {\n      var length = _.length;\n      var args = new Array(length - 1);\n\n      for (var i = 1; i < length; i++) {\n        args[i - 1] = _[i];\n      }\n\n      return args;\n    }\n\n    function lib$rsvp$node$$wrapThenable(then, promise) {\n      return {\n        then: function(onFulFillment, onRejection) {\n          return then.call(promise, onFulFillment, onRejection);\n        }\n      };\n    }\n\n    function lib$rsvp$node$$denodeify(nodeFunc, options) {\n      var fn = function() {\n        var self = this;\n        var l = arguments.length;\n        var args = new Array(l + 1);\n        var arg;\n        var promiseInput = false;\n\n        for (var i = 0; i < l; ++i) {\n          arg = arguments[i];\n\n          if (!promiseInput) {\n            // TODO: clean this up\n            promiseInput = lib$rsvp$node$$needsPromiseInput(arg);\n            if (promiseInput === lib$rsvp$node$$GET_THEN_ERROR) {\n              var p = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n              lib$rsvp$$internal$$reject(p, lib$rsvp$node$$GET_THEN_ERROR.value);\n              return p;\n            } else if (promiseInput && promiseInput !== true) {\n              arg = lib$rsvp$node$$wrapThenable(promiseInput, arg);\n            }\n          }\n          args[i] = arg;\n        }\n\n        var promise = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n\n        args[l] = function(err, val) {\n          if (err)\n            lib$rsvp$$internal$$reject(promise, err);\n          else if (options === undefined)\n            lib$rsvp$$internal$$resolve(promise, val);\n          else if (options === true)\n            lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$arrayResult(arguments));\n          else if (lib$rsvp$utils$$isArray(options))\n            lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$makeObject(arguments, options));\n          else\n            lib$rsvp$$internal$$resolve(promise, val);\n        };\n\n        if (promiseInput) {\n          return lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self);\n        } else {\n          return lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self);\n        }\n      };\n\n      fn.__proto__ = nodeFunc;\n\n      return fn;\n    }\n\n    var lib$rsvp$node$$default = lib$rsvp$node$$denodeify;\n\n    function lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self) {\n      var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n      if (result === lib$rsvp$node$$ERROR) {\n        lib$rsvp$$internal$$reject(promise, result.value);\n      }\n      return promise;\n    }\n\n    function lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self){\n      return lib$rsvp$promise$$default.all(args).then(function(args){\n        var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n        if (result === lib$rsvp$node$$ERROR) {\n          lib$rsvp$$internal$$reject(promise, result.value);\n        }\n        return promise;\n      });\n    }\n\n    function lib$rsvp$node$$needsPromiseInput(arg) {\n      if (arg && typeof arg === 'object') {\n        if (arg.constructor === lib$rsvp$promise$$default) {\n          return true;\n        } else {\n          return lib$rsvp$node$$getThen(arg);\n        }\n      } else {\n        return false;\n      }\n    }\n    var lib$rsvp$platform$$platform;\n\n    /* global self */\n    if (typeof self === 'object') {\n      lib$rsvp$platform$$platform = self;\n\n    /* global global */\n    } else if (typeof global === 'object') {\n      lib$rsvp$platform$$platform = global;\n    } else {\n      throw new Error('no global: `self` or `global` found');\n    }\n\n    var lib$rsvp$platform$$default = lib$rsvp$platform$$platform;\n    function lib$rsvp$race$$race(array, label) {\n      return lib$rsvp$promise$$default.race(array, label);\n    }\n    var lib$rsvp$race$$default = lib$rsvp$race$$race;\n    function lib$rsvp$reject$$reject(reason, label) {\n      return lib$rsvp$promise$$default.reject(reason, label);\n    }\n    var lib$rsvp$reject$$default = lib$rsvp$reject$$reject;\n    function lib$rsvp$resolve$$resolve(value, label) {\n      return lib$rsvp$promise$$default.resolve(value, label);\n    }\n    var lib$rsvp$resolve$$default = lib$rsvp$resolve$$resolve;\n    function lib$rsvp$rethrow$$rethrow(reason) {\n      setTimeout(function() {\n        throw reason;\n      });\n      throw reason;\n    }\n    var lib$rsvp$rethrow$$default = lib$rsvp$rethrow$$rethrow;\n\n    // defaults\n    lib$rsvp$config$$config.async = lib$rsvp$asap$$default;\n    lib$rsvp$config$$config.after = function(cb) {\n      setTimeout(cb, 0);\n    };\n    var lib$rsvp$$cast = lib$rsvp$resolve$$default;\n    function lib$rsvp$$async(callback, arg) {\n      lib$rsvp$config$$config.async(callback, arg);\n    }\n\n    function lib$rsvp$$on() {\n      lib$rsvp$config$$config['on'].apply(lib$rsvp$config$$config, arguments);\n    }\n\n    function lib$rsvp$$off() {\n      lib$rsvp$config$$config['off'].apply(lib$rsvp$config$$config, arguments);\n    }\n\n    // Set up instrumentation through `window.__PROMISE_INTRUMENTATION__`\n    if (typeof window !== 'undefined' && typeof window['__PROMISE_INSTRUMENTATION__'] === 'object') {\n      var lib$rsvp$$callbacks = window['__PROMISE_INSTRUMENTATION__'];\n      lib$rsvp$config$$configure('instrument', true);\n      for (var lib$rsvp$$eventName in lib$rsvp$$callbacks) {\n        if (lib$rsvp$$callbacks.hasOwnProperty(lib$rsvp$$eventName)) {\n          lib$rsvp$$on(lib$rsvp$$eventName, lib$rsvp$$callbacks[lib$rsvp$$eventName]);\n        }\n      }\n    }\n\n    var lib$rsvp$umd$$RSVP = {\n      'race': lib$rsvp$race$$default,\n      'Promise': lib$rsvp$promise$$default,\n      'allSettled': lib$rsvp$all$settled$$default,\n      'hash': lib$rsvp$hash$$default,\n      'hashSettled': lib$rsvp$hash$settled$$default,\n      'denodeify': lib$rsvp$node$$default,\n      'on': lib$rsvp$$on,\n      'off': lib$rsvp$$off,\n      'map': lib$rsvp$map$$default,\n      'filter': lib$rsvp$filter$$default,\n      'resolve': lib$rsvp$resolve$$default,\n      'reject': lib$rsvp$reject$$default,\n      'all': lib$rsvp$all$$default,\n      'rethrow': lib$rsvp$rethrow$$default,\n      'defer': lib$rsvp$defer$$default,\n      'EventTarget': lib$rsvp$events$$default,\n      'configure': lib$rsvp$config$$configure,\n      'async': lib$rsvp$$async\n    };\n\n    /* global define:true module:true window: true */\n    if (typeof define === 'function' && define['amd']) {\n      define(function() { return lib$rsvp$umd$$RSVP; });\n    } else if (typeof module !== 'undefined' && module['exports']) {\n      module['exports'] = lib$rsvp$umd$$RSVP;\n    } else if (typeof lib$rsvp$platform$$default !== 'undefined') {\n      lib$rsvp$platform$$default['RSVP'] = lib$rsvp$umd$$RSVP;\n    }\n}).call(this);\n\n"]} +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","js/app/cache.js","js/app/constructor.js","js/app/index.js","js/dom/add_categories.js","js/dom/add_files.js","js/dom/index.js","js/dom/loading_slider.js","js/dom/module_container.js","js/dom/setup/index.js","js/dom/setup/setup_dividers.js","js/dom/setup/setup_document.js","js/dom/setup/setup_files_bar.js","js/dom/setup/setup_interval.js","js/dom/setup/setup_module_container.js","js/dom/setup/setup_side_menu.js","js/dom/setup/setup_tab_container.js","js/dom/setup/setup_top_menu.js","js/dom/setup/setup_window.js","js/dom/show_algorithm.js","js/dom/show_description.js","js/dom/show_first_algorithm.js","js/dom/show_requested_algorithm.js","js/dom/show_wiki.js","js/dom/toast.js","js/dom/top_menu.js","js/editor/create.js","js/editor/executor.js","js/editor/index.js","js/index.js","js/module/data/array1d.js","js/module/data/array2d.js","js/module/data/coordinate_system.js","js/module/data/directed_graph.js","js/module/data/index.js","js/module/data/integer.js","js/module/data/undirected_graph.js","js/module/data/weighted_directed_graph.js","js/module/data/weighted_undirected_graph.js","js/module/index.js","js/module/tracer/array1d.js","js/module/tracer/array2d.js","js/module/tracer/chart.js","js/module/tracer/coordinate_system.js","js/module/tracer/directed_graph.js","js/module/tracer/index.js","js/module/tracer/log.js","js/module/tracer/tracer.js","js/module/tracer/undirected_graph.js","js/module/tracer/weighted_directed_graph.js","js/module/tracer/weighted_undirected_graph.js","js/server/ajax/get.js","js/server/ajax/get_json.js","js/server/ajax/post_json.js","js/server/ajax/request.js","js/server/helpers.js","js/server/index.js","js/server/load_algorithm.js","js/server/load_categories.js","js/server/load_file.js","js/server/load_scratch_paper.js","js/server/load_wiki.js","js/server/load_wiki_list.js","js/server/share_scratch_paper.js","js/tracer_manager/index.js","js/tracer_manager/manager.js","js/tracer_manager/util/from_json.js","js/tracer_manager/util/index.js","js/tracer_manager/util/refine_by_type.js","js/tracer_manager/util/to_json.js","js/utils/index.js","node_modules/process/browser.js","node_modules/rsvp/dist/rsvp.js"],"names":[],"mappings":"AAAA;ACAA;;SAII,C;IADF,M,MAAA,M;;;AAGF,IAAM,QAAQ;AACZ,gBAAc,EADF;AAEZ,SAAO;AAFK,CAAd;;AAKA,IAAM,iBAAiB,SAAjB,cAAiB,CAAC,IAAD,EAAU;AAC/B,MAAI,CAAC,IAAL,EAAW;AACT,UAAM,mBAAN;AACD;AACF,CAJD;;;;;AAUA,OAAO,OAAP,GAAiB;AAEf,eAFe,yBAED,IAFC,EAEK;AAClB,mBAAe,IAAf;AACA,WAAO,MAAM,KAAN,CAAY,IAAZ,CAAP;AACD,GALc;AAOf,kBAPe,4BAOE,IAPF,EAOQ,OAPR,EAOiB;AAC9B,mBAAe,IAAf;AACA,QAAI,CAAC,MAAM,KAAN,CAAY,IAAZ,CAAL,EAAwB;AACtB,YAAM,KAAN,CAAY,IAAZ,IAAoB,EAApB;AACD;AACD,WAAO,MAAM,KAAN,CAAY,IAAZ,CAAP,EAA0B,OAA1B;AACD,GAbc;AAef,iBAfe,6BAeG;AAChB,WAAO,MAAM,YAAb;AACD,GAjBc;AAmBf,iBAnBe,2BAmBC,IAnBD,EAmBO;AACpB,UAAM,YAAN,GAAqB,IAArB;AACD;AArBc,CAAjB;;;ACrBA;;AAEA,IAAM,SAAS,QAAQ,WAAR,CAAf;AACA,IAAM,gBAAgB,QAAQ,mBAAR,CAAtB;AACA,IAAM,MAAM,QAAQ,cAAR,CAAZ;;eAKI,QAAQ,uBAAR,C;;IAFF,iB,YAAA,iB;IACA,iB,YAAA,iB;;;AAGF,IAAM,QAAQ,QAAQ,SAAR,CAAd;;AAEA,IAAM,QAAQ;AACZ,aAAW,IADC;AAEZ,UAAQ,IAFI;AAGZ,iBAAe,IAHH;AAIZ,cAAY,IAJA;AAKZ,iBAAe,IALH;AAMZ,YAAU;AANE,CAAd;;AASA,IAAM,YAAY,SAAZ,SAAY,CAAC,aAAD,EAAmB;AACnC,QAAM,SAAN,GAAkB,KAAlB;AACA,QAAM,MAAN,GAAe,IAAI,MAAJ,CAAW,aAAX,CAAf;AACA,QAAM,aAAN,GAAsB,aAAtB;AACA,QAAM,UAAN,GAAmB,EAAnB;AACA,QAAM,aAAN,GAAsB,IAAtB;AACA,QAAM,QAAN,GAAiB,EAAjB;AACD,CAPD;;;;;AAYA,IAAM,MAAM,SAAN,GAAM,GAAY;;AAEtB,OAAK,YAAL,GAAoB,YAAM;AACxB,WAAO,MAAM,SAAb;AACD,GAFD;;AAIA,OAAK,YAAL,GAAoB,UAAC,OAAD,EAAa;AAC/B,UAAM,SAAN,GAAkB,OAAlB;AACA,QAAI,OAAJ,EAAa;AACX;AACD,KAFD,MAEO;AACL;AACD;AACF,GAPD;;AASA,OAAK,SAAL,GAAiB,YAAM;AACrB,WAAO,MAAM,MAAb;AACD,GAFD;;AAIA,OAAK,aAAL,GAAqB,YAAM;AACzB,WAAO,MAAM,UAAb;AACD,GAFD;;AAIA,OAAK,WAAL,GAAmB,UAAC,IAAD,EAAU;AAC3B,WAAO,MAAM,UAAN,CAAiB,IAAjB,CAAP;AACD,GAFD;;AAIA,OAAK,aAAL,GAAqB,UAAC,UAAD,EAAgB;AACnC,UAAM,UAAN,GAAmB,UAAnB;AACD,GAFD;;AAIA,OAAK,cAAL,GAAsB,UAAC,IAAD,EAAO,OAAP,EAAmB;AACvC,MAAE,MAAF,CAAS,MAAM,UAAN,CAAiB,IAAjB,CAAT,EAAiC,OAAjC;AACD,GAFD;;AAIA,OAAK,gBAAL,GAAwB,YAAM;AAC5B,WAAO,MAAM,aAAb;AACD,GAFD;;AAIA,OAAK,gBAAL,GAAwB,YAAM;AAC5B,WAAO,MAAM,aAAb;AACD,GAFD;;AAIA,OAAK,gBAAL,GAAwB,UAAC,aAAD,EAAmB;AACzC,UAAM,aAAN,GAAsB,aAAtB;AACD,GAFD;;AAIA,OAAK,WAAL,GAAmB,YAAM;AACvB,WAAO,MAAM,QAAb;AACD,GAFD;;AAIA,OAAK,WAAL,GAAmB,UAAC,QAAD,EAAc;AAC/B,UAAM,QAAN,GAAiB,QAAjB;AACD,GAFD;;AAIA,OAAK,OAAL,GAAe,UAAC,IAAD,EAAU;AACvB,WAAO,CAAC,MAAM,QAAN,CAAe,OAAf,CAAuB,IAAvB,CAAR;AACD,GAFD;;AAIA,MAAM,gBAAgB,cAAc,IAAd,EAAtB;;AAEA,YAAU,aAAV;AACA,MAAI,KAAJ,CAAU,aAAV;AAED,CAhED;;AAkEA,IAAI,SAAJ,GAAgB,KAAhB;;AAEA,OAAO,OAAP,GAAiB,GAAjB;;;ACtGA;;;;;;;AAMA,OAAO,OAAP,GAAiB,EAAjB;;;ACNA;;AAEA,IAAM,MAAM,QAAQ,QAAR,CAAZ;AACA,IAAM,SAAS,QAAQ,WAAR,CAAf;AACA,IAAM,gBAAgB,QAAQ,kBAAR,CAAtB;;SAII,C;IADF,I,MAAA,I;;;AAGF,IAAM,kBAAkB,SAAlB,eAAkB,CAAC,QAAD,EAAW,OAAX,EAAoB,SAApB,EAAkC;AACxD,SAAO,EAAE,yBAAF,EACJ,MADI,CACG,QAAQ,SAAR,CADH,EAEJ,IAFI,CAEC,gBAFD,EAEmB,SAFnB,EAGJ,IAHI,CAGC,eAHD,EAGkB,QAHlB,EAIJ,KAJI,CAIE,YAAY;AACjB,WAAO,aAAP,CAAqB,QAArB,EAA+B,SAA/B,EAA0C,IAA1C,CAA+C,UAAC,IAAD,EAAU;AACvD,oBAAc,QAAd,EAAwB,SAAxB,EAAmC,IAAnC;AACD,KAFD;AAGD,GARI,CAAP;;AAUA,IAAE,OAAF,EAAW,MAAX,CAAkB,UAAlB;AACD,CAZD;;AAcA,IAAM,mBAAmB,SAAnB,gBAAmB,CAAC,QAAD,EAAc;AAAA,yBAKjC,IAAI,WAAJ,CAAgB,QAAhB,CALiC;;AAAA,MAG7B,YAH6B,oBAGnC,IAHmC;AAAA,MAI7B,eAJ6B,oBAInC,IAJmC;;;AAOrC,MAAM,YAAY,EAAE,2BAAF,EACf,MADe,CACR,qCADQ,EAEf,MAFe,CAER,YAFQ,EAGf,IAHe,CAGV,eAHU,EAGO,QAHP,CAAlB;;AAKA,YAAU,KAAV,CAAgB,YAAY;AAC1B,QAAM,QAAQ,EAAE,IAAF,CAAd;AACA,UAAM,WAAN,CAAkB,MAAlB;AACA,UAAM,IAAN,GAAa,WAAb,CAAyB,UAAzB;AACA,UAAM,IAAN,CAAW,MAAX,EAAmB,WAAnB,CAA+B,8BAA/B;AACD,GALD;;AAOA,MAAM,cAAc,EAAE,mCAAF,CAApB;AACA,IAAE,OAAF,EAAW,MAAX,CAAkB,SAAlB,EAA6B,MAA7B,CAAoC,WAApC;;AAEA,OAAK,eAAL,EAAsB,UAAC,SAAD,EAAe;AACnC,QAAM,aAAa,gBAAgB,QAAhB,EAA0B,eAA1B,EAA2C,SAA3C,CAAnB;AACA,gBAAY,MAAZ,CAAmB,UAAnB;AACD,GAHD;AAID,CA1BD;;AA4BA,OAAO,OAAP,GAAiB,YAAM;AACrB,OAAK,IAAI,aAAJ,EAAL,EAA0B,gBAA1B;AACD,CAFD;;;ACpDA;;AAEA,IAAM,SAAS,QAAQ,WAAR,CAAf;;SAII,C;IADF,I,MAAA,I;;;AAGF,IAAM,eAAe,SAAf,YAAe,CAAC,QAAD,EAAW,SAAX,EAAsB,IAAtB,EAA4B,WAA5B,EAA4C;AAC/D,MAAI,QAAQ,EAAE,UAAF,EACT,MADS,CACF,IADE,EAET,IAFS,CAEJ,WAFI,EAES,IAFT,EAGT,KAHS,CAGH,YAAY;AACjB,WAAO,QAAP,CAAgB,QAAhB,EAA0B,SAA1B,EAAqC,IAArC,EAA2C,WAA3C;AACA,MAAE,gCAAF,EAAoC,WAApC,CAAgD,QAAhD;AACA,MAAE,IAAF,EAAQ,QAAR,CAAiB,QAAjB;AACD,GAPS,CAAZ;AAQA,IAAE,uBAAF,EAA2B,MAA3B,CAAkC,KAAlC;AACA,SAAO,KAAP;AACD,CAXD;;AAaA,OAAO,OAAP,GAAiB,UAAC,QAAD,EAAW,SAAX,EAAsB,KAAtB,EAA6B,aAA7B,EAA+C;AAC9D,IAAE,uBAAF,EAA2B,KAA3B;;AAEA,OAAK,KAAL,EAAY,UAAC,IAAD,EAAO,WAAP,EAAuB;AACjC,QAAI,QAAQ,aAAa,QAAb,EAAuB,SAAvB,EAAkC,IAAlC,EAAwC,WAAxC,CAAZ;AACA,QAAI,iBAAiB,iBAAiB,IAAtC,EAA4C,MAAM,KAAN;AAC7C,GAHD;;AAKA,MAAI,CAAC,aAAL,EAAoB,EAAE,gCAAF,EAAoC,KAApC,GAA4C,KAA5C;AACpB,IAAE,uBAAF,EAA2B,MAA3B;AACD,CAVD;;;ACrBA;;AAEA,IAAM,gBAAgB,QAAQ,kBAAR,CAAtB;AACA,IAAM,gBAAgB,QAAQ,kBAAR,CAAtB;AACA,IAAM,kBAAkB,QAAQ,oBAAR,CAAxB;AACA,IAAM,WAAW,QAAQ,aAAR,CAAjB;AACA,IAAM,qBAAqB,QAAQ,wBAAR,CAA3B;AACA,IAAM,yBAAyB,QAAQ,4BAAR,CAA/B;AACA,IAAM,WAAW,QAAQ,aAAR,CAAjB;;AAEA,OAAO,OAAP,GAAiB;AACf,8BADe;AAEf,8BAFe;AAGf,kCAHe;AAIf,oBAJe;AAKf,wCALe;AAMf,gDANe;AAOf;AAPe,CAAjB;;;ACVA;;AAEA,IAAM,oBAAoB,SAApB,iBAAoB,GAAM;AAC9B,IAAE,iBAAF,EAAqB,WAArB,CAAiC,QAAjC;AACD,CAFD;;AAIA,IAAM,oBAAoB,SAApB,iBAAoB,GAAM;AAC9B,IAAE,iBAAF,EAAqB,QAArB,CAA8B,QAA9B;AACD,CAFD;;AAIA,OAAO,OAAP,GAAiB;AACf,sCADe;AAEf;AAFe,CAAjB;;;ACVA;;AAEA,IAAM,SAAS,SAAT,MAAS,GAAM;AACnB,MAAM,aAAa,EAAE,kCAAF,CAAnB;AACA,IAAE,mBAAF,EAAuB,MAAvB,CAA8B,UAA9B;AACA,SAAO,UAAP;AACD,CAJD;;AAMA,OAAO,OAAP,GAAiB;AACf;AADe,CAAjB;;;ACRA;;AAEA,IAAM,gBAAgB,QAAQ,kBAAR,CAAtB;AACA,IAAM,gBAAgB,QAAQ,kBAAR,CAAtB;AACA,IAAM,gBAAgB,QAAQ,mBAAR,CAAtB;AACA,IAAM,gBAAgB,QAAQ,kBAAR,CAAtB;AACA,IAAM,uBAAuB,QAAQ,0BAAR,CAA7B;AACA,IAAM,oBAAoB,QAAQ,uBAAR,CAA1B;AACA,IAAM,gBAAgB,QAAQ,mBAAR,CAAtB;AACA,IAAM,eAAe,QAAQ,kBAAR,CAArB;AACA,IAAM,cAAc,QAAQ,gBAAR,CAApB;;;;;AAKA,IAAM,QAAQ,SAAR,KAAQ,GAAM;;AAElB,IAAE,YAAF,EAAgB,KAAhB,CAAsB,UAAC,CAAD,EAAO;AAC3B,MAAE,eAAF;AACD,GAFD;;;AAKA;;;AAGA;;;AAGA;;;AAGA;;;AAGA;;;AAGA;;;AAGA;;;AAGA;;;AAGA;AAED,CAjCD;;AAmCA,OAAO,OAAP,GAAiB;AACf;AADe,CAAjB;;;AClDA;;;;AAEA,IAAM,MAAM,QAAQ,WAAR,CAAZ;;AAEA,IAAM,kBAAkB,SAAlB,eAAkB,CAAC,OAAD,EAAa;AAAA,gCACC,OADD;;AAAA,MAC5B,QAD4B;AAAA,MAClB,MADkB;AAAA,MACV,OADU;;AAEnC,MAAM,UAAU,OAAO,MAAP,EAAhB;AACA,MAAM,YAAY,CAAlB;;AAEA,MAAM,WAAW,EAAE,uBAAF,CAAjB;;AAEA,MAAI,WAAW,KAAf;AACA,MAAI,QAAJ,EAAc;AAAA;AACZ,eAAS,QAAT,CAAkB,UAAlB;;AAEA,UAAI,QAAQ,CAAC,SAAD,GAAa,CAAzB;AACA,eAAS,GAAT,CAAa;AACX,aAAK,CADM;AAEX,gBAAQ,CAFG;AAGX,cAAM,KAHK;AAIX,eAAO;AAJI,OAAb;;AAOA,UAAI,UAAJ;AACA,eAAS,SAAT,CAAmB,gBAEb;AAAA,YADJ,KACI,QADJ,KACI;;AACJ,YAAI,KAAJ;AACA,mBAAW,IAAX;AACD,OALD;;AAOA,QAAE,QAAF,EAAY,SAAZ,CAAsB,iBAEhB;AAAA,YADJ,KACI,SADJ,KACI;;AACJ,YAAI,QAAJ,EAAc;AACZ,cAAM,WAAW,QAAQ,QAAR,GAAmB,IAAnB,GAA0B,KAA1B,GAAkC,CAAnD;AACA,cAAI,UAAU,WAAW,QAAQ,KAAR,EAAX,GAA6B,GAA3C;AACA,oBAAU,KAAK,GAAL,CAAS,EAAT,EAAa,KAAK,GAAL,CAAS,EAAT,EAAa,OAAb,CAAb,CAAV;AACA,iBAAO,GAAP,CAAW,OAAX,EAAqB,MAAM,OAAP,GAAkB,GAAtC;AACA,kBAAQ,GAAR,CAAY,MAAZ,EAAoB,UAAU,GAA9B;AACA,cAAI,KAAJ;AACA,cAAI,gBAAJ,GAAuB,MAAvB;AACA,YAAE,uBAAF,EAA2B,MAA3B;AACD;AACF,OAbD;;AAeA,QAAE,QAAF,EAAY,OAAZ,CAAoB,UAAS,CAAT,EAAY;AAC9B,mBAAW,KAAX;AACD,OAFD;AAlCY;AAsCb,GAtCD,MAsCO;AAAA;;AAEL,eAAS,QAAT,CAAkB,YAAlB;AACA,UAAM,OAAO,CAAC,SAAD,GAAa,CAA1B;AACA,eAAS,GAAT,CAAa;AACX,aAAK,IADM;AAEX,gBAAQ,SAFG;AAGX,cAAM,CAHK;AAIX,eAAO;AAJI,OAAb;;AAOA,UAAI,UAAJ;AACA,eAAS,SAAT,CAAmB,iBAEhB;AAAA,YADD,KACC,SADD,KACC;;AACD,YAAI,KAAJ;AACA,mBAAW,IAAX;AACD,OALD;;AAOA,QAAE,QAAF,EAAY,SAAZ,CAAsB,iBAEnB;AAAA,YADD,KACC,SADD,KACC;;AACD,YAAI,QAAJ,EAAc;AACZ,cAAM,UAAU,QAAQ,QAAR,GAAmB,GAAnB,GAAyB,KAAzB,GAAiC,CAAjD;AACA,cAAI,UAAU,UAAU,QAAQ,MAAR,EAAV,GAA6B,GAA3C;AACA,oBAAU,KAAK,GAAL,CAAS,EAAT,EAAa,KAAK,GAAL,CAAS,EAAT,EAAa,OAAb,CAAb,CAAV;AACA,iBAAO,GAAP,CAAW,QAAX,EAAsB,MAAM,OAAP,GAAkB,GAAvC;AACA,kBAAQ,GAAR,CAAY,KAAZ,EAAmB,UAAU,GAA7B;AACA,cAAI,KAAJ;AACA,cAAI,gBAAJ,GAAuB,MAAvB;AACD;AACF,OAZD;;AAcA,QAAE,QAAF,EAAY,OAAZ,CAAoB,UAAS,CAAT,EAAY;AAC9B,mBAAW,KAAX;AACD,OAFD;AAjCK;AAoCN;;AAED,UAAQ,MAAR,CAAe,QAAf;AACD,CArFD;;AAuFA,OAAO,OAAP,GAAiB,YAAM;AACrB,MAAM,WAAW,CACf,CAAC,GAAD,EAAM,EAAE,WAAF,CAAN,EAAsB,EAAE,YAAF,CAAtB,CADe,EAEf,CAAC,GAAD,EAAM,EAAE,mBAAF,CAAN,EAA8B,EAAE,mBAAF,CAA9B,CAFe,EAGf,CAAC,GAAD,EAAM,EAAE,iBAAF,CAAN,EAA4B,EAAE,iBAAF,CAA5B,CAHe,CAAjB;AAKA,OAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,SAAS,MAA7B,EAAqC,GAArC,EAA0C;AACxC,oBAAgB,SAAS,CAAT,CAAhB;AACD;AACF,CATD;;;AC3FA;;AAEA,IAAM,MAAM,QAAQ,WAAR,CAAZ;;AAEA,OAAO,OAAP,GAAiB,YAAM;AACrB,IAAE,QAAF,EAAY,EAAZ,CAAe,OAAf,EAAwB,GAAxB,EAA6B,UAAU,CAAV,EAAa;AACxC,QAAM,OAAO,EAAE,IAAF,EAAQ,IAAR,CAAa,MAAb,CAAb;AACA,QAAI,mBAAmB,IAAnB,CAAwB,IAAxB,CAAJ,EAAmC;AACjC,QAAE,cAAF;AACA,UAAI,CAAC,OAAO,IAAP,CAAY,IAAZ,EAAkB,QAAlB,CAAL,EAAkC;AAChC,cAAM,mCAAN;AACD;AACF;AACF,GARD;;AAUA,IAAE,QAAF,EAAY,OAAZ,CAAoB,UAAU,CAAV,EAAa;AAC/B,QAAI,gBAAJ,GAAuB,OAAvB,CAA+B,SAA/B,EAA0C,CAA1C;AACD,GAFD;AAGD,CAdD;;;ACJA;;AAEA,IAAM,mBAAmB,SAAnB,gBAAmB,CAAC,CAAD,EAAI,CAAJ;AAAA,SAAU,IAAK,IAAI,CAAnB;AAAA,CAAzB;;AAEA,OAAO,OAAP,GAAiB,YAAM;;AAErB,IAAE,wBAAF,EAA4B,KAA5B,CAAkC,YAAM;AACtC,QAAM,WAAW,EAAE,uBAAF,CAAjB;AACA,QAAM,YAAY,SAAS,KAAT,EAAlB;AACA,QAAM,aAAa,SAAS,UAAT,EAAnB;;AAEA,MAAE,SAAS,QAAT,CAAkB,QAAlB,EAA4B,GAA5B,GAAkC,OAAlC,EAAF,EAA+C,IAA/C,CAAoD,YAAW;AAC7D,UAAM,OAAO,EAAE,IAAF,EAAQ,QAAR,GAAmB,IAAhC;AACA,UAAM,QAAQ,OAAO,EAAE,IAAF,EAAQ,UAAR,EAArB;AACA,UAAI,IAAI,IAAR,EAAc;AACZ,iBAAS,UAAT,CAAoB,aAAa,KAAb,GAAqB,SAAzC;AACA,eAAO,KAAP;AACD;AACF,KAPD;AAQD,GAbD;;AAeA,IAAE,yBAAF,EAA6B,KAA7B,CAAmC,YAAM;AACvC,QAAM,WAAW,EAAE,uBAAF,CAAjB;AACA,QAAM,YAAY,SAAS,KAAT,EAAlB;AACA,QAAM,aAAa,SAAS,UAAT,EAAnB;;AAEA,aAAS,QAAT,CAAkB,QAAlB,EAA4B,IAA5B,CAAiC,YAAW;AAC1C,UAAM,OAAO,EAAE,IAAF,EAAQ,QAAR,GAAmB,IAAhC;AACA,UAAM,QAAQ,OAAO,EAAE,IAAF,EAAQ,UAAR,EAArB;AACA,UAAI,YAAY,KAAhB,EAAuB;AACrB,iBAAS,UAAT,CAAoB,aAAa,IAAjC;AACA,eAAO,KAAP;AACD;AACF,KAPD;AAQD,GAbD;;AAeA,IAAE,uBAAF,EAA2B,MAA3B,CAAkC,YAAW;;AAE3C,QAAM,WAAW,EAAE,uBAAF,CAAjB;AACA,QAAM,YAAY,SAAS,KAAT,EAAlB;AACA,QAAM,QAAQ,SAAS,QAAT,CAAkB,oBAAlB,CAAd;AACA,QAAM,SAAS,SAAS,QAAT,CAAkB,mBAAlB,CAAf;AACA,QAAM,OAAO,MAAM,QAAN,GAAiB,IAA9B;AACA,QAAM,QAAQ,OAAO,QAAP,GAAkB,IAAlB,GAAyB,OAAO,UAAP,EAAvC;;AAEA,QAAI,iBAAiB,CAAjB,EAAoB,IAApB,KAA6B,iBAAiB,SAAjB,EAA4B,KAA5B,CAAjC,EAAqE;AACnE,UAAM,aAAa,SAAS,UAAT,EAAnB;AACA,eAAS,UAAT,CAAoB,aAAa,SAAb,GAAyB,KAA7C;AACA;AACD;;AAED,QAAM,SAAS,iBAAiB,CAAjB,EAAoB,IAApB,CAAf;AACA,QAAM,UAAU,iBAAiB,KAAjB,EAAwB,SAAxB,CAAhB;AACA,aAAS,WAAT,CAAqB,aAArB,EAAoC,MAApC;AACA,aAAS,WAAT,CAAqB,cAArB,EAAqC,OAArC;AACA,MAAE,wBAAF,EAA4B,IAA5B,CAAiC,UAAjC,EAA6C,CAAC,MAA9C;AACA,MAAE,yBAAF,EAA6B,IAA7B,CAAkC,UAAlC,EAA8C,CAAC,OAA/C;AACD,GArBD;AAsBD,CAtDD;;;ACJA;;;;AAEA,IAAM,MAAM,QAAQ,WAAR,CAAZ;AACA,IAAM,QAAQ,QAAQ,UAAR,CAAd;;IAGE,U,GACE,M,CADF,U;;;AAGF,IAAM,cAAc,GAApB;AACA,IAAM,cAAc,EAApB;AACA,IAAM,gBAAgB,GAAtB;AACA,IAAM,eAAe,GAArB;;AAEA,IAAM,YAAY,SAAZ,SAAY,CAAC,GAAD,EAAS;;AAGzB,MAAI,iBAAJ;AACA,MAAI,gBAAJ;AACA,MAAI,MAAM,WAAV,EAAuB;AACrB,eAAW,WAAX;AACA,+BAAyB,GAAzB,gEAAuF,WAAvF;AACD,GAHD,MAGO,IAAI,MAAM,WAAV,EAAuB;AAC5B,eAAW,WAAX;AACA,+BAAyB,GAAzB,iEAAwF,WAAxF;AACD,GAHM,MAGA;AACL,eAAW,GAAX;AACA,4CAAsC,GAAtC;AACD;;AAED,SAAO,CAAC,QAAD,EAAW,OAAX,CAAP;AACD,CAjBD;;AAmBA,OAAO,OAAP,GAAiB,YAAM;;AAErB,MAAM,YAAY,EAAE,WAAF,CAAlB;AACA,YAAU,GAAV,CAAc,aAAd;AACA,YAAU,IAAV,CAAe;AACb,SAAK,WADQ;AAEb,SAAK,WAFQ;AAGb,UAAM;AAHO,GAAf;;AAMA,IAAE,WAAF,EAAe,EAAf,CAAkB,QAAlB,EAA4B,YAAW;AACrC,QAAM,gBAAgB,IAAI,gBAAJ,EAAtB;;AADqC,qBAEV,UAAU,WAAW,EAAE,IAAF,EAAQ,GAAR,EAAX,CAAV,CAFU;;AAAA;;AAAA,QAE9B,OAF8B;AAAA,QAErB,OAFqB;;;AAIrC,MAAE,IAAF,EAAQ,GAAR,CAAY,OAAZ;AACA,kBAAc,QAAd,GAAyB,UAAU,IAAnC;AACA,UAAM,aAAN,CAAoB,OAApB;AACD,GAPD;AAQD,CAlBD;;;ACjCA;;AAEA,IAAM,MAAM,QAAQ,WAAR,CAAZ;;AAEA,OAAO,OAAP,GAAiB,YAAM;;AAErB,MAAM,oBAAoB,EAAE,mBAAF,CAA1B;;AAEA,oBAAkB,EAAlB,CAAqB,WAArB,EAAkC,iBAAlC,EAAqD,UAAS,CAAT,EAAY;AAC/D,QAAI,gBAAJ,GAAuB,SAAvB,CAAiC,IAAjC,EAAuC,SAAvC,CAAiD,CAAjD;AACD,GAFD;;AAIA,oBAAkB,EAAlB,CAAqB,WAArB,EAAkC,iBAAlC,EAAqD,UAAS,CAAT,EAAY;AAC/D,QAAI,gBAAJ,GAAuB,SAAvB,CAAiC,IAAjC,EAAuC,SAAvC,CAAiD,CAAjD;AACD,GAFD;;AAIA,oBAAkB,EAAlB,CAAqB,2BAArB,EAAkD,iBAAlD,EAAqE,UAAS,CAAT,EAAY;AAC/E,QAAI,gBAAJ,GAAuB,SAAvB,CAAiC,IAAjC,EAAuC,UAAvC,CAAkD,CAAlD;AACD,GAFD;AAGD,CAfD;;;ACJA;;AAEA,IAAM,MAAM,QAAQ,WAAR,CAAZ;AACA,IAAM,SAAS,QAAQ,cAAR,CAAf;AACA,IAAM,gBAAgB,QAAQ,mBAAR,CAAtB;;AAEA,IAAI,yBAAJ;;AAEA,OAAO,OAAP,GAAiB,YAAM;AACrB,IAAE,aAAF,EAAiB,KAAjB,CAAuB,YAAM;AAC3B,QAAM,YAAY,EAAE,WAAF,CAAlB;AACA,QAAM,aAAa,EAAE,YAAF,CAAnB;;AAEA,cAAU,WAAV,CAAsB,QAAtB;AACA,MAAE,eAAF,EAAmB,WAAnB,CAA+B,2BAA/B;;AAEA,QAAI,UAAU,QAAV,CAAmB,QAAnB,CAAJ,EAAkC;AAChC,gBAAU,GAAV,CAAc,OAAd,EAAwB,MAAM,gBAAP,GAA2B,GAAlD;AACA,iBAAW,GAAX,CAAe,MAAf,EAAuB,mBAAmB,GAA1C;AAED,KAJD,MAIO;AACL,yBAAmB,WAAW,QAAX,GAAsB,IAAtB,GAA6B,EAAE,MAAF,EAAU,KAAV,EAA7B,GAAiD,GAApE;AACA,gBAAU,GAAV,CAAc,OAAd,EAAuB,CAAvB;AACA,iBAAW,GAAX,CAAe,MAAf,EAAuB,CAAvB;AACD;;AAED,QAAI,gBAAJ,GAAuB,MAAvB;AACD,GAlBD;;AAoBA,IAAE,gBAAF,EAAoB,KAApB,CAA0B,YAAY;AACpC,MAAE,UAAF,EAAc,KAAd;AACD,GAFD;;AAIA,IAAE,aAAF,EAAiB,KAAjB,CAAuB,YAAM;AAC3B,MAAE,yBAAF,EAA6B,WAA7B,CAAyC,UAAzC;AACD,GAFD;;AAIA,IAAE,gBAAF,EAAoB,KAApB,CAA0B,YAAM;AAC9B,QAAM,WAAW,SAAjB;AACA,QAAM,YAAY,IAAI,gBAAJ,EAAlB;AACA,WAAO,aAAP,CAAqB,QAArB,EAA+B,SAA/B,EAA0C,IAA1C,CAA+C,UAAC,IAAD,EAAU;AACvD,oBAAc,QAAd,EAAwB,SAAxB,EAAmC,IAAnC;AACD,KAFD;AAGD,GAND;AAOD,CApCD;;;ACRA;;AAEA,OAAO,OAAP,GAAiB,YAAM;AACrB,IAAE,mBAAF,EAAuB,KAAvB,CAA6B,YAAY;AACvC,MAAE,mBAAF,EAAuB,WAAvB,CAAmC,QAAnC;AACA,MAAE,uBAAF,EAA2B,WAA3B,CAAuC,QAAvC;AACA,MAAE,IAAF,EAAQ,QAAR,CAAiB,QAAjB;AACA,MAAE,EAAE,IAAF,EAAQ,IAAR,CAAa,aAAb,CAAF,EAA+B,QAA/B,CAAwC,QAAxC;AACD,GALD;AAMD,CAPD;;;ACFA;;AAEA,IAAM,MAAM,QAAQ,WAAR,CAAZ;AACA,IAAM,SAAS,QAAQ,cAAR,CAAf;AACA,IAAM,QAAQ,QAAQ,UAAR,CAAd;AACA,IAAM,UAAU,QAAQ,aAAR,CAAhB;;AAEA,OAAO,OAAP,GAAiB,YAAM;;;AAGrB,IAAE,SAAF,EAAa,OAAb,CAAqB,YAAY;AAC/B,MAAE,IAAF,EAAQ,MAAR;AACD,GAFD;;AAIA,IAAE,YAAF,EAAgB,KAAhB,CAAsB,YAAY;;AAEhC,QAAM,QAAQ,EAAE,IAAF,EAAQ,IAAR,CAAa,WAAb,CAAd;AACA,UAAM,QAAN,CAAe,wBAAf;;AAEA,WAAO,iBAAP,GAA2B,IAA3B,CAAgC,UAAC,GAAD,EAAS;AACvC,YAAM,WAAN,CAAkB,wBAAlB;AACA,QAAE,SAAF,EAAa,WAAb,CAAyB,UAAzB;AACA,QAAE,SAAF,EAAa,GAAb,CAAiB,GAAjB;AACA,YAAM,aAAN,CAAoB,4BAApB;AACD,KALD;AAMD,GAXD;;;;AAeA,MAAM,UAAU,EAAE,UAAF,CAAhB;AACA,MAAM,YAAY,EAAE,YAAF,CAAlB;AACA,MAAM,YAAY,EAAE,YAAF,CAAlB;AACA,MAAM,WAAW,EAAE,WAAF,CAAjB;AACA,MAAM,WAAW,EAAE,WAAF,CAAjB;;;AAGA,UAAQ,kBAAR;;AAEA,UAAQ,KAAR,CAAc,YAAM;AAClB,cAAU,KAAV;AACA,cAAU,WAAV,CAAsB,QAAtB;AACA,YAAQ,QAAR,CAAiB,QAAjB;AACA,YAAQ,iBAAR;AACA,QAAI,MAAM,IAAI,SAAJ,GAAgB,OAAhB,EAAV;AACA,QAAI,GAAJ,EAAS;AACP,cAAQ,KAAR,CAAc,GAAd;AACA,YAAM,cAAN,CAAqB,GAArB;AACA,cAAQ,mBAAR;AACD;AACF,GAXD;;AAaA,YAAU,KAAV,CAAgB,YAAM;AACpB,YAAQ,WAAR,CAAoB,QAApB;AACA,cAAU,WAAV,CAAsB,QAAtB;AACA,QAAI,IAAI,gBAAJ,GAAuB,OAAvB,EAAJ,EAAsC;AACpC,UAAI,gBAAJ,GAAuB,UAAvB;AACD,KAFD,MAEO;AACL,UAAI,gBAAJ,GAAuB,SAAvB;AACD;AACF,GARD;;AAUA,WAAS,KAAT,CAAe,YAAM;AACnB,YAAQ,WAAR,CAAoB,QAApB;AACA,cAAU,QAAV,CAAmB,QAAnB;AACA,QAAI,gBAAJ,GAAuB,SAAvB;AACA,QAAI,gBAAJ,GAAuB,QAAvB;AACD,GALD;;AAOA,WAAS,KAAT,CAAe,YAAM;AACnB,YAAQ,WAAR,CAAoB,QAApB;AACA,cAAU,QAAV,CAAmB,QAAnB;AACA,QAAI,gBAAJ,GAAuB,SAAvB;AACA,QAAI,gBAAJ,GAAuB,QAAvB;AACD,GALD;AAOD,CApED;;;ACPA;;AAEA,IAAM,MAAM,QAAQ,WAAR,CAAZ;;AAEA,OAAO,OAAP,GAAiB,YAAW;AAC1B,IAAE,MAAF,EAAU,MAAV,CAAiB,YAAW;AAC1B,QAAI,gBAAJ,GAAuB,MAAvB;AACD,GAFD;AAGD,CAJD;;;ACJA;;AAEA,IAAM,MAAM,QAAQ,QAAR,CAAZ;;eAII,QAAQ,UAAR,C;;IADF,c,YAAA,c;;;AAGF,IAAM,kBAAkB,QAAQ,oBAAR,CAAxB;AACA,IAAM,WAAW,QAAQ,aAAR,CAAjB;;AAEA,OAAO,OAAP,GAAiB,UAAC,QAAD,EAAW,SAAX,EAAsB,IAAtB,EAA4B,aAA5B,EAA8C;AAC7D,MAAI,cAAJ;AACA,MAAI,sBAAJ;AACA,MAAI,uBAAJ;;AAEA,MAAI,eAAe,QAAf,CAAJ,EAA8B;AAC5B,YAAQ,EAAE,gBAAF,CAAR;AACA,oBAAgB,eAAhB;AACA,qBAAiB,YAAY,QAAZ,GAAuB,WAAxC;AACD,GAJD,MAIO;AACL,YAAQ,uBAAqB,QAArB,2BAAmD,SAAnD,QAAR;AACA,QAAM,cAAc,IAAI,WAAJ,CAAgB,QAAhB,CAApB;AACA,oBAAgB,YAAY,IAA5B;AACA,qBAAiB,YAAY,IAAZ,CAAiB,SAAjB,CAAjB;AACD;;AAED,IAAE,kBAAF,EAAsB,WAAtB,CAAkC,QAAlC;AACA,QAAM,QAAN,CAAe,QAAf;;AAEA,IAAE,WAAF,EAAe,IAAf,CAAoB,aAApB;AACA,IAAE,YAAF,EAAgB,IAAhB,CAAqB,cAArB;AACA,IAAE,sBAAF,EAA0B,KAA1B;AACA,IAAE,uBAAF,EAA2B,KAA3B;AACA,IAAE,cAAF,EAAkB,IAAlB,CAAuB,EAAvB;;AAEA,MAAI,eAAJ,CAAoB,IAApB;AACA,MAAI,SAAJ,GAAgB,YAAhB;;AA1B6D,MA6B3D,KA7B2D,GA8BzD,IA9ByD,CA6B3D,KA7B2D;;;AAgC7D,SAAO,KAAK,KAAZ;;AAEA,kBAAgB,IAAhB;AACA,WAAS,QAAT,EAAmB,SAAnB,EAA8B,KAA9B,EAAqC,aAArC;AACD,CApCD;;;ACXA;;;;IAGE,O,GACE,K,CADF,O;SAKE,C;IADF,I,MAAA,I;;;AAGF,OAAO,OAAP,GAAiB,UAAC,IAAD,EAAU;AACzB,MAAM,aAAa,EAAE,sBAAF,CAAnB;AACA,aAAW,KAAX;;AAEA,OAAK,IAAL,EAAW,UAAC,GAAD,EAAM,KAAN,EAAgB;;AAEzB,QAAI,GAAJ,EAAS;AACP,iBAAW,MAAX,CAAkB,EAAE,MAAF,EAAU,IAAV,CAAe,GAAf,CAAlB;AACD;;AAED,QAAI,OAAO,KAAP,KAAiB,QAArB,EAA+B;AAC7B,iBAAW,MAAX,CAAkB,EAAE,KAAF,EAAS,IAAT,CAAc,KAAd,CAAlB;AAED,KAHD,MAGO,IAAI,QAAQ,KAAR,CAAJ,EAAoB;AAAA;;AAEzB,YAAM,MAAM,EAAE,2BAAF,CAAZ;AACA,mBAAW,MAAX,CAAkB,GAAlB;;AAEA,cAAM,OAAN,CAAc,UAAC,EAAD,EAAQ;AACpB,cAAI,MAAJ,CAAW,EAAE,MAAF,EAAU,IAAV,CAAe,EAAf,CAAX;AACD,SAFD;AALyB;AAS1B,KATM,MASA,IAAI,QAAO,KAAP,yCAAO,KAAP,OAAiB,QAArB,EAA+B;AAAA;;AAEpC,YAAM,MAAM,EAAE,2BAAF,CAAZ;AACA,mBAAW,MAAX,CAAkB,GAAlB;;AAEA,aAAK,KAAL,EAAY,UAAC,IAAD,EAAU;AACpB,cAAM,WAAW,EAAE,0BAAF,CAAjB;AACA,cAAM,QAAQ,EAAE,gCAAF,EAAoC,IAApC,CAA4C,IAA5C,QAAd;AACA,cAAM,SAAS,EAAE,iCAAF,EAAqC,IAArC,MAA6C,MAAM,IAAN,CAA7C,CAAf;;AAEA,mBAAS,MAAT,CAAgB,KAAhB,EAAuB,MAAvB,CAA8B,MAA9B;;AAEA,cAAI,MAAJ,CAAW,EAAE,MAAF,EAAU,MAAV,CAAiB,QAAjB,CAAX;AACD,SARD;AALoC;AAcrC;AACF,GAjCD;AAkCD,CAtCD;;;ACVA;;;;AAGA,OAAO,OAAP,GAAiB,YAAM;AACrB,IAAE,iBAAF,EAAqB,KAArB,GAA6B,KAA7B;AACA,IAAE,yCAAF,EAA6C,KAA7C,GAAqD,KAArD;AACD,CAHD;;;ACHA;;AAEA,IAAM,SAAS,QAAQ,WAAR,CAAf;AACA,IAAM,gBAAgB,QAAQ,kBAAR,CAAtB;;AAEA,OAAO,OAAP,GAAiB,UAAC,QAAD,EAAW,SAAX,EAAsB,IAAtB,EAA+B;AAC9C,kCAA8B,QAA9B,SAA4C,KAA5C;AACA,SAAO,aAAP,CAAqB,QAArB,EAA+B,SAA/B,EAA0C,IAA1C,CAA+C,UAAC,IAAD,EAAU;AACvD,kBAAc,QAAd,EAAwB,SAAxB,EAAmC,IAAnC,EAAyC,IAAzC;AACD,GAFD;AAGD,CALD;;;ACLA;;AAEA,IAAM,MAAM,QAAQ,QAAR,CAAZ;AACA,IAAM,SAAS,QAAQ,WAAR,CAAf;AACA,IAAM,YAAY,IAAI,SAAS,SAAb,CAAuB,EAAC,QAAQ,IAAT,EAAvB,CAAlB;;AAEA,OAAO,OAAP,GAAiB,UAAC,IAAD,EAAU;AACzB,SAAO,QAAP,CAAgB,IAAhB,EAAsB,IAAtB,CAA2B,UAAC,IAAD,EAAU;AACnC,MAAE,qBAAF,EAAyB,IAAzB,CAA8B,UAAU,QAAV,OAAuB,IAAvB,UAAgC,IAAhC,CAA9B;AACA,MAAE,UAAF,EAAc,SAAd,CAAwB,CAAxB;AACA,MAAE,uBAAF,EAA2B,KAA3B,CAAiC,UAAU,CAAV,EAAa;AAC5C,UAAM,OAAO,EAAE,IAAF,EAAQ,IAAR,CAAa,MAAb,CAAb;AACA,UAAI,IAAI,OAAJ,CAAY,IAAZ,CAAJ,EAAuB;AACrB,UAAE,cAAF;AACA,eAAO,OAAP,CAAe,IAAf;AACD;AACF,KAND;AAOD,GAVD;AAWD,CAZD;;;ACNA;;AAEA,IAAM,YAAY,SAAZ,SAAY,CAAC,IAAD,EAAO,IAAP,EAAgB;AAChC,MAAM,SAAS,yBAAuB,IAAvB,SAAiC,MAAjC,CAAwC,IAAxC,CAAf;;AAEA,IAAE,kBAAF,EAAsB,MAAtB,CAA6B,MAA7B;AACA,aAAW,YAAM;AACf,WAAO,OAAP,CAAe,YAAM;AACnB,aAAO,MAAP;AACD,KAFD;AAGD,GAJD,EAIG,IAJH;AAKD,CATD;;AAWA,IAAM,iBAAiB,SAAjB,cAAiB,CAAC,GAAD,EAAS;AAC9B,YAAU,GAAV,EAAe,OAAf;AACD,CAFD;;AAIA,IAAM,gBAAgB,SAAhB,aAAgB,CAAC,GAAD,EAAS;AAC7B,YAAU,GAAV,EAAe,MAAf;AACD,CAFD;;AAIA,OAAO,OAAP,GAAiB;AACf,gCADe;AAEf;AAFe,CAAjB;;;ACrBA;;AAEA,IAAM,MAAM,QAAQ,QAAR,CAAZ;;AAEA,IAAM,kBAAkB,CAAE,EAAE,YAAF,CAAF,EAAmB,EAAE,WAAF,CAAnB,EAAmC,EAAE,WAAF,CAAnC,CAAxB;AACA,IAAM,sBAAsB,SAAtB,mBAAsB,CAAC,UAAD,EAAgB;AAC1C,kBAAgB,OAAhB,CAAwB;AAAA,WAAQ,KAAK,IAAL,CAAU,UAAV,EAAsB,UAAtB,CAAR;AAAA,GAAxB;AACD,CAFD;;AAIA,IAAM,oBAAoB,SAApB,iBAAoB,GAAM;AAC9B,sBAAoB,KAApB;AACD,CAFD;;AAIA,IAAM,qBAAqB,SAArB,kBAAqB,GAAM;AAC/B,sBAAoB,IAApB;AACD,CAFD;;AAIA,IAAM,sBAAsB,SAAtB,mBAAsB,GAAM;AAChC,IAAE,0BAAF,EAA8B,WAA9B,CAA0C,QAA1C;AACA;AACA,MAAI,SAAJ,GAAgB,eAAhB;AACD,CAJD;;AAMA,IAAM,cAAc,SAAd,WAAc,CAAC,GAAD,EAAS;AAC3B,IAAE,WAAF,EAAe,GAAf,CAAmB,QAAnB;AACD,CAFD;;AAIA,IAAM,mBAAmB,SAAnB,gBAAmB,GAAM;AAC7B,IAAE,YAAF,EAAgB,QAAhB,CAAyB,QAAzB;AACD,CAFD;;AAIA,IAAM,qBAAqB,SAArB,kBAAqB,GAAM;AAC/B,IAAE,YAAF,EAAgB,WAAhB,CAA4B,QAA5B;AACD,CAFD;;AAIA,OAAO,OAAP,GAAiB;AACf,sCADe;AAEf,wCAFe;AAGf,0CAHe;AAIf,0BAJe;AAKf,oCALe;AAMf;AANe,CAAjB;;;ACnCA;;AAEA,OAAO,OAAP,GAAiB,UAAS,EAAT,EAAa;AAC5B,MAAM,SAAS,IAAI,IAAJ,CAAS,EAAT,CAAf;;AAEA,SAAO,UAAP,CAAkB;AAChB,+BAA2B,IADX;AAEhB,oBAAgB,IAFA;AAGhB,8BAA0B;AAHV,GAAlB;;AAMA,SAAO,QAAP,CAAgB,mCAAhB;AACA,SAAO,OAAP,CAAe,OAAf,CAAuB,qBAAvB;AACA,SAAO,eAAP,GAAyB,QAAzB;;AAEA,SAAO,MAAP;AACD,CAdD;;;ACFA;;AAEA,IAAM,UAAU,SAAV,OAAU,CAAC,aAAD,EAAgB,IAAhB,EAAsB,SAAtB,EAAoC;;AAElD,MAAI;AAAA;AACF,oBAAc,aAAd;AACA,UAAM,QAAQ,KAAK,KAAL,CAAW,IAAX,CAAd;AACA,UAAM,WAAW,EAAjB;AACA,YAAM,OAAN,CAAc,UAAC,IAAD,EAAO,CAAP,EAAa;AACzB,iBAAS,IAAT,CAAc,KAAK,OAAL,CAAa,0BAAb,WAA+C,IAAI,SAAnD,QAAd;AACD,OAFD;AAGA,WAAK,SAAS,IAAT,CAAc,IAAd,CAAL;AACA,oBAAc,SAAd;AARE;AASH,GATD,CASE,OAAO,GAAP,EAAY;AACZ,WAAO,GAAP;AACD,GAXD,SAWU;AACR,kBAAc,iBAAd;AACD;AACF,CAhBD;;AAkBA,IAAM,cAAc,SAAd,WAAc,CAAC,aAAD,EAAgB,QAAhB,EAA6B;AAC/C,SAAO,QAAQ,aAAR,EAAuB,QAAvB,CAAP;AACD,CAFD;;AAIA,IAAM,qBAAqB,SAArB,kBAAqB,CAAC,aAAD,EAAgB,QAAhB,EAA0B,QAA1B,EAAuC;AAChE,MAAM,YAAY,SAAS,KAAT,CAAe,IAAf,EAAqB,MAAvC;AACA,SAAO,QAAQ,aAAR,EAA0B,QAA1B,UAAuC,QAAvC,EAAmD,SAAnD,CAAP;AACD,CAHD;;AAKA,OAAO,OAAP,GAAiB;AACf,0BADe;AAEf;AAFe,CAAjB;;;AC7BA;;AAEA,IAAM,MAAM,QAAQ,QAAR,CAAZ;AACA,IAAM,eAAe,QAAQ,UAAR,CAArB;AACA,IAAM,WAAW,QAAQ,YAAR,CAAjB;AACA,IAAM,UAAU,QAAQ,iBAAR,CAAhB;;AAEA,SAAS,MAAT,CAAgB,aAAhB,EAA+B;AAAA;;AAC7B,MAAI,CAAC,aAAL,EAAoB;AAClB,UAAM,iDAAN;AACD;;AAED,MAAI,OAAJ,CAAY,wBAAZ;AACA,MAAM,QAAQ,IAAI,OAAJ,CAAY,WAAZ,EAAyB,KAAvC;;AAEA,OAAK,UAAL,GAAkB,aAAa,MAAb,CAAlB;AACA,OAAK,UAAL,GAAkB,aAAa,MAAb,CAAlB;;;;AAIA,OAAK,OAAL,GAAe,UAAC,IAAD,EAAU;AACvB,UAAK,UAAL,CAAgB,QAAhB,CAAyB,IAAzB,EAA+B,CAAC,CAAhC;AACD,GAFD;;AAIA,OAAK,OAAL,GAAe,UAAC,IAAD,EAAU;AACvB,UAAK,UAAL,CAAgB,QAAhB,CAAyB,IAAzB,EAA+B,CAAC,CAAhC;AACD,GAFD;;AAIA,OAAK,UAAL,GAAmB,gBAGb;AAAA,QAFJ,IAEI,QAFJ,IAEI;AAAA,QADJ,IACI,QADJ,IACI;;AACJ,UAAK,OAAL,CAAa,IAAb;AACA,UAAK,OAAL,CAAa,IAAb;AACD,GAND;;;;AAUA,OAAK,SAAL,GAAiB,YAAM;AACrB,UAAK,UAAL,CAAgB,QAAhB,CAAyB,EAAzB;AACD,GAFD;;AAIA,OAAK,SAAL,GAAiB,YAAM;AACrB,UAAK,UAAL,CAAgB,QAAhB,CAAyB,EAAzB;AACD,GAFD;;AAIA,OAAK,YAAL,GAAoB,YAAM;AACxB,UAAK,SAAL;AACA,UAAK,SAAL;AACD,GAHD;;AAKA,OAAK,OAAL,GAAe,YAAM;AACnB,QAAM,OAAO,MAAK,UAAL,CAAgB,QAAhB,EAAb;AACA,QAAM,OAAO,MAAK,UAAL,CAAgB,QAAhB,EAAb;AACA,WAAO,SAAS,kBAAT,CAA4B,aAA5B,EAA2C,IAA3C,EAAiD,IAAjD,CAAP;AACD,GAJD;;AAMA,OAAK,aAAL,GAAqB,UAAC,UAAD,EAAgB;AACnC,QAAM,UAAU,MAAK,UAAL,CAAgB,UAAhB,EAAhB;AACA,QAAI,MAAK,MAAT,EAAiB,QAAQ,YAAR,CAAqB,MAAK,MAA1B;AACjB,UAAK,MAAL,GAAc,QAAQ,SAAR,CAAkB,IAAI,KAAJ,CAAU,UAAV,EAAsB,CAAtB,EAAyB,UAAzB,EAAqC,QAArC,CAAlB,EAAkE,WAAlE,EAA+E,MAA/E,EAAuF,IAAvF,CAAd;AACD,GAJD;;AAMA,OAAK,eAAL,GAAuB,YAAM;AAC3B,QAAM,UAAU,MAAK,UAAL,CAAgB,UAAhB,EAAhB;AACA,QAAI,MAAK,MAAT,EAAiB,QAAQ,YAAR,CAAqB,MAAK,MAA1B;AAClB,GAHD;;;;AAOA,OAAK,UAAL,CAAgB,EAAhB,CAAmB,QAAnB,EAA6B,YAAM;AACjC,QAAM,OAAO,MAAK,UAAL,CAAgB,QAAhB,EAAb;AACA,QAAM,eAAe,IAAI,eAAJ,EAArB;AACA,QAAI,YAAJ,EAAkB;AAChB,UAAI,gBAAJ,CAAqB,YAArB,EAAmC;AACjC;AADiC,OAAnC;AAGD;AACD,aAAS,WAAT,CAAqB,aAArB,EAAoC,IAApC;AACA,YAAQ,mBAAR;AACD,GAVD;;AAYA,OAAK,UAAL,CAAgB,EAAhB,CAAmB,QAAnB,EAA6B,YAAM;AACjC,QAAM,OAAO,MAAK,UAAL,CAAgB,QAAhB,EAAb;AACA,QAAM,eAAe,IAAI,eAAJ,EAArB;AACA,QAAI,YAAJ,EAAkB;AAChB,UAAI,gBAAJ,CAAqB,YAArB,EAAmC;AACjC;AADiC,OAAnC;AAGD;AACD,kBAAc,KAAd;AACA,YAAQ,mBAAR;AACD,GAVD;AAWD;;AAED,OAAO,OAAP,GAAiB,MAAjB;;;AC/FA;;AAEA,IAAM,OAAO,QAAQ,MAAR,CAAb;AACA,IAAM,MAAM,QAAQ,OAAR,CAAZ;AACA,IAAM,iBAAiB,QAAQ,mBAAR,CAAvB;AACA,IAAM,MAAM,QAAQ,OAAR,CAAZ;AACA,IAAM,SAAS,QAAQ,UAAR,CAAf;;AAEA,IAAM,UAAU,QAAQ,UAAR,CAAhB;;SAII,C;IADF,M,MAAA,M;;;AAGF,EAAE,SAAF,CAAY;AACV,SAAO,KADG;AAEV,YAAU;AAFA,CAAZ;;eAOI,QAAQ,SAAR,C;;IADF,c,YAAA,c;;gBAOE,QAAQ,kBAAR,C;;IAHF,Y,aAAA,Y;IACA,kB,aAAA,kB;IACA,O,aAAA,O;;;;AAIF,KAAK,EAAL,CAAQ,OAAR,EAAiB,UAAU,MAAV,EAAkB;AACjC,UAAQ,MAAR,CAAe,KAAf,EAAsB,MAAtB;AACD,CAFD;;AAIA,EAAE,YAAM;;;AAGN,MAAM,iBAAiB,IAAI,cAAJ,EAAvB;AACA,SAAO,IAAP,EAAa,GAAb,EAAkB,cAAlB;;;AAGA,SAAO,IAAP,EAAa,MAAb,EAAqB,OAArB;;AAEA,SAAO,cAAP,GAAwB,IAAxB,CAA6B,UAAC,IAAD,EAAU;AACrC,QAAI,aAAJ,CAAkB,IAAlB;AACA,QAAI,aAAJ;;;;;AAFqC,mBAUjC,SAViC;;AAAA,QAOnC,QAPmC,YAOnC,QAPmC;AAAA,QAQnC,SARmC,YAQnC,SARmC;AAAA,QASnC,IATmC,YASnC,IATmC;;AAWrC,QAAI,eAAe,QAAf,CAAJ,EAA8B;AAC5B,UAAI,SAAJ,EAAe;AACb,eAAO,gBAAP,CAAwB,SAAxB,EAAmC,IAAnC,CAAwC,gBAAiC;AAAA,cAA/B,QAA+B,QAA/B,QAA+B;AAAA,cAArB,SAAqB,QAArB,SAAqB;AAAA,cAAV,IAAU,QAAV,IAAU;;AACvE,cAAI,aAAJ,CAAkB,QAAlB,EAA4B,SAA5B,EAAuC,IAAvC;AACD,SAFD;AAGD,OAJD,MAIO;AACL,eAAO,aAAP,CAAqB,QAArB,EAA+B,IAA/B,CAAoC,UAAC,IAAD,EAAU;AAC5C,cAAI,aAAJ,CAAkB,QAAlB,EAA4B,IAA5B,EAAkC,IAAlC;AACD,SAFD;AAGD;AACF,KAVD,MAUO,IAAI,YAAY,SAAhB,EAA2B;AAChC,UAAI,sBAAJ,CAA2B,QAA3B,EAAqC,SAArC,EAAgD,IAAhD;AACD,KAFM,MAEA;AACL,UAAI,kBAAJ;AACD;AACF,GA1BD;;AA4BA,SAAO,YAAP,GAAsB,IAAtB,CAA2B,UAAC,IAAD,EAAU;AACnC,QAAI,WAAJ,CAAgB,KAAK,KAArB;;AAEA,QAAI,QAAJ,CAAa,QAAb;AACD,GAJD;;AAMA,MAAI,kBAAkB,aAAa,eAAb,CAAtB;AACA,MAAI,kBAAkB,mBAAmB,eAAnB,CAAtB;AACA,MAAI,iBAAiB,mBAAmB,eAAxC;AACA,MAAI,cAAJ,EAAoB;AAClB,WAAO,QAAP,CAAgB,IAAhB,GAAuB,OAAO,QAAP,CAAgB,QAAhB,GAA2B,IAA3B,GAAkC,OAAO,QAAP,CAAgB,IAAlD,GAAyD,OAAO,QAAP,CAAgB,QAAzE,GAAoF,gBAApF,GAAuG,cAA9H;AACD;AAEF,CAlDD;;;AClCA;;AAEA,IAAM,UAAU,QAAQ,WAAR,CAAhB;;AAEA,IAAM,SAAS,SAAT,MAAS,CAAC,CAAD,EAAI,GAAJ,EAAS,GAAT,EAAiB;AAC9B,SAAO,QAAQ,MAAR,CAAe,CAAf,EAAkB,CAAlB,EAAqB,GAArB,EAA0B,GAA1B,EAA+B,CAA/B,CAAP;AACD,CAFD;;AAIA,IAAM,eAAe,SAAf,YAAe,CAAC,CAAD,EAAI,GAAJ,EAAS,GAAT,EAAgB;AACnC,SAAO,QAAQ,YAAR,CAAqB,CAArB,EAAwB,CAAxB,EAA2B,GAA3B,EAAgC,GAAhC,EAAqC,CAArC,CAAP;AACD,CAFD;;AAIA,OAAO,OAAP,GAAiB;AACf,gBADe;AAEf;AAFe,CAAjB;;;ACZA;;AAEA,IAAM,UAAU,QAAQ,WAAR,CAAhB;;AAEA,IAAM,SAAS,SAAT,MAAS,CAAC,CAAD,EAAI,CAAJ,EAAO,GAAP,EAAY,GAAZ,EAAoB;AACjC,MAAI,CAAC,CAAL,EAAQ,IAAI,EAAJ;AACR,MAAI,CAAC,CAAL,EAAQ,IAAI,EAAJ;AACR,MAAI,QAAQ,SAAZ,EAAuB,MAAM,CAAN;AACvB,MAAI,QAAQ,SAAZ,EAAuB,MAAM,CAAN;AACvB,MAAI,IAAI,EAAR;AACA,OAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB,EAA4B;AAC1B,MAAE,IAAF,CAAO,EAAP;AACA,SAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB,EAA4B;AAC1B,QAAE,CAAF,EAAK,IAAL,CAAU,QAAQ,MAAR,CAAe,GAAf,EAAoB,GAApB,CAAV;AACD;AACF;AACD,SAAO,CAAP;AACD,CAbD;;AAeA,IAAM,eAAe,SAAf,YAAe,CAAC,CAAD,EAAI,CAAJ,EAAO,GAAP,EAAY,GAAZ,EAAoB;AACvC,SAAO,OAAO,CAAP,EAAU,CAAV,EAAa,GAAb,EAAkB,GAAlB,EAAuB,GAAvB,CAA2B,UAAU,GAAV,EAAe;AAC/C,WAAO,IAAI,IAAJ,CAAS,UAAU,CAAV,EAAa,CAAb,EAAgB;AAC9B,aAAO,IAAI,CAAX;AACD,KAFM,CAAP;AAGD,GAJM,CAAP;AAKD,CAND;;AAQA,OAAO,OAAP,GAAiB;AACf,gBADe;AAEf;AAFe,CAAjB;;;AC3BA;;AAEA,IAAM,UAAU,QAAQ,WAAR,CAAhB;;AAEA,IAAM,SAAS,SAAT,MAAS,CAAC,CAAD,EAAI,GAAJ,EAAS,GAAT,EAAiB;AAC9B,MAAI,CAAC,CAAL,EAAQ,IAAI,CAAJ;AACR,MAAI,CAAC,GAAL,EAAU,MAAM,CAAN;AACV,MAAI,CAAC,GAAL,EAAU,MAAM,EAAN;AACV,MAAI,IAAI,IAAI,KAAJ,CAAU,CAAV,CAAR;AACA,OAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB;AAA4B,MAAE,CAAF,IAAO,IAAI,KAAJ,CAAU,CAAV,CAAP;AAA5B,GACA,KAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB;AACE,SAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,EAAE,CAAF,EAAK,MAAzB,EAAiC,GAAjC;AACE,QAAE,CAAF,EAAK,CAAL,IAAU,QAAQ,MAAR,CAAe,GAAf,EAAoB,GAApB,CAAV;AADF;AADF,GAGA,OAAO,CAAP;AACD,CAVD;;AAYA,OAAO,OAAP,GAAiB;AACf;AADe,CAAjB;;;AChBA;;AAEA,IAAM,SAAS,SAAT,MAAS,CAAC,CAAD,EAAI,KAAJ,EAAc;AAC3B,MAAI,CAAC,CAAL,EAAQ,IAAI,CAAJ;AACR,MAAI,CAAC,KAAL,EAAY,QAAQ,EAAR;AACZ,MAAI,IAAI,IAAI,KAAJ,CAAU,CAAV,CAAR;AACA,OAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB,EAA4B;AAC1B,MAAE,CAAF,IAAO,IAAI,KAAJ,CAAU,CAAV,CAAP;AACA,SAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB,EAA4B;AAC1B,UAAI,KAAK,CAAT,EAAY;AACV,UAAE,CAAF,EAAK,CAAL,IAAU,CAAC,KAAK,MAAL,MAAiB,IAAI,KAArB,IAA8B,CAA/B,KAAqC,CAArC,GAAyC,CAAzC,GAA6C,CAAvD;AACD;AACF;AACF;AACD,SAAO,CAAP;AACD,CAbD;;AAeA,OAAO,OAAP,GAAiB;AACf;AADe,CAAjB;;;ACjBA;;AAEA,IAAM,UAAU,QAAQ,WAAR,CAAhB;AACA,IAAM,UAAU,QAAQ,WAAR,CAAhB;AACA,IAAM,UAAU,QAAQ,WAAR,CAAhB;AACA,IAAM,mBAAmB,QAAQ,qBAAR,CAAzB;AACA,IAAM,gBAAgB,QAAQ,kBAAR,CAAtB;AACA,IAAM,kBAAkB,QAAQ,oBAAR,CAAxB;AACA,IAAM,wBAAwB,QAAQ,2BAAR,CAA9B;AACA,IAAM,0BAA0B,QAAQ,6BAAR,CAAhC;;AAEA,OAAO,OAAP,GAAiB;AACf,kBADe;AAEf,kBAFe;AAGf,kBAHe;AAIf,oCAJe;AAKf,8BALe;AAMf,kCANe;AAOf,8CAPe;AAQf;AARe,CAAjB;;;ACXA;;AAEA,IAAM,SAAS,SAAT,MAAS,CAAC,GAAD,EAAM,GAAN,EAAc;AAC3B,SAAO,CAAC,KAAK,MAAL,MAAiB,MAAM,GAAN,GAAY,CAA7B,IAAkC,CAAnC,IAAwC,GAA/C;AACD,CAFD;;AAIA,OAAO,OAAP,GAAiB;AACf;AADe,CAAjB;;;ACNA;;AAEA,IAAM,SAAS,SAAT,MAAS,CAAC,CAAD,EAAI,KAAJ,EAAc;AAC3B,MAAI,CAAC,CAAL,EAAQ,IAAI,CAAJ;AACR,MAAI,CAAC,KAAL,EAAY,QAAQ,EAAR;AACZ,MAAI,IAAI,IAAI,KAAJ,CAAU,CAAV,CAAR;AACA,OAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB;AAA4B,MAAE,CAAF,IAAO,IAAI,KAAJ,CAAU,CAAV,CAAP;AAA5B,GACA,KAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB,EAA4B;AAC1B,SAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB,EAA4B;AAC1B,UAAI,IAAI,CAAR,EAAW;AACT,UAAE,CAAF,EAAK,CAAL,IAAU,EAAE,CAAF,EAAK,CAAL,IAAU,CAAC,KAAK,MAAL,MAAiB,IAAI,KAArB,IAA8B,CAA/B,KAAqC,CAArC,GAAyC,CAAzC,GAA6C,CAAjE;AACD;AACF;AACF;AACD,SAAO,CAAP;AACD,CAbD;;AAeA,OAAO,OAAP,GAAiB;AACf;AADe,CAAjB;;;ACjBA;;AAEA,IAAM,UAAU,QAAQ,WAAR,CAAhB;;AAEA,IAAM,SAAS,SAAT,MAAS,CAAC,CAAD,EAAI,KAAJ,EAAW,GAAX,EAAgB,GAAhB,EAAwB;AACrC,MAAI,CAAC,CAAL,EAAQ,IAAI,CAAJ;AACR,MAAI,CAAC,KAAL,EAAY,QAAQ,EAAR;AACZ,MAAI,CAAC,GAAL,EAAU,MAAM,CAAN;AACV,MAAI,CAAC,GAAL,EAAU,MAAM,CAAN;AACV,MAAI,IAAI,IAAI,KAAJ,CAAU,CAAV,CAAR;AACA,OAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB,EAA4B;AAC1B,MAAE,CAAF,IAAO,IAAI,KAAJ,CAAU,CAAV,CAAP;AACA,SAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB,EAA4B;AAC1B,UAAI,KAAK,CAAL,IAAU,CAAC,KAAK,MAAL,MAAiB,IAAI,KAArB,IAA8B,CAA/B,KAAqC,CAAnD,EAAsD;AACpD,UAAE,CAAF,EAAK,CAAL,IAAU,QAAQ,MAAR,CAAe,GAAf,EAAoB,GAApB,CAAV;AACD;AACF;AACF;AACD,SAAO,CAAP;AACD,CAfD;;AAiBA,OAAO,OAAP,GAAiB;AACf;AADe,CAAjB;;;ACrBA;;AAEA,IAAM,UAAU,QAAQ,WAAR,CAAhB;;AAEA,IAAM,SAAS,SAAT,MAAS,CAAC,CAAD,EAAI,KAAJ,EAAW,GAAX,EAAgB,GAAhB,EAAwB;AACrC,MAAI,CAAC,CAAL,EAAQ,IAAI,CAAJ;AACR,MAAI,CAAC,KAAL,EAAY,QAAQ,EAAR;AACZ,MAAI,CAAC,GAAL,EAAU,MAAM,CAAN;AACV,MAAI,CAAC,GAAL,EAAU,MAAM,CAAN;AACV,MAAI,IAAI,IAAI,KAAJ,CAAU,CAAV,CAAR;AACA,OAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB;AAA4B,MAAE,CAAF,IAAO,IAAI,KAAJ,CAAU,CAAV,CAAP;AAA5B,GACA,KAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB,EAA4B;AAC1B,SAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,CAApB,EAAuB,GAAvB,EAA4B;AAC1B,UAAI,IAAI,CAAJ,IAAS,CAAC,KAAK,MAAL,MAAiB,IAAI,KAArB,IAA8B,CAA/B,KAAqC,CAAlD,EAAqD;AACnD,UAAE,CAAF,EAAK,CAAL,IAAU,EAAE,CAAF,EAAK,CAAL,IAAU,QAAQ,MAAR,CAAe,GAAf,EAAoB,GAApB,CAApB;AACD;AACF;AACF;AACD,SAAO,CAAP;AACD,CAfD;;AAiBA,OAAO,OAAP,GAAiB;AACf;AADe,CAAjB;;;ACrBA;;AAEA,IAAI,UAAU,QAAQ,UAAR,CAAd;AACA,IAAI,QAAQ,QAAQ,QAAR,CAAZ;;SAII,C;IADF,M,MAAA,M;;;AAGF,OAAO,OAAP,GAAiB,OAAO,IAAP,EAAa,EAAb,EAAiB,OAAjB,EAA0B,KAA1B,CAAjB;;;ACTA;;;;;;;;;;;;AAEA,IAAM,gBAAgB,QAAQ,WAAR,CAAtB;;IAEM,a;;;;;mCACkB;AACpB,aAAO,eAAP;AACD;;;AAED,yBAAY,IAAZ,EAAkB;AAAA;;AAAA,4FACV,IADU;AAEjB;;;;4BAEO,G,EAAK,C,EAAG;AACd,uFAAc,CAAd,EAAiB,GAAjB,EAAsB,CAAtB;AACA,aAAO,IAAP;AACD;;;8BAES,G,EAAK;AACb,yFAAgB,CAAhB,EAAmB,GAAnB;AACA,aAAO,IAAP;AACD;;;4BAEO,C,EAAG,C,EAAG;AACZ,UAAI,MAAM,SAAV,EAAqB;AACnB,yFAAc,CAAd,EAAiB,CAAjB;AACD,OAFD,MAEO;AACL,4FAAiB,CAAjB,EAAoB,CAApB,EAAuB,CAAvB;AACD;AACD,aAAO,IAAP;AACD;;;8BAES,C,EAAG,C,EAAG;AACd,UAAI,MAAM,SAAV,EAAqB;AACnB,2FAAgB,CAAhB,EAAmB,CAAnB;AACD,OAFD,MAEO;AACL,8FAAmB,CAAnB,EAAsB,CAAtB,EAAyB,CAAzB;AACD;AACD,aAAO,IAAP;AACD;;;gCAEW,I,EAAM,O,EAAS;AACzB,2FAAkB,IAAlB,EAAwB,OAAxB;AACA,UAAI,KAAK,WAAT,EAAsB;AACpB,YAAM,UAAU,EAAE,MAAF,CAAS,IAAT,EAAe,EAAf,EAAmB,IAAnB,CAAhB;AACA,gBAAQ,OAAR,GAAkB,KAAK,WAAL,CAAiB,OAAnC;AACA,gBAAQ,CAAR,GAAY,QAAQ,EAApB;AACA,gBAAQ,CAAR,GAAY,QAAQ,EAApB;AACA,YAAI,QAAQ,CAAR,KAAc,SAAlB,EAA6B,QAAQ,CAAR,GAAY,QAAQ,CAApB;AAC7B,eAAO,QAAQ,CAAf;AACA,eAAO,QAAQ,CAAf;AACA,eAAO,QAAQ,EAAf;AACA,eAAO,QAAQ,EAAf;AACA,eAAO,QAAQ,EAAf;AACA,eAAO,QAAQ,EAAf;AACA,aAAK,WAAL,CAAiB,WAAjB,CAA6B,OAA7B,EAAsC,OAAtC;AACD;AACF;;;4BAEO,C,EAAG;AACT,8FAAqB,CAAC,CAAD,CAArB;AACD;;;;EAzDyB,a;;AA4D5B,OAAO,OAAP,GAAiB,aAAjB;;;AChEA;;;;;;;;;;;;AAEA,IAAM,SAAS,QAAQ,UAAR,CAAf;;eAII,QAAQ,iCAAR,C;;IADF,Y,YAAA,Y;;IAGI,a;;;;;mCACkB;AACpB,aAAO,eAAP;AACD;;;AAED,yBAAY,IAAZ,EAAkB;AAAA;;AAAA,iGACV,IADU;;AAGhB,UAAK,UAAL,GAAkB;AAChB,gBAAU,UADM;AAEhB,gBAAU;AAFM,KAAlB;;AAKA,QAAI,MAAK,KAAT,EAAgB;AARA;AASjB;;;;4BAEO,C,EAAG,C,EAAG,C,EAAG;AACf,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,QAD4B;AAElC,WAAG,CAF+B;AAGlC,WAAG,CAH+B;AAIlC,WAAG;AAJ+B,OAApC;AAMA,aAAO,IAAP;AACD;;;8BAES,C,EAAG,C,EAAG;AACd,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,UAD4B;AAElC,WAAG,CAF+B;AAGlC,WAAG;AAH+B,OAApC;AAKA,aAAO,IAAP;AACD;;;4BAEO,E,EAAI,E,EAAI,E,EAAI,E,EAAI;AACtB,WAAK,iBAAL,CAAuB,QAAvB,EAAiC,IAAjC,EAAuC,SAAvC;AACA,aAAO,IAAP;AACD;;;+BAEU,C,EAAG,E,EAAI,E,EAAI;AACpB,WAAK,iBAAL,CAAuB,QAAvB,EAAiC,KAAjC,EAAwC,SAAxC;AACA,aAAO,IAAP;AACD;;;+BAEU,C,EAAG,E,EAAI,E,EAAI;AACpB,WAAK,iBAAL,CAAuB,QAAvB,EAAiC,KAAjC,EAAwC,SAAxC;AACA,aAAO,IAAP;AACD;;;8BAES,E,EAAI,E,EAAI,E,EAAI,E,EAAI;AACxB,WAAK,iBAAL,CAAuB,UAAvB,EAAmC,IAAnC,EAAyC,SAAzC;AACA,aAAO,IAAP;AACD;;;iCAEY,C,EAAG,E,EAAI,E,EAAI;AACtB,WAAK,iBAAL,CAAuB,UAAvB,EAAmC,KAAnC,EAA0C,SAA1C;AACA,aAAO,IAAP;AACD;;;iCAEY,C,EAAG,E,EAAI,E,EAAI;AACtB,WAAK,iBAAL,CAAuB,UAAvB,EAAmC,KAAnC,EAA0C,SAA1C;AACA,aAAO,IAAP;AACD;;;8BAES,C,EAAG,C,EAAG;AACd,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,UAD4B;AAElC,WAAG,CAF+B;AAGlC,WAAG;AAH+B,OAApC;AAKA,aAAO,IAAP;AACD;;;iCAEY,C,EAAG;AACd,WAAK,SAAL,CAAe,CAAf,EAAkB,CAAC,CAAnB;AACA,aAAO,IAAP;AACD;;;iCAEY,C,EAAG;AACd,WAAK,SAAL,CAAe,CAAC,CAAhB,EAAmB,CAAnB;AACA,aAAO,IAAP;AACD;;;gCAEW,C,EAAG,C,EAAG;AAChB,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,YAD4B;AAElC,WAAG,CAF+B;AAGlC,WAAG;AAH+B,OAApC;AAKA,aAAO,IAAP;AACD;;;mCAEc,C,EAAG;AAChB,WAAK,WAAL,CAAiB,CAAjB,EAAoB,CAAC,CAArB;AACA,aAAO,IAAP;AACD;;;mCAEc,C,EAAG;AAChB,WAAK,WAAL,CAAiB,CAAC,CAAlB,EAAqB,CAArB;AACA,aAAO,IAAP;AACD;;;wCAEmB;AAClB,UAAI,OAAO,MAAM,SAAN,CAAgB,KAAhB,CAAsB,IAAtB,CAA2B,SAA3B,CAAX;AACA,UAAI,OAAO,KAAK,KAAL,EAAX;AACA,UAAI,OAAO,KAAK,KAAL,EAAX;AACA,aAAO,MAAM,SAAN,CAAgB,KAAhB,CAAsB,IAAtB,CAA2B,KAAK,KAAL,EAA3B,CAAP;AACA,UAAI,KAAJ;AACA,cAAQ,IAAR;AACE,aAAK,KAAL;AACE,kBAAQ;AACN,eAAG,KAAK,CAAL,CADG;AAEN,gBAAI,KAAK,CAAL,CAFE;AAGN,gBAAI,KAAK,CAAL;AAHE,WAAR;AAKA;AACF,aAAK,KAAL;AACE,kBAAQ;AACN,eAAG,KAAK,CAAL,CADG;AAEN,gBAAI,KAAK,CAAL,CAFE;AAGN,gBAAI,KAAK,CAAL;AAHE,WAAR;AAKA;AACF;AACE,cAAI,KAAK,CAAL,MAAY,SAAZ,IAAyB,KAAK,CAAL,MAAY,SAAzC,EAAoD;AAClD,oBAAQ;AACN,iBAAG,KAAK,CAAL,CADG;AAEN,iBAAG,KAAK,CAAL;AAFG,aAAR;AAID,WALD,MAKO;AACL,oBAAQ;AACN,kBAAI,KAAK,CAAL,CADE;AAEN,kBAAI,KAAK,CAAL,CAFE;AAGN,kBAAI,KAAK,CAAL,CAHE;AAIN,kBAAI,KAAK,CAAL;AAJE,aAAR;AAMD;AA5BL;AA8BA,UAAI,OAAO;AACT,cAAM;AADG,OAAX;AAGA,QAAE,MAAF,CAAS,IAAT,EAAe,KAAf;AACA,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC,IAApC;AACD;;;gCAEW,I,EAAM,O,EAAS;AACzB,cAAQ,KAAK,IAAb;AACE,aAAK,QAAL;AACE,cAAI,KAAK,CAAL,KAAW,SAAf,EAA0B;AACxB,gBAAI,OAAO,KAAK,MAAL,CAAY,IAAZ,CAAiB,WAAjB,EAA8B,EAA9B,CAAiC,KAAK,CAAtC,CAAX;AACA,gBAAI,OAAO,KAAK,IAAL,CAAU,WAAV,EAAuB,EAAvB,CAA0B,KAAK,CAA/B,CAAX;AACA,iBAAK,IAAL,CAAU,aAAa,KAAK,CAAlB,CAAV;AACD;AACH,aAAK,UAAL;AACA,aAAK,QAAL;AACA,aAAK,UAAL;AACE,cAAI,aAAa,KAAK,IAAL,IAAa,QAAb,IAAyB,KAAK,IAAL,IAAa,UAAtC,GAAmD,KAAK,UAAL,CAAgB,QAAnE,GAA8E,KAAK,UAAL,CAAgB,QAA/G;AACA,cAAI,WAAW,KAAK,IAAL,IAAa,QAAb,IAAyB,KAAK,IAAL,IAAa,QAArD;AACA,cAAI,KAAK,KAAK,EAAd;AACA,cAAI,KAAK,KAAK,EAAd;AACA,cAAI,KAAK,KAAK,EAAd;AACA,cAAI,KAAK,KAAK,EAAd;AACA,cAAI,OAAO,SAAX,EAAsB,KAAK,KAAK,CAAV;AACtB,cAAI,OAAO,SAAX,EAAsB,KAAK,KAAK,CAAV;AACtB,cAAI,OAAO,SAAX,EAAsB,KAAK,KAAK,CAAV;AACtB,cAAI,OAAO,SAAX,EAAsB,KAAK,KAAK,CAAV;AACtB,eAAK,UAAL,CAAgB,EAAhB,EAAoB,EAApB,EAAwB,EAAxB,EAA4B,EAA5B,EAAgC,UAAhC,EAA4C,QAA5C;AACA;AACF,aAAK,UAAL;AACE,eAAK,UAAL,CAAgB,KAAK,CAArB,EAAwB,KAAK,CAA7B;AACA,eAAK,QAAL,CAAc,KAAK,CAAnB,EAAsB,KAAK,CAA3B;AACA;AACF,aAAK,YAAL;AACE,eAAK,UAAL,CAAgB,KAAK,CAArB,EAAwB,KAAK,CAA7B;AACA;AACF;AACE,+FAAkB,IAAlB,EAAwB,OAAxB;AA9BJ;AAgCD;;;4BAEO,C,EAAG;AACT,WAAK,KAAL,GAAa,KAAK,KAAL,GAAa,CAA1B;AACA,WAAK,QAAL,GAAgB,CAAhB;AACA,WAAK,QAAL,GAAgB,CAAhB;AACA,WAAK,QAAL,GAAgB,EAAhB;;AAEA,UAAI,sEAAc,KAAd,CAAoB,IAApB,EAA0B,SAA1B,CAAJ,EAA0C;AACxC,aAAK,MAAL,CAAY,IAAZ,CAAiB,WAAjB,EAA8B,IAA9B,CAAmC,UAAU,CAAV,EAAa;AAC9C,YAAE,IAAF,EAAQ,IAAR,CAAa,WAAb,EAA0B,IAA1B,CAA+B,UAAU,CAAV,EAAa;AAC1C,cAAE,IAAF,EAAQ,IAAR,CAAa,aAAa,EAAE,CAAF,EAAK,CAAL,CAAb,CAAb;AACD,WAFD;AAGD,SAJD;AAKA,eAAO,IAAP;AACD;;AAED,WAAK,MAAL,CAAY,KAAZ;AACA,WAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,EAAE,MAAtB,EAA8B,GAA9B,EAAmC;AACjC,YAAI,OAAO,EAAE,wBAAF,CAAX;AACA,aAAK,MAAL,CAAY,MAAZ,CAAmB,IAAnB;AACA,aAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,EAAE,CAAF,EAAK,MAAzB,EAAiC,GAAjC,EAAsC;AACpC,cAAI,OAAO,EAAE,wBAAF,EACR,GADQ,CACJ,KAAK,UAAL,EADI,EAER,IAFQ,CAEH,aAAa,EAAE,CAAF,EAAK,CAAL,CAAb,CAFG,CAAX;AAGA,eAAK,MAAL,CAAY,IAAZ;AACD;AACF;AACD,WAAK,MAAL;;AAEA,aAAO,KAAP;AACD;;;6BAEQ;AACP;;AAEA,WAAK,OAAL;AACD;;;4BAEO;AACN;;AAEA,WAAK,UAAL;AACA,WAAK,aAAL;AACD;;;iCAEY;AACX,aAAO;AACL,iBAAS,KAAK,QAAL,CAAc,OAAd,CAAsB,CAAtB,IAA2B,KAA3B,GAAmC,KAAK,QAAL,CAAc,OAAd,CAAsB,CAAtB,CAAnC,GAA8D,IADlE;AAEL,qBAAa,KAAK,QAAL,CAAc,OAAd,CAAsB,CAAtB,IAA2B;AAFnC,OAAP;AAID;;;8BAES;AACR;;AAEA,UAAI,UAAU,KAAK,MAAL,CAAY,MAAZ,EAAd;AACA,UAAI,MAAM,QAAQ,MAAR,KAAmB,CAAnB,GAAuB,KAAK,MAAL,CAAY,MAAZ,KAAuB,CAA9C,GAAkD,KAAK,KAAjE;AACA,UAAI,OAAO,QAAQ,KAAR,KAAkB,CAAlB,GAAsB,KAAK,MAAL,CAAY,KAAZ,KAAsB,CAA5C,GAAgD,KAAK,KAAhE;AACA,WAAK,MAAL,CAAY,GAAZ,CAAgB,YAAhB,EAA8B,GAA9B;AACA,WAAK,MAAL,CAAY,GAAZ,CAAgB,aAAhB,EAA+B,IAA/B;AACD;;;8BAES,C,EAAG;AACX,yFAAgB,CAAhB;;AAEA,WAAK,KAAL,GAAa,EAAE,KAAf;AACA,WAAK,KAAL,GAAa,EAAE,KAAf;AACA,WAAK,QAAL,GAAgB,IAAhB;AACD;;;8BAES,C,EAAG;AACX,yFAAgB,CAAhB;;AAEA,UAAI,KAAK,QAAT,EAAmB;AACjB,aAAK,KAAL,IAAc,EAAE,KAAF,GAAU,KAAK,KAA7B;AACA,aAAK,KAAL,IAAc,EAAE,KAAF,GAAU,KAAK,KAA7B;AACA,aAAK,KAAL,GAAa,EAAE,KAAf;AACA,aAAK,KAAL,GAAa,EAAE,KAAf;AACA,aAAK,OAAL;AACD;AACF;;;4BAEO,C,EAAG;AACT,uFAAc,CAAd;;AAEA,WAAK,QAAL,GAAgB,KAAhB;AACD;;;+BAEU,C,EAAG;AACZ,0FAAiB,CAAjB;;AAEA,QAAE,cAAF;AACA,UAAI,EAAE,aAAN;AACA,UAAI,QAAS,EAAE,UAAF,KAAiB,SAAjB,IAA8B,EAAE,UAAjC,IACT,EAAE,MAAF,KAAa,SAAb,IAA0B,CAAC,EAAE,MADhC;AAEA,UAAI,SAAS,IAAb;AACA,UAAI,QAAQ,QAAQ,CAAR,GAAY,IAAI,MAAhB,GAAyB,MAArC;AACA,UAAI,KAAK,QAAL,GAAgB,CAAhB,IAAqB,QAAQ,CAAjC,EAAoC;AACpC,UAAI,KAAK,QAAL,GAAgB,EAAhB,IAAsB,QAAQ,CAAlC,EAAqC;AACrC,WAAK,QAAL,IAAiB,KAAjB;AACA,WAAK,QAAL,IAAiB,KAAjB;AACA,WAAK,QAAL,IAAiB,KAAjB;AACA,WAAK,MAAL,CAAY,IAAZ,CAAiB,WAAjB,EAA8B,GAA9B,CAAkC,KAAK,UAAL,EAAlC;AACA,WAAK,OAAL;AACD;;;+BAEU,E,EAAI,E,EAAI,E,EAAI,E,EAAI,U,EAAY,Q,EAAU;AAC/C,WAAK,IAAI,IAAI,EAAb,EAAiB,KAAK,EAAtB,EAA0B,GAA1B,EAA+B;AAC7B,YAAI,OAAO,KAAK,MAAL,CAAY,IAAZ,CAAiB,WAAjB,EAA8B,EAA9B,CAAiC,CAAjC,CAAX;AACA,aAAK,IAAI,IAAI,EAAb,EAAiB,KAAK,EAAtB,EAA0B,GAA1B,EAA+B;AAC7B,cAAI,OAAO,KAAK,IAAL,CAAU,WAAV,EAAuB,EAAvB,CAA0B,CAA1B,CAAX;AACA,cAAI,QAAJ,EAAc,KAAK,QAAL,CAAc,UAAd,EAAd,KACK,KAAK,WAAL,CAAiB,UAAjB;AACN;AACF;AACF;;;iCAEY;AACX,WAAK,MAAL,CAAY,IAAZ,CAAiB,WAAjB,EAA8B,WAA9B,CAA0C,OAAO,IAAP,CAAY,KAAK,UAAjB,EAA6B,IAA7B,CAAkC,GAAlC,CAA1C;AACD;;;6BAEQ,C,EAAG,C,EAAG;AACb,WAAK,MAAL,CAAY,IAAZ,CAAiB,WAAjB,EAA8B,IAA9B,CAAmC,UAAU,CAAV,EAAa;AAC9C,YAAI,OAAO,EAAE,IAAF,CAAX;AACA,YAAI,KAAK,CAAT,EAAY;AACV,eAAK,KAAL,CAAW,EAAE,8BAAF,EAAkC,IAAlC,CAAuC,UAAvC,EAAmD,CAAnD,CAAX;AACD;AACD,aAAK,IAAL,CAAU,WAAV,EAAuB,IAAvB,CAA4B,UAAU,CAAV,EAAa;AACvC,cAAI,OAAO,EAAE,IAAF,CAAX;AACA,cAAI,KAAK,CAAT,EAAY;AACV,iBAAK,KAAL,CAAW,EAAE,8BAAF,EAAkC,IAAlC,CAAuC,UAAvC,EAAmD,CAAnD,CAAX;AACD;AACF,SALD;AAMD,OAXD;AAYD;;;+BAEU,C,EAAG,C,EAAG;AACf,WAAK,MAAL,CAAY,IAAZ,CAAiB,eAAe,CAAf,GAAmB,GAApC,EAAyC,MAAzC;AACA,WAAK,MAAL,CAAY,IAAZ,CAAiB,eAAe,CAAf,GAAmB,GAApC,EAAyC,MAAzC;AACD;;;oCAEe;AACd,WAAK,MAAL,CAAY,IAAZ,CAAiB,kCAAjB,EAAqD,MAArD;AACD;;;;EAnUyB,M;;AAsU5B,IAAM,WAAW,SAAX,QAAW,CAAC,MAAD,EAAY;AAC3B,SAAO,MAAP,GAAgB,OAAO,OAAP,CAAe,MAAf,GAAwB,EAAE,0BAAF,CAAxC;AACA,SAAO,UAAP,CAAkB,MAAlB,CAAyB,OAAO,MAAhC;AACD,CAHD;;AAKA,OAAO,OAAP,GAAiB,aAAjB;;;ACnVA;;;;;;;;;;;;AAEA,IAAM,SAAS,QAAQ,UAAR,CAAf;;IAEM,W;;;;;mCACkB;AACpB,aAAO,aAAP;AACD;;;AAED,uBAAY,IAAZ,EAAkB;AAAA;;AAAA,+FACV,IADU;;AAGhB,UAAK,KAAL,GAAa;AACX,gBAAU,gBADC;AAEX,gBAAU,gBAFC;AAGX,eAAS;AAHE,KAAb;;AAMA,QAAI,MAAK,KAAT,EAAgB;AATA;AAUjB;;;;4BAEO,C,EAAG;AACT,UAAI,oEAAc,KAAd,CAAoB,IAApB,EAA0B,SAA1B,CAAJ,EAA0C;AACxC,aAAK,KAAL,CAAW,MAAX,CAAkB,IAAlB,CAAuB,QAAvB,CAAgC,CAAhC,EAAmC,IAAnC,GAA0C,CAA1C;AACA,aAAK,KAAL,CAAW,MAAX;AACA,eAAO,IAAP;AACD;;AAED,UAAI,QAAQ,EAAZ;AACA,WAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,EAAE,MAAtB,EAA8B,GAA9B;AAAmC,cAAM,IAAN,CAAW,KAAK,KAAL,CAAW,OAAtB;AAAnC,OACA,KAAK,KAAL,CAAW,MAAX,CAAkB,IAAlB,GAAyB;AACvB,gBAAQ,EAAE,GAAF,CAAM,MAAN,CADe;AAEvB,kBAAU,CAAC;AACT,2BAAiB,KADR;AAET,gBAAM;AAFG,SAAD;AAFa,OAAzB;AAOA,WAAK,KAAL,CAAW,MAAX;AACD;;;4BAEO,C,EAAG,C,EAAG;AACZ,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,QAD4B;AAElC,WAAG,CAF+B;AAGlC,WAAG;AAH+B,OAApC;AAKA,aAAO,IAAP;AACD;;;8BAES,C,EAAG;AACX,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,UAD4B;AAElC,WAAG;AAF+B,OAApC;AAIA,aAAO,IAAP;AACD;;;4BAEO,C,EAAG,C,EAAG;AACZ,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,QAD4B;AAElC,WAAG,CAF+B;AAGlC,WAAG;AAH+B,OAApC;AAKA,aAAO,IAAP;AACD;;;8BAES,C,EAAG,C,EAAG;AACd,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,UAD4B;AAElC,WAAG,CAF+B;AAGlC,WAAG;AAH+B,OAApC;AAKA,aAAO,IAAP;AACD;;;gCAEW,I,EAAM,O,EAAS;AACzB,cAAQ,KAAK,IAAb;AACE,aAAK,QAAL;AACE,cAAI,KAAK,CAAL,KAAW,SAAf,EAA0B;AACxB,iBAAK,KAAL,CAAW,MAAX,CAAkB,IAAlB,CAAuB,QAAvB,CAAgC,CAAhC,EAAmC,IAAnC,CAAwC,KAAK,CAA7C,IAAkD,KAAK,CAAvD;AACA,iBAAK,KAAL,CAAW,MAAX,CAAkB,IAAlB,CAAuB,MAAvB,CAA8B,KAAK,CAAnC,IAAwC,KAAK,CAAL,CAAO,QAAP,EAAxC;AACD;AACH,aAAK,UAAL;AACA,aAAK,QAAL;AACA,aAAK,UAAL;AACE,cAAI,QAAQ,KAAK,IAAL,IAAa,QAAb,GAAwB,KAAK,KAAL,CAAW,QAAnC,GAA8C,KAAK,IAAL,IAAa,QAAb,GAAwB,KAAK,KAAL,CAAW,QAAnC,GAA8C,KAAK,KAAL,CAAW,OAAnH;AACA,cAAI,KAAK,CAAL,KAAW,SAAf,EACE,KAAK,IAAI,IAAI,KAAK,CAAlB,EAAqB,KAAK,KAAK,CAA/B,EAAkC,GAAlC;AACE,iBAAK,KAAL,CAAW,MAAX,CAAkB,IAAlB,CAAuB,QAAvB,CAAgC,CAAhC,EAAmC,eAAnC,CAAmD,CAAnD,IAAwD,KAAxD;AADF,WADF,MAIE,KAAK,KAAL,CAAW,MAAX,CAAkB,IAAlB,CAAuB,QAAvB,CAAgC,CAAhC,EAAmC,eAAnC,CAAmD,KAAK,CAAxD,IAA6D,KAA7D;AACF,eAAK,KAAL,CAAW,MAAX;AACA;AACF;AACE,6FAAkB,IAAlB,EAAwB,OAAxB;AAlBJ;AAoBD;;;6BAEQ;AACP;;AAEA,WAAK,KAAL,CAAW,MAAX;AACD;;;4BAEO;AACN;;AAEA,UAAM,OAAO,KAAK,KAAL,CAAW,MAAX,CAAkB,IAA/B;AACA,UAAI,KAAK,QAAL,CAAc,MAAlB,EAA0B;AACxB,YAAM,kBAAkB,KAAK,QAAL,CAAc,CAAd,EAAiB,eAAzC;AACA,aAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,gBAAgB,MAApC,EAA4C,GAA5C,EAAiD;AAC/C,0BAAgB,CAAhB,IAAqB,KAAK,KAAL,CAAW,OAAhC;AACD;AACD,aAAK,KAAL,CAAW,MAAX;AACD;AACF;;;;EA/GuB,M;;AAkH1B,IAAM,WAAW,SAAX,QAAW,CAAC,MAAD,EAAY;AAC3B,SAAO,QAAP,GAAkB,OAAO,OAAP,CAAe,QAAf,GAA0B,EAAE,8BAAF,CAA5C;AACA,SAAO,UAAP,CAAkB,MAAlB,CAAyB,OAAO,QAAhC;AACA,SAAO,KAAP,GAAe,OAAO,OAAP,CAAe,KAAf,GAAuB,IAAI,KAAJ,CAAU,OAAO,QAAjB,EAA2B;AAC/D,UAAM,KADyD;AAE/D,UAAM;AACJ,cAAQ,EADJ;AAEJ,gBAAU;AAFN,KAFyD;AAM/D,aAAS;AACP,cAAQ;AACN,eAAO,CAAC;AACN,iBAAO;AACL,yBAAa;AADR;AADD,SAAD;AADD,OADD;AAQP,iBAAW,KARJ;AASP,cAAQ,KATD;AAUP,kBAAY,IAVL;AAWP,2BAAqB;AAXd;AANsD,GAA3B,CAAtC;AAoBD,CAvBD;;AAyBA,OAAO,OAAP,GAAiB,WAAjB;;;AC/IA;;;;;;;;;;;;AAEA,IAAM,sBAAsB,QAAQ,kBAAR,CAA5B;;IAEM,sB;;;;;mCACkB;AACpB,aAAO,wBAAP;AACD;;;AAED,kCAAY,IAAZ,EAAkB;AAAA;;AAAA,0GACV,IADU;;AAGhB,QAAI,MAAK,KAAT,EAAgB;AAHA;AAIjB;;;;4BAEO,C,EAAG;AACT,UAAI,OAAO,SAAP,CAAiB,OAAjB,CAAyB,KAAzB,CAA+B,IAA/B,EAAqC,SAArC,CAAJ,EAAqD,OAAO,IAAP;;AAErD,WAAK,KAAL,CAAW,KAAX;AACA,UAAI,QAAQ,EAAZ;AACA,UAAI,QAAQ,EAAZ;AACA,WAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,EAAE,MAAtB,EAA8B,GAA9B;AACE,cAAM,IAAN,CAAW;AACT,cAAI,KAAK,CAAL,CAAO,CAAP,CADK;AAET,aAAG,EAAE,CAAF,EAAK,CAAL,CAFM;AAGT,aAAG,EAAE,CAAF,EAAK,CAAL,CAHM;AAIT,iBAAO,KAAK,CAJH;AAKT,gBAAM,CALG;AAMT,iBAAO,KAAK,KAAL,CAAW;AANT,SAAX;AADF,OASA,KAAK,KAAL,CAAW,IAAX,CAAgB;AACd,eAAO,KADO;AAEd,eAAO;AAFO,OAAhB;AAIA,WAAK,CAAL,CAAO,MAAP,CAAc,IAAd,CAAmB;AACjB,WAAG,CADc;AAEjB,WAAG,CAFc;AAGjB,eAAO,CAHU;AAIjB,eAAO;AAJU,OAAnB;AAMA,WAAK,OAAL;;AAEA,aAAO,KAAP;AACD;;;gCAEW,I,EAAM,O,EAAS;AACzB,cAAQ,KAAK,IAAb;AACE,aAAK,OAAL;AACA,aAAK,OAAL;AACE,cAAI,QAAQ,KAAK,IAAL,IAAa,OAAzB;AACA,cAAI,aAAa,KAAK,KAAL,CAAW,KAAX,CAAiB,KAAK,CAAL,CAAO,KAAK,MAAZ,CAAjB,CAAjB;AACA,cAAI,QAAQ,QAAQ,KAAK,KAAL,CAAW,OAAnB,GAA6B,KAAK,KAAL,CAAW,IAApD;AACA,qBAAW,KAAX,GAAmB,KAAnB;AACA,cAAI,KAAK,MAAL,KAAgB,SAApB,EAA+B;AAC7B,gBAAI,SAAS,KAAK,CAAL,CAAO,KAAK,MAAZ,EAAoB,KAAK,MAAzB,CAAb;AACA,gBAAI,KAAK,KAAL,CAAW,KAAX,CAAiB,MAAjB,CAAJ,EAA8B;AAC5B,kBAAI,OAAO,KAAK,KAAL,CAAW,KAAX,CAAiB,MAAjB,CAAX;AACA,mBAAK,KAAL,GAAa,KAAb;AACA,mBAAK,KAAL,CAAW,QAAX,CAAoB,MAApB,EAA4B,OAA5B,CAAoC,IAApC;AACD,aAJD,MAIO;AACL,mBAAK,KAAL,CAAW,OAAX,CAAmB;AACjB,oBAAI,KAAK,CAAL,CAAO,KAAK,MAAZ,EAAoB,KAAK,MAAzB,CADa;AAEjB,wBAAQ,KAAK,CAAL,CAAO,KAAK,MAAZ,CAFS;AAGjB,wBAAQ,KAAK,CAAL,CAAO,KAAK,MAAZ,CAHS;AAIjB,uBAAO,KAJU;AAKjB,sBAAM;AALW,eAAnB;AAOD;AACF;AACD,cAAI,KAAK,SAAT,EAAoB;AAClB,gBAAI,SAAS,KAAK,MAAlB;AACA,gBAAI,WAAW,SAAf,EAA0B,SAAS,EAAT;AAC1B,iBAAK,SAAL,CAAe,KAAf,CAAqB,QAAQ,SAAS,MAAT,GAAkB,KAAK,MAA/B,GAAwC,SAAS,MAAT,GAAkB,KAAK,MAApF;AACD;AACD;AACF;AACE,wGAAkB,IAAlB,EAAwB,OAAxB;AA9BJ;AAgCD;;;sBAEC,E,EAAI,E,EAAI;AACR,UAAI,KAAK,EAAT,EAAa;AACX,YAAI,OAAO,EAAX;AACA,aAAK,EAAL;AACA,aAAK,IAAL;AACD;AACD,aAAO,MAAM,EAAN,GAAW,GAAX,GAAiB,EAAxB;AACD;;;gCAEW,I,EAAM,O,EAAS,Q,EAAU,I,EAAM;AACzC,UAAI,SAAS,IAAb;;AAEA,cAAQ,WAAR,CAAoB,CAAC,CAAD,EAAI,CAAJ,CAApB;AACA,UAAI,UAAU,KAAK,EAAL,CAAQ,SAAR,CAAkB,CAAlB,CAAd;AACA,WAAK,KAAL,CAAW,KAAX,GAAmB,OAAnB,CAA2B,UAAU,IAAV,EAAgB;AACzC,YAAI,OAAO,KAAK,EAAL,CAAQ,SAAR,CAAkB,CAAlB,EAAqB,KAArB,CAA2B,GAA3B,CAAX;AACA,YAAI,KAAK,CAAL,KAAW,OAAf,EAAwB;AACtB,cAAI,QAAQ,MAAZ;AACA,cAAI,SAAS,IAAb;AACA,cAAI,SAAS,OAAO,KAAP,CAAa,KAAb,CAAmB,MAAM,KAAK,CAAL,CAAzB,CAAb;AACA,iBAAO,QAAP,CAAgB,IAAhB,EAAsB,MAAtB,EAA8B,MAA9B,EAAsC,KAAtC,EAA6C,OAA7C,EAAsD,QAAtD;AACA,cAAI,IAAJ,EAAU,KAAK,IAAL,EAAW,MAAX,EAAmB,MAAnB,EAA2B,KAA3B,EAAkC,OAAlC,EAA2C,QAA3C;AACX,SAND,MAMO,IAAI,KAAK,CAAL,KAAW,OAAf,EAAwB;AAC7B,cAAI,QAAQ,MAAZ;AACA,cAAI,SAAS,OAAO,KAAP,CAAa,KAAb,CAAmB,MAAM,KAAK,CAAL,CAAzB,CAAb;AACA,cAAI,SAAS,IAAb;AACA,iBAAO,QAAP,CAAgB,IAAhB,EAAsB,MAAtB,EAA8B,MAA9B,EAAsC,KAAtC,EAA6C,OAA7C,EAAsD,QAAtD;AACA,cAAI,IAAJ,EAAU,KAAK,IAAL,EAAW,MAAX,EAAmB,MAAnB,EAA2B,KAA3B,EAAkC,OAAlC,EAA2C,QAA3C;AACX;AACF,OAfD;AAgBD;;;6BAEQ,I,EAAM,M,EAAQ,M,EAAQ,K,EAAO,O,EAAS,Q,EAAU;AACvD,UAAI,SAAS,SAAS,QAAT,KAAsB,EAAnC;UACE,OAAO,KAAK,SAAS,MAAd,KAAyB,CADlC;;AAGA,cAAQ,WAAR,GAAsB,KAAtB;AACA,cAAQ,SAAR,GAAoB,IAApB;AACA,cAAQ,SAAR;AACA,cAAQ,MAAR,CACE,OAAO,SAAS,GAAhB,CADF,EAEE,OAAO,SAAS,GAAhB,CAFF;AAIA,cAAQ,MAAR,CACE,OAAO,SAAS,GAAhB,CADF,EAEE,OAAO,SAAS,GAAhB,CAFF;AAIA,cAAQ,MAAR;AACD;;;;EA5HkC,mB;;AA+HrC,IAAM,WAAW,SAAX,QAAW,CAAC,MAAD,EAAY;AAC3B,SAAO,CAAP,CAAS,QAAT,CAAkB;AAChB,qBAAiB,KADD;AAEhB,gBAFgB,wBAEH,IAFG,EAEG,MAFH,EAEW,MAFX,EAEmB,OAFnB,EAE4B,QAF5B,EAEsC;AACpD,UAAI,QAAQ,OAAO,QAAP,CAAgB,IAAhB,EAAsB,MAAtB,EAA8B,MAA9B,EAAsC,QAAtC,CAAZ;AACA,aAAO,QAAP,CAAgB,IAAhB,EAAsB,MAAtB,EAA8B,MAA9B,EAAsC,KAAtC,EAA6C,OAA7C,EAAsD,QAAtD;AACD;AALe,GAAlB;AAOD,CARD;;AAUA,OAAO,OAAP,GAAiB,sBAAjB;;;AC7IA;;;;;;;;;;;;AAEA,IAAM,SAAS,QAAQ,UAAR,CAAf;;eAII,QAAQ,iCAAR,C;;IADF,Y,YAAA,Y;;IAGI,mB;;;;;mCACkB;AACpB,aAAO,qBAAP;AACD;;;AAED,+BAAY,IAAZ,EAAkB;AAAA;;AAAA,uGACV,IADU;;AAGhB,UAAK,KAAL,GAAa;AACX,gBAAU,MADC;AAEX,eAAS,MAFE;AAGX,YAAM,MAHK;AAIX,eAAS;AAJE,KAAb;;AAOA,QAAI,MAAK,KAAT,EAAgB;AAVA;AAWjB;;;;iCAEY,C,EAAG,I,EAAM;AACpB,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,aAD4B;AAElC,mBAAW;AAFuB,OAApC;AAIA,aAAO,IAAP;AACD;;;2BAEM,M,EAAQ,M,EAAQ;AACrB,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,OAD4B;AAElC,gBAAQ,MAF0B;AAGlC,gBAAQ;AAH0B,OAApC;AAKA,aAAO,IAAP;AACD;;;2BAEM,M,EAAQ,M,EAAQ;AACrB,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,OAD4B;AAElC,gBAAQ,MAF0B;AAGlC,gBAAQ;AAH0B,OAApC;AAKA,aAAO,IAAP;AACD;;;gCAEW,I,EAAM,O,EAAS;AACzB,cAAQ,KAAK,IAAb;AACE,aAAK,aAAL;AACE,eAAK,WAAL,CAAiB,KAAjB,CAAuB,IAAvB,EAA6B,KAAK,SAAlC;AACA;AACF,aAAK,OAAL;AACA,aAAK,OAAL;AACE,cAAI,QAAQ,KAAK,IAAL,IAAa,OAAzB;AACA,cAAI,aAAa,KAAK,KAAL,CAAW,KAAX,CAAiB,KAAK,CAAL,CAAO,KAAK,MAAZ,CAAjB,CAAjB;AACA,cAAI,QAAQ,QAAQ,KAAK,KAAL,CAAW,OAAnB,GAA6B,KAAK,KAAL,CAAW,IAApD;AACA,qBAAW,KAAX,GAAmB,KAAnB;AACA,cAAI,KAAK,MAAL,KAAgB,SAApB,EAA+B;AAC7B,gBAAI,SAAS,KAAK,CAAL,CAAO,KAAK,MAAZ,EAAoB,KAAK,MAAzB,CAAb;AACA,gBAAI,OAAO,KAAK,KAAL,CAAW,KAAX,CAAiB,MAAjB,CAAX;AACA,iBAAK,KAAL,GAAa,KAAb;AACA,iBAAK,KAAL,CAAW,QAAX,CAAoB,MAApB,EAA4B,OAA5B,CAAoC,IAApC;AACD;AACD,cAAI,KAAK,SAAT,EAAoB;AAClB,gBAAI,SAAS,KAAK,MAAlB;AACA,gBAAI,WAAW,SAAf,EAA0B,SAAS,EAAT;AAC1B,iBAAK,SAAL,CAAe,KAAf,CAAqB,QAAQ,SAAS,MAAT,GAAkB,KAAK,MAA/B,GAAwC,SAAS,MAAT,GAAkB,KAAK,MAApF;AACD;AACD;AACF;AACE,qGAAkB,IAAlB,EAAwB,OAAxB;AAvBJ;AAyBD;;;gCAEW,C,EAAG,I,EAAM,U,EAAY;AAC/B,UAAI,SAAS,IAAb;;AAEA,aAAO,QAAQ,CAAf;AACA,UAAI,WAAW,CAAC,CAAhB;;AAEA,UAAI,MAAM,IAAI,KAAJ,CAAU,EAAE,MAAZ,CAAV;AACA,UAAI,WAAW,SAAX,QAAW,CAAU,IAAV,EAAgB,KAAhB,EAAuB;AACpC,YAAI,IAAI,IAAJ,CAAJ,EAAe,MAAM,0DAAN;AACf,YAAI,IAAJ,IAAY,IAAZ;AACA,YAAI,WAAW,KAAf,EAAsB,WAAW,KAAX;AACtB,aAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,EAAE,IAAF,EAAQ,MAA5B,EAAoC,GAApC,EAAyC;AACvC,cAAI,EAAE,IAAF,EAAQ,CAAR,CAAJ,EAAgB,SAAS,CAAT,EAAY,QAAQ,CAApB;AACjB;AACF,OAPD;AAQA,eAAS,IAAT,EAAe,CAAf;;AAEA,UAAI,KAAK,OAAL,CAAa,CAAb,EAAgB,UAAhB,CAAJ,EAAiC,OAAO,IAAP;;AAEjC,UAAI,QAAQ,SAAR,KAAQ,CAAU,IAAV,EAAgB,CAAhB,EAAmB,CAAnB,EAAsB;AAChC,YAAI,OAAO,OAAO,KAAP,CAAa,KAAb,CAAmB,OAAO,CAAP,CAAS,IAAT,CAAnB,CAAX;AACA,aAAK,CAAL,GAAS,CAAT;AACA,aAAK,CAAL,GAAS,CAAT;AACD,OAJD;;AAMA,UAAI,OAAO,KAAK,WAAW,CAAhB,CAAX;AACA,UAAI,MAAM,SAAN,GAAM,CAAU,IAAV,EAAgB,KAAhB,EAAuB,GAAvB,EAA4B,MAA5B,EAAoC;AAC5C,cAAM,IAAN,EAAY,MAAM,MAAlB,EAA0B,QAAQ,IAAlC;AACA,YAAI,WAAW,CAAf;AACA,aAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,EAAE,IAAF,EAAQ,MAA5B,EAAoC,GAApC,EAAyC;AACvC,cAAI,EAAE,IAAF,EAAQ,CAAR,CAAJ,EAAgB;AACjB;AACD,YAAI,OAAO,CAAC,SAAS,GAAV,IAAiB,QAA5B;AACA,YAAI,MAAM,CAAV;AACA,aAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,EAAE,IAAF,EAAQ,MAA5B,EAAoC,GAApC,EAAyC;AACvC,cAAI,EAAE,IAAF,EAAQ,CAAR,CAAJ,EAAgB,IAAI,CAAJ,EAAO,QAAQ,CAAf,EAAkB,MAAM,OAAO,GAA/B,EAAoC,MAAM,OAAO,EAAE,GAAnD;AACjB;AACF,OAXD;AAYA,UAAI,IAAJ,EAAU,CAAV,EAAa,CAAb,EAAgB,CAAhB;;AAEA,WAAK,OAAL;AACD;;;4BAEO,C,EAAG,U,EAAY;AACrB,UAAI,4EAAc,KAAd,CAAoB,IAApB,EAA0B,SAA1B,CAAJ,EAA0C,OAAO,IAAP;;AAE1C,WAAK,KAAL,CAAW,KAAX;AACA,UAAM,QAAQ,EAAd;AACA,UAAM,QAAQ,EAAd;AACA,UAAM,YAAY,IAAI,KAAK,EAAT,GAAc,EAAE,MAAlC;AACA,UAAI,eAAe,CAAnB;AACA,WAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,EAAE,MAAtB,EAA8B,GAA9B,EAAmC;AACjC,wBAAgB,SAAhB;AACA,cAAM,IAAN,CAAW;AACT,cAAI,KAAK,CAAL,CAAO,CAAP,CADK;AAET,iBAAO,KAAK,CAFH;AAGT,aAAG,KAAK,KAAK,GAAL,CAAS,YAAT,IAAyB,CAHxB;AAIT,aAAG,KAAK,KAAK,GAAL,CAAS,YAAT,IAAyB,CAJxB;AAKT,gBAAM,CALG;AAMT,iBAAO,KAAK,KAAL,CAAW,OANT;AAOT,kBAAQ;AAPC,SAAX;;AAUA,YAAI,UAAJ,EAAgB;AACd,eAAK,IAAI,IAAI,CAAb,EAAgB,KAAK,CAArB,EAAwB,GAAxB,EAA6B;AAC3B,gBAAM,QAAQ,EAAE,CAAF,EAAK,CAAL,KAAW,EAAE,CAAF,EAAK,CAAL,CAAzB;AACA,gBAAI,KAAJ,EAAW;AACT,oBAAM,IAAN,CAAW;AACT,oBAAI,KAAK,CAAL,CAAO,CAAP,EAAU,CAAV,CADK;AAET,wBAAQ,KAAK,CAAL,CAAO,CAAP,CAFC;AAGT,wBAAQ,KAAK,CAAL,CAAO,CAAP,CAHC;AAIT,uBAAO,KAAK,KAAL,CAAW,OAJT;AAKT,sBAAM,CALG;AAMT,wBAAQ,aAAa,KAAb;AANC,eAAX;AAQD;AACF;AACF,SAdD,MAcO;AACL,eAAK,IAAI,KAAI,CAAb,EAAgB,KAAI,EAAE,CAAF,EAAK,MAAzB,EAAiC,IAAjC,EAAsC;AACpC,gBAAI,EAAE,CAAF,EAAK,EAAL,CAAJ,EAAa;AACX,oBAAM,IAAN,CAAW;AACT,oBAAI,KAAK,CAAL,CAAO,CAAP,EAAU,EAAV,CADK;AAET,wBAAQ,KAAK,CAAL,CAAO,CAAP,CAFC;AAGT,wBAAQ,KAAK,CAAL,CAAO,EAAP,CAHC;AAIT,uBAAO,KAAK,KAAL,CAAW,OAJT;AAKT,sBAAM,CALG;AAMT,wBAAQ,aAAa,EAAE,CAAF,EAAK,EAAL,CAAb;AANC,eAAX;AAQD;AACF;AACF;AACF;;AAED,WAAK,KAAL,CAAW,IAAX,CAAgB;AACd,eAAO,KADO;AAEd,eAAO;AAFO,OAAhB;AAIA,WAAK,CAAL,CAAO,MAAP,CAAc,IAAd,CAAmB;AACjB,WAAG,CADc;AAEjB,WAAG,CAFc;AAGjB,eAAO,CAHU;AAIjB,eAAO;AAJU,OAAnB;AAMA,WAAK,OAAL;;AAEA,aAAO,KAAP;AACD;;;6BAEQ;AACP;;AAEA,WAAK,CAAL,CAAO,SAAP,CAAiB,CAAjB,EAAoB,MAApB;AACA,WAAK,OAAL;AACD;;;8BAES;AACR;;AAEA,WAAK,CAAL,CAAO,OAAP;AACD;;;4BAEO;AACN;;AAEA,WAAK,eAAL;AACA,WAAK,OAAL;AACD;;;sCAEiB;AAChB,UAAI,SAAS,IAAb;;AAEA,WAAK,KAAL,CAAW,KAAX,GAAmB,OAAnB,CAA2B,UAAU,IAAV,EAAgB;AACzC,aAAK,KAAL,GAAa,OAAO,KAAP,CAAa,OAA1B;AACD,OAFD;AAGA,WAAK,KAAL,CAAW,KAAX,GAAmB,OAAnB,CAA2B,UAAU,IAAV,EAAgB;AACzC,aAAK,KAAL,GAAa,OAAO,KAAP,CAAa,OAA1B;AACD,OAFD;AAGD;;;sBAEC,C,EAAG;AACH,aAAO,MAAM,CAAb;AACD;;;sBAEC,E,EAAI,E,EAAI;AACR,aAAO,MAAM,EAAN,GAAW,GAAX,GAAiB,EAAxB;AACD;;;6BAEQ,I,EAAM,M,EAAQ,M,EAAQ,Q,EAAU;AACvC,UAAI,QAAQ,KAAK,KAAjB;UACE,YAAY,SAAS,WAAT,CADd;UAEE,mBAAmB,SAAS,kBAAT,CAFrB;UAGE,mBAAmB,SAAS,kBAAT,CAHrB;AAIA,UAAI,CAAC,KAAL,EACE,QAAQ,SAAR;AACE,aAAK,QAAL;AACE,kBAAQ,OAAO,KAAP,IAAgB,gBAAxB;AACA;AACF,aAAK,QAAL;AACE,kBAAQ,OAAO,KAAP,IAAgB,gBAAxB;AACA;AACF;AACE,kBAAQ,gBAAR;AACA;AATJ;;AAYF,aAAO,KAAP;AACD;;;8BAES,I,EAAM,O,EAAS,Q,EAAU;AACjC,UAAI,QAAJ;UACE,SAAS,SAAS,QAAT,KAAsB,EADjC;UAEE,OAAO,KAAK,SAAS,MAAd,CAFT;;AAIA,UAAI,OAAO,SAAS,gBAAT,CAAX,EACE;;AAEF,UAAI,CAAC,KAAK,KAAN,IAAe,OAAO,KAAK,KAAZ,KAAsB,QAAzC,EACE;;AAEF,iBAAY,SAAS,WAAT,MAA0B,OAA3B,GACT,SAAS,kBAAT,CADS,GAEX,SAAS,gBAAT,IAA6B,IAF7B;;AAIA,cAAQ,IAAR,GAAe,CAAC,SAAS,WAAT,IAAwB,SAAS,WAAT,IAAwB,GAAhD,GAAsD,EAAvD,IACb,QADa,GACF,KADE,GACM,SAAS,MAAT,CADrB;AAEA,cAAQ,SAAR,GAAqB,SAAS,YAAT,MAA2B,MAA5B,GACjB,KAAK,KAAL,IAAc,SAAS,kBAAT,CADG,GAElB,SAAS,mBAAT,CAFF;;AAIA,cAAQ,SAAR,GAAoB,QAApB;AACA,cAAQ,QAAR,CACE,KAAK,KADP,EAEE,KAAK,KAAL,CAAW,KAAK,SAAS,GAAd,CAAX,CAFF,EAGE,KAAK,KAAL,CAAW,KAAK,SAAS,GAAd,IAAqB,WAAW,CAA3C,CAHF;AAKD;;;8BAES,I,EAAM,M,EAAQ,M,EAAQ,K,EAAO,O,EAAS,Q,EAAU;AACxD,UAAI,SAAS,SAAS,QAAT,KAAsB,EAAnC;UACE,OAAO,KAAK,SAAS,MAAd,KAAyB,CADlC;UAEE,QAAQ,OAAO,SAAS,MAAhB,CAFV;UAGE,KAAK,OAAO,SAAS,GAAhB,CAHP;UAIE,KAAK,OAAO,SAAS,GAAhB,CAJP;UAKE,KAAK,OAAO,SAAS,GAAhB,CALP;UAME,KAAK,OAAO,SAAS,GAAhB,CANP;UAOE,QAAQ,KAAK,KAAL,CAAW,KAAK,EAAhB,EAAoB,KAAK,EAAzB,CAPV;UAQE,OAAO,CART;AASA,YAAM,KAAK,GAAL,CAAS,KAAT,IAAkB,IAAxB;AACA,YAAM,KAAK,GAAL,CAAS,KAAT,IAAkB,IAAxB;AACA,YAAM,CAAC,KAAK,GAAL,CAAS,KAAT,CAAD,GAAmB,IAAzB;AACA,YAAM,CAAC,KAAK,GAAL,CAAS,KAAT,CAAD,GAAmB,IAAzB;AACA,UAAI,QAAQ,KAAK,GAAL,CAAS,OAAO,GAAhB,EAAqB,SAAS,cAAT,CAArB,CAAZ;UACE,IAAI,KAAK,IAAL,CAAU,KAAK,GAAL,CAAS,KAAK,EAAd,EAAkB,CAAlB,IAAuB,KAAK,GAAL,CAAS,KAAK,EAAd,EAAkB,CAAlB,CAAjC,CADN;UAEE,KAAK,KAAK,CAAC,KAAK,EAAN,KAAa,IAAI,KAAJ,GAAY,KAAzB,IAAkC,CAF9C;UAGE,KAAK,KAAK,CAAC,KAAK,EAAN,KAAa,IAAI,KAAJ,GAAY,KAAzB,IAAkC,CAH9C;UAIE,KAAK,CAAC,KAAK,EAAN,IAAY,KAAZ,GAAoB,CAJ3B;UAKE,KAAK,CAAC,KAAK,EAAN,IAAY,KAAZ,GAAoB,CAL3B;;AAOA,cAAQ,WAAR,GAAsB,KAAtB;AACA,cAAQ,SAAR,GAAoB,IAApB;AACA,cAAQ,SAAR;AACA,cAAQ,MAAR,CAAe,EAAf,EAAmB,EAAnB;AACA,cAAQ,MAAR,CACE,EADF,EAEE,EAFF;AAIA,cAAQ,MAAR;;AAEA,cAAQ,SAAR,GAAoB,KAApB;AACA,cAAQ,SAAR;AACA,cAAQ,MAAR,CAAe,KAAK,EAApB,EAAwB,KAAK,EAA7B;AACA,cAAQ,MAAR,CAAe,KAAK,KAAK,GAAzB,EAA8B,KAAK,KAAK,GAAxC;AACA,cAAQ,MAAR,CAAe,KAAK,KAAK,GAAzB,EAA8B,KAAK,KAAK,GAAxC;AACA,cAAQ,MAAR,CAAe,KAAK,EAApB,EAAwB,KAAK,EAA7B;AACA,cAAQ,SAAR;AACA,cAAQ,IAAR;AACD;;;gCAEW,I,EAAM,O,EAAS,Q,EAAU,I,EAAM;AACzC,UAAI,SAAS,IAAb;;AAEA,cAAQ,WAAR,CAAoB,CAAC,CAAD,EAAI,CAAJ,CAApB;AACA,UAAI,UAAU,KAAK,EAAL,CAAQ,SAAR,CAAkB,CAAlB,CAAd;AACA,WAAK,KAAL,CAAW,KAAX,GAAmB,OAAnB,CAA2B,UAAU,IAAV,EAAgB;AACzC,YAAI,OAAO,KAAK,EAAL,CAAQ,SAAR,CAAkB,CAAlB,EAAqB,KAArB,CAA2B,GAA3B,CAAX;AACA,YAAI,KAAK,CAAL,KAAW,OAAf,EAAwB;AACtB,cAAI,QAAQ,MAAZ;AACA,cAAI,SAAS,IAAb;AACA,cAAI,SAAS,OAAO,KAAP,CAAa,KAAb,CAAmB,MAAM,KAAK,CAAL,CAAzB,CAAb;AACA,iBAAO,SAAP,CAAiB,IAAjB,EAAuB,MAAvB,EAA+B,MAA/B,EAAuC,KAAvC,EAA8C,OAA9C,EAAuD,QAAvD;AACA,cAAI,IAAJ,EAAU,KAAK,IAAL,EAAW,MAAX,EAAmB,MAAnB,EAA2B,KAA3B,EAAkC,OAAlC,EAA2C,QAA3C;AACX,SAND,MAMO,IAAI,KAAK,CAAL,KAAW,OAAf,EAAwB;AAC7B,cAAI,QAAQ,MAAZ;AACA,cAAI,SAAS,OAAO,KAAP,CAAa,KAAb,CAAmB,MAAM,KAAK,CAAL,CAAzB,CAAb;AACA,cAAI,SAAS,IAAb;AACA,iBAAO,SAAP,CAAiB,IAAjB,EAAuB,MAAvB,EAA+B,MAA/B,EAAuC,KAAvC,EAA8C,OAA9C,EAAuD,QAAvD;AACA,cAAI,IAAJ,EAAU,KAAK,IAAL,EAAW,MAAX,EAAmB,MAAnB,EAA2B,KAA3B,EAAkC,OAAlC,EAA2C,QAA3C;AACX;AACF,OAfD;AAgBD;;;;EA3U+B,M;;AA8UlC,IAAM,WAAW,SAAX,QAAW,CAAC,MAAD,EAAY;AAC3B,SAAO,CAAP,GAAW,OAAO,OAAP,CAAe,CAAf,GAAmB,IAAI,KAAJ,CAAU;AACtC,cAAU;AACR,iBAAW,OAAO,UAAP,CAAkB,CAAlB,CADH;AAER,YAAM;AAFE,KAD4B;AAKtC,cAAU;AACR,oBAAc,CADN;AAER,uBAAiB,OAFT;AAGR,mBAAa,GAHL;AAIR,sBAAgB,CAJR;AAKR,YAAM,QALE;AAMR,yBAAmB,MANX;AAOR,eAAS,GAPD;AAQR,eAAS,GARD;AASR,kBAAY,IATJ;AAUR,mBAAa,EAVL;AAWR,mBAAa,EAXL;AAYR,iBAAW,cAZH;AAaR,sBAAgB,GAbR;AAcR,mBAdQ,yBAcM,IAdN,EAcY,OAdZ,EAcqB,QAdrB,EAc+B;AACrC,eAAO,SAAP,CAAiB,IAAjB,EAAuB,OAAvB,EAAgC,QAAhC;AACD,OAhBO;AAiBR,mBAjBQ,yBAiBM,IAjBN,EAiBY,OAjBZ,EAiBqB,QAjBrB,EAiB+B,IAjB/B,EAiBqC;AAC3C,eAAO,WAAP,CAAmB,IAAnB,EAAyB,OAAzB,EAAkC,QAAlC,EAA4C,IAA5C;AACD,OAnBO;AAoBR,oBApBQ,0BAoBO,IApBP,EAoBa,MApBb,EAoBqB,MApBrB,EAoB6B,OApB7B,EAoBsC,QApBtC,EAoBgD;AACtD,YAAI,QAAQ,OAAO,QAAP,CAAgB,IAAhB,EAAsB,MAAtB,EAA8B,MAA9B,EAAsC,QAAtC,CAAZ;AACA,eAAO,SAAP,CAAiB,IAAjB,EAAuB,MAAvB,EAA+B,MAA/B,EAAuC,KAAvC,EAA8C,OAA9C,EAAuD,QAAvD;AACD;AAvBO;AAL4B,GAAV,CAA9B;AA+BA,QAAM,OAAN,CAAc,SAAd,CAAwB,OAAO,CAA/B,EAAkC,OAAO,CAAP,CAAS,SAAT,CAAmB,CAAnB,CAAlC;AACA,SAAO,KAAP,GAAe,OAAO,OAAP,CAAe,KAAf,GAAuB,OAAO,CAAP,CAAS,KAA/C;AACD,CAlCD;;AAoCA,MAAM,MAAN,CAAa,MAAb,CAAoB,GAApB,GAA0B,UAAU,IAAV,EAAgB,OAAhB,EAAyB,QAAzB,EAAmC;AAC3D,MAAI,OAAO,SAAS,eAAT,CAAX;AACA,MAAI,IAAJ,EAAU;AACR,SAAK,IAAL,EAAW,OAAX,EAAoB,QAApB;AACD;AACF,CALD;AAMA,MAAM,MAAN,CAAa,MAAb,CAAoB,GAApB,GAA0B,UAAU,IAAV,EAAgB,OAAhB,EAAyB,QAAzB,EAAmC;AAC3D,MAAI,OAAO,SAAS,eAAT,CAAX;AACA,MAAI,IAAJ,EAAU;AACR,SAAK,IAAL,EAAW,OAAX,EAAoB,QAApB;AACD;AACF,CALD;AAMA,MAAM,MAAN,CAAa,KAAb,CAAmB,GAAnB,GAAyB,UAAU,IAAV,EAAgB,MAAhB,EAAwB,MAAxB,EAAgC,OAAhC,EAAyC,QAAzC,EAAmD;AAC1E,MAAI,OAAO,SAAS,cAAT,CAAX;AACA,MAAI,IAAJ,EAAU;AACR,SAAK,IAAL,EAAW,MAAX,EAAmB,MAAnB,EAA2B,OAA3B,EAAoC,QAApC;AACD;AACF,CALD;AAMA,MAAM,MAAN,CAAa,KAAb,CAAmB,KAAnB,GAA2B,UAAU,IAAV,EAAgB,MAAhB,EAAwB,MAAxB,EAAgC,OAAhC,EAAyC,QAAzC,EAAmD;AAC5E,MAAI,OAAO,SAAS,gBAAT,CAAX;AACA,MAAI,IAAJ,EAAU;AACR,SAAK,IAAL,EAAW,MAAX,EAAmB,MAAnB,EAA2B,OAA3B,EAAoC,QAApC;AACD;AACF,CALD;;AAOA,OAAO,OAAP,GAAiB,mBAAjB;;;ACnZA;;AAEA,IAAM,SAAS,QAAQ,UAAR,CAAf;AACA,IAAM,YAAY,QAAQ,OAAR,CAAlB;AACA,IAAM,gBAAgB,QAAQ,WAAR,CAAtB;AACA,IAAM,gBAAgB,QAAQ,WAAR,CAAtB;AACA,IAAM,cAAc,QAAQ,SAAR,CAApB;AACA,IAAM,yBAAyB,QAAQ,qBAAR,CAA/B;AACA,IAAM,sBAAsB,QAAQ,kBAAR,CAA5B;AACA,IAAM,wBAAwB,QAAQ,oBAAR,CAA9B;AACA,IAAM,8BAA8B,QAAQ,2BAAR,CAApC;AACA,IAAM,gCAAgC,QAAQ,6BAAR,CAAtC;;AAEA,OAAO,OAAP,GAAiB;AACf,gBADe;AAEf,sBAFe;AAGf,8BAHe;AAIf,8BAJe;AAKf,0BALe;AAMf,gDANe;AAOf,0CAPe;AAQf,8CARe;AASf,0DATe;AAUf;AAVe,CAAjB;;;ACbA;;;;;;;;;;;;AAEA,IAAM,SAAS,QAAQ,UAAR,CAAf;;IAEM,S;;;;;mCACkB;AACpB,aAAO,WAAP;AACD;;;AAED,qBAAY,IAAZ,EAAkB;AAAA;;AAAA,6FACV,IADU;;AAGhB,QAAI,MAAK,KAAT,EAAgB;AAHA;AAIjB;;;;2BAEM,G,EAAK;AACV,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,OAD4B;AAElC,aAAK;AAF6B,OAApC;AAIA,aAAO,IAAP;AACD;;;gCAEW,I,EAAM,O,EAAS;AACzB,cAAQ,KAAK,IAAb;AACE,aAAK,OAAL;AACE,eAAK,KAAL,CAAW,KAAK,GAAhB;AACA;AAHJ;AAKD;;;8BAES;AACR,WAAK,WAAL,CAAiB,KAAK,GAAL,CAAS,EAAT,EAAa,KAAK,QAAlB,CAAjB;AACD;;;4BAEO;AACN;;AAEA,WAAK,QAAL,CAAc,KAAd;AACD;;;0BAEK,O,EAAS;AACb,WAAK,QAAL,CAAc,MAAd,CAAqB,EAAE,QAAF,EAAY,MAAZ,CAAmB,UAAU,OAA7B,CAArB;AACD;;;gCAEW,Q,EAAU;AACpB,WAAK,UAAL,CAAgB,OAAhB,CAAwB;AACtB,mBAAW,KAAK,UAAL,CAAgB,CAAhB,EAAmB;AADR,OAAxB,EAEG,QAFH;AAGD;;;;EA7CqB,M;;AAgDxB,IAAM,WAAW,SAAX,QAAW,CAAC,MAAD,EAAY;AAC3B,SAAO,QAAP,GAAkB,OAAO,OAAP,CAAe,QAAf,GAA0B,EAAE,uBAAF,CAA5C;AACA,SAAO,UAAP,CAAkB,MAAlB,CAAyB,OAAO,QAAhC;AACD,CAHD;;AAKA,OAAO,OAAP,GAAiB,SAAjB;;;ACzDA;;;;;;;;AAEA,IAAM,MAAM,QAAQ,WAAR,CAAZ;;eAKI,QAAQ,iCAAR,C;;IAFF,M,YAAA,M;IACA,Q,YAAA,Q;;IAGI,M;;;mCACkB;AACpB,aAAO,QAAP;AACD;;;AAED,kBAAY,IAAZ,EAAkB;AAAA;;AAChB,SAAK,MAAL,GAAc,KAAK,WAAnB;;AAEA,SAAK,OAAL,GAAe,IAAI,gBAAJ,EAAf;AACA,SAAK,OAAL,GAAe,KAAK,OAAL,CAAa,QAAb,CAAsB,IAAtB,CAAf;AACA,MAAE,MAAF,CAAS,IAAT,EAAe,KAAK,OAApB;;AAEA,SAAK,OAAL,CAAa,IAAb;AACD;;;;+BAEiB;AAAA,wCAAN,IAAM;AAAN,YAAM;AAAA;;AAChB,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,SAD4B;AAElC,cAAM,OAAO,IAAP;AAF4B,OAApC;AAIA,aAAO,IAAP;AACD;;;6BAEQ;AACP,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM;AAD4B,OAApC;AAGA,aAAO,IAAP;AACD;;;0BAEK,I,EAAM;AACV,WAAK,OAAL,CAAa,OAAb,CAAqB,IAArB;AACA,aAAO,IAAP;AACD;;;gCAEW,I,EAAM,O,EAAS;AAAA,UAEvB,IAFuB,GAIrB,IAJqB,CAEvB,IAFuB;AAAA,UAGvB,IAHuB,GAIrB,IAJqB,CAGvB,IAHuB;;;AAMzB,cAAQ,IAAR;AACE,aAAK,SAAL;AACE,eAAK,OAAL,gCAAgB,SAAS,IAAT,CAAhB;AACA;AACF,aAAK,OAAL;AACE,eAAK,KAAL;AACA;AANJ;AAQD;;;4BAEO,I,EAAM;AACZ,UAAI,cAAJ;AACA,UAAI,KAAK,KAAT,EAAgB;AACd,gBAAQ,EAAE,qBAAF,CAAR;AACA,aAAK,UAAL,CAAgB,MAAhB,CAAuB,KAAvB;AACD,OAHD,MAGO;AACL,gBAAQ,KAAK,UAAL,CAAgB,IAAhB,CAAqB,WAArB,CAAR;AACD;AACD,YAAM,IAAN,CAAW,QAAQ,KAAK,WAAxB;AACD;;;8BAES;AACR,UAAM,OAAO,OAAO,SAAP,CAAb;AACA,UAAI,CAAC,KAAK,KAAN,IAAe,KAAK,QAAL,KAAkB,IAArC,EAA2C;AACzC,eAAO,IAAP;AACD;AACD,WAAK,QAAL,GAAgB,KAAK,OAAL,CAAa,QAAb,GAAwB,IAAxC;AACA,aAAO,KAAP;AACD;;;6BAEQ,CACR;;;8BAES,CACT;;;4BAEO,CACP;;;2BAEM,M,EAAQ;AACb,cAAQ,OAAO,MAAf;AACE,aAAK,SAAL;AACE,eAAK,SAAL,GAAiB,MAAjB;AACA;AACF,aAAK,WAAL;AACE,eAAK,WAAL,GAAmB,MAAnB;AACA;AANJ;AAQA,aAAO,IAAP;AACD;;;8BAES,C,EAAG,CACZ;;;8BAES,C,EAAG,CACZ;;;4BAEO,C,EAAG,CACV;;;+BAEU,C,EAAG,CACb;;;;;;AAGH,OAAO,OAAP,GAAiB,MAAjB;;;AClHA;;;;;;;;;;;;AAEA,IAAM,sBAAsB,QAAQ,kBAAR,CAA5B;;IAEM,qB;;;;;mCACkB;AACpB,aAAO,uBAAP;AACD;;;AAED,iCAAY,IAAZ,EAAkB;AAAA;;AAAA,yGACV,IADU;;AAGhB,QAAI,MAAK,KAAT,EAAgB;AAHA;AAIjB;;;;gCAEW,C,EAAG,I,EAAM;AACnB,0GAAyB,CAAzB,EAA4B,IAA5B,EAAkC,IAAlC;AACD;;;4BAEO,C,EAAG;AACT,sGAAqB,CAArB,EAAwB,IAAxB;AACD;;;sBAEC,E,EAAI,E,EAAI;AACR,UAAI,KAAK,EAAT,EAAa;AACX,YAAI,OAAO,EAAX;AACA,aAAK,EAAL;AACA,aAAK,IAAL;AACD;AACD,aAAO,MAAM,EAAN,GAAW,GAAX,GAAiB,EAAxB;AACD;;;gCAEW,I,EAAM,O,EAAS,Q,EAAU,I,EAAM;AACzC,UAAI,SAAS,IAAb;;AAEA,cAAQ,WAAR,CAAoB,CAAC,CAAD,EAAI,CAAJ,CAApB;AACA,UAAI,UAAU,KAAK,EAAL,CAAQ,SAAR,CAAkB,CAAlB,CAAd;AACA,WAAK,KAAL,CAAW,KAAX,GAAmB,OAAnB,CAA2B,UAAU,IAAV,EAAgB;AACzC,YAAI,OAAO,KAAK,EAAL,CAAQ,SAAR,CAAkB,CAAlB,EAAqB,KAArB,CAA2B,GAA3B,CAAX;AACA,YAAI,KAAK,CAAL,KAAW,OAAf,EAAwB;AACtB,cAAI,QAAQ,MAAZ;AACA,cAAI,SAAS,IAAb;AACA,cAAI,SAAS,OAAO,KAAP,CAAa,KAAb,CAAmB,MAAM,KAAK,CAAL,CAAzB,CAAb;AACA,iBAAO,QAAP,CAAgB,IAAhB,EAAsB,MAAtB,EAA8B,MAA9B,EAAsC,KAAtC,EAA6C,OAA7C,EAAsD,QAAtD;AACA,cAAI,IAAJ,EAAU,KAAK,IAAL,EAAW,MAAX,EAAmB,MAAnB,EAA2B,KAA3B,EAAkC,OAAlC,EAA2C,QAA3C;AACX,SAND,MAMO,IAAI,KAAK,CAAL,KAAW,OAAf,EAAwB;AAC7B,cAAI,QAAQ,MAAZ;AACA,cAAI,SAAS,OAAO,KAAP,CAAa,KAAb,CAAmB,MAAM,KAAK,CAAL,CAAzB,CAAb;AACA,cAAI,SAAS,IAAb;AACA,iBAAO,QAAP,CAAgB,IAAhB,EAAsB,MAAtB,EAA8B,MAA9B,EAAsC,KAAtC,EAA6C,OAA7C,EAAsD,QAAtD;AACA,cAAI,IAAJ,EAAU,KAAK,IAAL,EAAW,MAAX,EAAmB,MAAnB,EAA2B,KAA3B,EAAkC,OAAlC,EAA2C,QAA3C;AACX;AACF,OAfD;AAgBD;;;6BAEQ,I,EAAM,M,EAAQ,M,EAAQ,K,EAAO,O,EAAS,Q,EAAU;AACvD,UAAI,SAAS,SAAS,QAAT,KAAsB,EAAnC;UACE,OAAO,KAAK,SAAS,MAAd,KAAyB,CADlC;;AAGA,cAAQ,WAAR,GAAsB,KAAtB;AACA,cAAQ,SAAR,GAAoB,IAApB;AACA,cAAQ,SAAR;AACA,cAAQ,MAAR,CACE,OAAO,SAAS,GAAhB,CADF,EAEE,OAAO,SAAS,GAAhB,CAFF;AAIA,cAAQ,MAAR,CACE,OAAO,SAAS,GAAhB,CADF,EAEE,OAAO,SAAS,GAAhB,CAFF;AAIA,cAAQ,MAAR;AACD;;;;EAnEiC,mB;;AAsEpC,IAAM,WAAW,SAAX,QAAW,CAAC,MAAD,EAAY;AAC3B,SAAO,CAAP,CAAS,QAAT,CAAkB;AAChB,qBAAiB,KADD;AAEhB,gBAFgB,wBAEH,IAFG,EAEG,MAFH,EAEW,MAFX,EAEmB,OAFnB,EAE4B,QAF5B,EAEsC;AACpD,UAAI,QAAQ,OAAO,QAAP,CAAgB,IAAhB,EAAsB,MAAtB,EAA8B,MAA9B,EAAsC,QAAtC,CAAZ;AACA,aAAO,QAAP,CAAgB,IAAhB,EAAsB,MAAtB,EAA8B,MAA9B,EAAsC,KAAtC,EAA6C,OAA7C,EAAsD,QAAtD;AACD;AALe,GAAlB;AAOD,CARD;;AAUA,OAAO,OAAP,GAAiB,qBAAjB;;;ACpFA;;;;;;;;;;;;AAEA,IAAM,sBAAsB,QAAQ,kBAAR,CAA5B;;eAII,QAAQ,iCAAR,C;;IADF,Y,YAAA,Y;;IAGI,2B;;;;;mCACkB;AACpB,aAAO,6BAAP;AACD;;;AAED,uCAAY,IAAZ,EAAkB;AAAA;;AAAA,+GACV,IADU;;AAGhB,QAAI,MAAK,KAAT,EAAgB;AAHA;AAIjB;;;;4BAEO,M,EAAQ,M,EAAQ;AACtB,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,QAD4B;AAElC,gBAAQ,MAF0B;AAGlC,gBAAQ;AAH0B,OAApC;AAKA,aAAO,IAAP;AACD;;;2BAEM,M,EAAQ,M,EAAQ,M,EAAQ;AAC7B,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,OAD4B;AAElC,gBAAQ,MAF0B;AAGlC,gBAAQ,MAH0B;AAIlC,gBAAQ;AAJ0B,OAApC;AAMA,aAAO,IAAP;AACD;;;2BAEM,M,EAAQ,M,EAAQ,M,EAAQ;AAC7B,WAAK,OAAL,CAAa,QAAb,CAAsB,KAAK,OAA3B,EAAoC;AAClC,cAAM,OAD4B;AAElC,gBAAQ,MAF0B;AAGlC,gBAAQ,MAH0B;AAIlC,gBAAQ;AAJ0B,OAApC;AAMA,aAAO,IAAP;AACD;;;gCAEW,I,EAAM,O,EAAS;AACzB,cAAQ,KAAK,IAAb;AACE,aAAK,QAAL;AACE,cAAI,aAAa,KAAK,KAAL,CAAW,KAAX,CAAiB,KAAK,CAAL,CAAO,KAAK,MAAZ,CAAjB,CAAjB;AACA,cAAI,KAAK,MAAL,KAAgB,SAApB,EAA+B,WAAW,MAAX,GAAoB,aAAa,KAAK,MAAlB,CAApB;AAC/B;AACF,aAAK,OAAL;AACA,aAAK,OAAL;AACE,cAAI,QAAQ,KAAK,IAAL,IAAa,OAAzB;AACA,cAAI,aAAa,KAAK,KAAL,CAAW,KAAX,CAAiB,KAAK,CAAL,CAAO,KAAK,MAAZ,CAAjB,CAAjB;AACA,cAAI,QAAQ,QAAQ,KAAK,MAAL,KAAgB,SAAhB,GAA4B,KAAK,KAAL,CAAW,QAAvC,GAAkD,KAAK,KAAL,CAAW,OAArE,GAA+E,KAAK,KAAL,CAAW,IAAtG;AACA,qBAAW,KAAX,GAAmB,KAAnB;AACA,cAAI,KAAK,MAAL,KAAgB,SAApB,EAA+B,WAAW,MAAX,GAAoB,aAAa,KAAK,MAAlB,CAApB;AAC/B,cAAI,KAAK,MAAL,KAAgB,SAApB,EAA+B;AAC7B,gBAAI,SAAS,KAAK,CAAL,CAAO,KAAK,MAAZ,EAAoB,KAAK,MAAzB,CAAb;AACA,gBAAI,OAAO,KAAK,KAAL,CAAW,KAAX,CAAiB,MAAjB,CAAX;AACA,iBAAK,KAAL,GAAa,KAAb;AACA,iBAAK,KAAL,CAAW,QAAX,CAAoB,MAApB,EAA4B,OAA5B,CAAoC,IAApC;AACD;AACD,cAAI,KAAK,SAAT,EAAoB;AAClB,gBAAI,SAAS,KAAK,MAAlB;AACA,gBAAI,WAAW,SAAf,EAA0B,SAAS,EAAT;AAC1B,iBAAK,SAAL,CAAe,KAAf,CAAqB,QAAQ,SAAS,MAAT,GAAkB,KAAK,MAA/B,GAAwC,SAAS,MAAT,GAAkB,KAAK,MAApF;AACD;AACD;AACF;AACE,6GAAkB,IAAlB,EAAwB,OAAxB;AAzBJ;AA2BD;;;4BAEO;AACN;;AAEA,WAAK,YAAL;AACD;;;mCAEc;AACb,WAAK,KAAL,CAAW,KAAX,GAAmB,OAAnB,CAA2B,UAAU,IAAV,EAAgB;AACzC,aAAK,MAAL,GAAc,CAAd;AACD,OAFD;AAGD;;;mCAEc,I,EAAM,M,EAAQ,M,EAAQ,K,EAAO,O,EAAS,Q,EAAU;AAC7D,UAAI,UAAU,MAAd,EACE;;AAEF,UAAI,SAAS,SAAS,QAAT,KAAsB,EAAnC;UACE,OAAO,KAAK,SAAS,MAAd,KAAyB,CADlC;;AAGA,UAAI,OAAO,SAAS,oBAAT,CAAX,EACE;;AAEF,UAAI,MAAM,SAAS,uBAAT,CAAV,EACE,MAAM,wCAAN;;AAEF,UAAI,QAAJ;UACE,IAAI,CAAC,OAAO,SAAS,GAAhB,IAAuB,OAAO,SAAS,GAAhB,CAAxB,IAAgD,CADtD;UAEE,IAAI,CAAC,OAAO,SAAS,GAAhB,IAAuB,OAAO,SAAS,GAAhB,CAAxB,IAAgD,CAFtD;UAGE,KAAK,OAAO,SAAS,GAAhB,IAAuB,OAAO,SAAS,GAAhB,CAH9B;UAIE,KAAK,OAAO,SAAS,GAAhB,IAAuB,OAAO,SAAS,GAAhB,CAJ9B;UAKE,QAAQ,KAAK,KAAL,CAAW,EAAX,EAAe,EAAf,CALV;;AAOA,iBAAY,SAAS,eAAT,MAA8B,OAA/B,GACT,SAAS,sBAAT,CADS,GAEX,SAAS,sBAAT,IACA,IADA,GAEA,KAAK,GAAL,CAAS,IAAT,EAAe,CAAC,CAAD,GAAK,SAAS,uBAAT,CAApB,CAJA;;AAMA,cAAQ,IAAR;;AAEA,UAAI,KAAK,MAAT,EAAiB;AACf,gBAAQ,IAAR,GAAe,CACb,SAAS,iBAAT,CADa,EAEb,WAAW,IAFE,EAGb,SAAS,YAAT,KAA0B,SAAS,MAAT,CAHb,EAIb,IAJa,CAIR,GAJQ,CAAf;;AAMA,gBAAQ,SAAR,GAAoB,KAApB;AACD,OARD,MAQO;AACL,gBAAQ,IAAR,GAAe,CACb,SAAS,WAAT,CADa,EAEb,WAAW,IAFE,EAGb,SAAS,MAAT,CAHa,EAIb,IAJa,CAIR,GAJQ,CAAf;;AAMA,gBAAQ,SAAR,GAAoB,KAApB;AACD;;AAED,cAAQ,SAAR,GAAoB,QAApB;AACA,cAAQ,YAAR,GAAuB,YAAvB;;AAEA,cAAQ,SAAR,CAAkB,CAAlB,EAAqB,CAArB;AACA,cAAQ,MAAR,CAAe,KAAf;AACA,cAAQ,QAAR,CACE,KAAK,MADP,EAEE,CAFF,EAGG,CAAC,IAAD,GAAQ,CAAT,GAAc,CAHhB;;AAMA,cAAQ,OAAR;AACD;;;mCAEc,I,EAAM,O,EAAS,Q,EAAU;AACtC,UAAI,QAAJ;UACE,SAAS,SAAS,QAAT,KAAsB,EADjC;UAEE,OAAO,KAAK,SAAS,MAAd,CAFT;;AAIA,UAAI,OAAO,SAAS,gBAAT,CAAX,EACE;;AAEF,iBAAY,SAAS,WAAT,MAA0B,OAA3B,GACT,SAAS,kBAAT,CADS,GAEX,SAAS,gBAAT,IAA6B,IAF7B;;AAIA,cAAQ,IAAR,GAAe,CAAC,SAAS,WAAT,IAAwB,SAAS,WAAT,IAAwB,GAAhD,GAAsD,EAAvD,IACb,QADa,GACF,KADE,GACM,SAAS,MAAT,CADrB;AAEA,cAAQ,SAAR,GAAqB,SAAS,YAAT,MAA2B,MAA5B,GACjB,KAAK,KAAL,IAAc,SAAS,kBAAT,CADG,GAElB,SAAS,mBAAT,CAFF;;AAIA,cAAQ,SAAR,GAAoB,MAApB;AACA,cAAQ,QAAR,CACE,KAAK,MADP,EAEE,KAAK,KAAL,CAAW,KAAK,SAAS,GAAd,IAAqB,OAAO,GAAvC,CAFF,EAGE,KAAK,KAAL,CAAW,KAAK,SAAS,GAAd,IAAqB,WAAW,CAA3C,CAHF;AAKD;;;;EAtKuC,mB;;AAyK1C,IAAM,WAAW,SAAX,QAAW,CAAC,MAAD,EAAY;AAC3B,SAAO,CAAP,CAAS,QAAT,CAAkB;AAChB,mBAAe,cADC;AAEhB,0BAAsB,EAFN;AAGhB,2BAAuB,GAHP;AAIhB,iBAJgB,yBAIF,IAJE,EAII,OAJJ,EAIa,QAJb,EAIuB;AACrC,aAAO,cAAP,CAAsB,IAAtB,EAA4B,OAA5B,EAAqC,QAArC;AACA,aAAO,SAAP,CAAiB,IAAjB,EAAuB,OAAvB,EAAgC,QAAhC;AACD,KAPe;AAQhB,iBARgB,yBAQF,IARE,EAQI,OARJ,EAQa,QARb,EAQuB;AACrC,aAAO,WAAP,CAAmB,IAAnB,EAAyB,OAAzB,EAAkC,QAAlC,EAA4C,OAAO,cAAnD;AACD,KAVe;AAWhB,kBAXgB,0BAWD,IAXC,EAWK,MAXL,EAWa,MAXb,EAWqB,OAXrB,EAW8B,QAX9B,EAWwC;AACtD,UAAI,QAAQ,OAAO,QAAP,CAAgB,IAAhB,EAAsB,MAAtB,EAA8B,MAA9B,EAAsC,QAAtC,CAAZ;AACA,aAAO,SAAP,CAAiB,IAAjB,EAAuB,MAAvB,EAA+B,MAA/B,EAAuC,KAAvC,EAA8C,OAA9C,EAAuD,QAAvD;AACA,aAAO,cAAP,CAAsB,IAAtB,EAA4B,MAA5B,EAAoC,MAApC,EAA4C,KAA5C,EAAmD,OAAnD,EAA4D,QAA5D;AACD;AAfe,GAAlB;AAiBD,CAlBD;;AAoBA,OAAO,OAAP,GAAiB,2BAAjB;;;ACrMA;;;;;;;;;;;;AAEA,IAAM,8BAA8B,QAAQ,2BAAR,CAApC;AACA,IAAM,wBAAwB,QAAQ,oBAAR,CAA9B;;IAEM,6B;;;;;mCACkB;AACpB,aAAO,+BAAP;AACD;;;AAED,yCAAY,IAAZ,EAAkB;AAAA;;AAAA,iHACV,IADU;;AAGhB,UAAK,CAAL,GAAS,sBAAsB,SAAtB,CAAgC,CAAzC;AACA,UAAK,WAAL,GAAmB,sBAAsB,SAAtB,CAAgC,WAAnD;AACA,UAAK,QAAL,GAAgB,sBAAsB,SAAtB,CAAgC,QAAhD;;AAEA,QAAI,MAAK,KAAT,EAAgB;AAPA;AAQjB;;;;gCAEW,C,EAAG,I,EAAM;AACnB,kHAAyB,CAAzB,EAA4B,IAA5B,EAAkC,IAAlC;AACD;;;4BAEO,C,EAAG;AACT,8GAAqB,CAArB,EAAwB,IAAxB;AACD;;;mCAEc,I,EAAM,M,EAAQ,M,EAAQ,K,EAAO,O,EAAS,Q,EAAU;AAC7D,UAAI,SAAS,SAAS,QAAT,KAAsB,EAAnC;AACA,UAAI,OAAO,SAAS,GAAhB,IAAuB,OAAO,SAAS,GAAhB,CAA3B,EAAiD;AAC/C,YAAI,OAAO,MAAX;AACA,iBAAS,MAAT;AACA,iBAAS,IAAT;AACD;AACD,kCAA4B,SAA5B,CAAsC,cAAtC,CAAqD,IAArD,CAA0D,IAA1D,EAAgE,IAAhE,EAAsE,MAAtE,EAA8E,MAA9E,EAAsF,KAAtF,EAA6F,OAA7F,EAAsG,QAAtG;AACD;;;;EA/ByC,2B;;AAkC5C,IAAM,WAAW,SAAX,QAAW,CAAC,MAAD,EAAY;AAC3B,SAAO,CAAP,CAAS,QAAT,CAAkB;AAChB,qBAAiB,KADD;AAEhB,gBAFgB,wBAEH,IAFG,EAEG,MAFH,EAEW,MAFX,EAEmB,OAFnB,EAE4B,QAF5B,EAEsC;AACpD,UAAI,QAAQ,OAAO,QAAP,CAAgB,IAAhB,EAAsB,MAAtB,EAA8B,MAA9B,EAAsC,QAAtC,CAAZ;AACA,aAAO,QAAP,CAAgB,IAAhB,EAAsB,MAAtB,EAA8B,MAA9B,EAAsC,KAAtC,EAA6C,OAA7C,EAAsD,QAAtD;AACA,aAAO,cAAP,CAAsB,IAAtB,EAA4B,MAA5B,EAAoC,MAApC,EAA4C,KAA5C,EAAmD,OAAnD,EAA4D,QAA5D;AACD;AANe,GAAlB;AAQD,CATD;;AAWA,OAAO,OAAP,GAAiB,6BAAjB;;;AClDA;;AAEA,IAAM,UAAU,QAAQ,WAAR,CAAhB;;AAEA,OAAO,OAAP,GAAiB,UAAC,GAAD,EAAS;AACxB,SAAO,QAAQ,GAAR,EAAa;AAClB,UAAM;AADY,GAAb,CAAP;AAGD,CAJD;;;ACJA;;AAEA,IAAM,UAAU,QAAQ,WAAR,CAAhB;;AAEA,OAAO,OAAP,GAAiB,UAAS,GAAT,EAAc;AAC7B,SAAO,QAAQ,GAAR,EAAa;AAClB,cAAU,MADQ;AAElB,UAAM;AAFY,GAAb,CAAP;AAID,CALD;;;ACJA;;AAEA,IAAM,UAAU,QAAQ,WAAR,CAAhB;;AAEA,OAAO,OAAP,GAAiB,UAAS,GAAT,EAAc,IAAd,EAAoB;AACnC,SAAO,QAAQ,GAAR,EAAa;AAClB,cAAU,MADQ;AAElB,UAAM,MAFY;AAGlB,UAAM,KAAK,SAAL,CAAe,IAAf;AAHY,GAAb,CAAP;AAKD,CAND;;;ACJA;;AAEA,IAAM,OAAO,QAAQ,MAAR,CAAb;AACA,IAAM,MAAM,QAAQ,WAAR,CAAZ;;SAKI,C;IAFF,I,MAAA,I;IACA,M,MAAA,M;;;AAGF,IAAM,WAAW,EAAjB;;AAIA,OAAO,OAAP,GAAiB,UAAS,GAAT,EAA4B;AAAA,MAAd,OAAc,yDAAJ,EAAI;;AAC3C,MAAI,YAAJ,CAAiB,IAAjB;;AAEA,SAAO,IAAI,KAAK,OAAT,CAAiB,UAAC,OAAD,EAAU,MAAV,EAAqB;AAC3C,QAAM,YAAY;AAChB,aADgB,mBACR,QADQ,EACE;AAChB,YAAI,YAAJ,CAAiB,KAAjB;AACA,gBAAQ,QAAR;AACD,OAJe;AAKhB,WALgB,iBAKV,MALU,EAKF;AACZ,YAAI,YAAJ,CAAiB,KAAjB;AACA,eAAO,MAAP;AACD;AARe,KAAlB;;AAWA,QAAM,OAAO,OAAO,EAAP,EAAW,QAAX,EAAqB,OAArB,EAA8B,SAA9B,EAAyC;AACpD;AADoD,KAAzC,CAAb;;AAIA,SAAK,IAAL;AACD,GAjBM,CAAP;AAkBD,CArBD;;;ACdA;;;;AAEA,IAAM,MAAM,QAAQ,QAAR,CAAZ;AACA,IAAM,QAAQ,QAAQ,cAAR,CAAd;;AAEA,IAAM,eAAe,SAAf,YAAe,GAAM;AACzB,MAAI,IAAI,YAAJ,EAAJ,EAAwB;AACtB,UAAM,cAAN,CAAqB,mDAArB;AACA,WAAO,IAAP;AACD;AACD,SAAO,KAAP;AACD,CAND;;AAQA,IAAM,qBAAqB,SAArB,kBAAqB,CAAC,IAAD,EAAU;AACnC,MAAM,MAAM,OAAO,QAAP,CAAgB,IAA5B;AACA,MAAM,QAAQ,IAAI,MAAJ,UAAkB,IAAlB,uBAAd;;AAEA,MAAM,UAAU,MAAM,IAAN,CAAW,GAAX,CAAhB;;AAEA,MAAI,CAAC,OAAD,IAAY,QAAQ,MAAR,KAAmB,CAAnC,EAAsC;AACpC,WAAO,IAAP;AACD;;AARkC,gCAUlB,OAVkB;;AAAA,MAUxB,EAVwB;;;AAYnC,SAAO,EAAP;AACD,CAbD;;AAeA,IAAM,eAAe,SAAf,YAAe,CAAC,GAAD,EAAQ;AAC3B,MAAI,CAAC,GAAL,EAAU,OAAO,IAAP;AACV,MAAM,OAAO,OAAO,QAAP,CAAgB,IAAhB,CAAqB,MAArB,CAA4B,CAA5B,CAAb;AACA,MAAM,SAAS,OAAO,KAAK,KAAL,CAAW,GAAX,CAAP,GAAyB,EAAxC;AACA,OAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,OAAO,MAA3B,EAAmC,GAAnC,EAAwC;AACtC,QAAM,OAAO,OAAO,CAAP,EAAU,KAAV,CAAgB,GAAhB,CAAb;AACA,QAAI,KAAK,CAAL,MAAY,GAAhB,EAAqB;AACnB,aAAO,KAAK,CAAL,CAAP;AACD;AACF;AACD,SAAO,IAAP;AACD,CAXD;;AAaA,IAAM,eAAe,SAAf,YAAe,CAAC,GAAD,EAAM,KAAN,EAAe;AAClC,MAAI,CAAC,GAAD,IAAQ,CAAC,KAAb,EAAoB;AACpB,MAAM,OAAO,OAAO,QAAP,CAAgB,IAAhB,CAAqB,MAArB,CAA4B,CAA5B,CAAb;AACA,MAAM,SAAS,OAAO,KAAK,KAAL,CAAW,GAAX,CAAP,GAAyB,EAAxC;;AAEA,MAAI,QAAQ,KAAZ;AACA,OAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,OAAO,MAAX,IAAqB,CAAC,KAAtC,EAA6C,GAA7C,EAAkD;AAChD,QAAM,OAAO,OAAO,CAAP,EAAU,KAAV,CAAgB,GAAhB,CAAb;AACA,QAAI,KAAK,CAAL,MAAY,GAAhB,EAAqB;AACnB,WAAK,CAAL,IAAU,KAAV;AACA,aAAO,CAAP,IAAY,KAAK,IAAL,CAAU,GAAV,CAAZ;AACA,cAAQ,IAAR;AACD;AACF;AACD,MAAI,CAAC,KAAL,EAAY;AACV,WAAO,IAAP,CAAY,CAAC,GAAD,EAAM,KAAN,EAAa,IAAb,CAAkB,GAAlB,CAAZ;AACD;;AAED,MAAM,UAAU,OAAO,IAAP,CAAY,GAAZ,CAAhB;AACA,SAAO,QAAP,CAAgB,IAAhB,SAA2B,OAA3B;AACD,CApBD;;AAsBA,IAAM,kBAAkB,SAAlB,eAAkB,CAAC,GAAD,EAAS;AAC/B,MAAI,CAAC,GAAL,EAAU;AACV,MAAM,OAAO,OAAO,QAAP,CAAgB,IAAhB,CAAqB,MAArB,CAA4B,CAA5B,CAAb;AACA,MAAM,SAAS,OAAO,KAAK,KAAL,CAAW,GAAX,CAAP,GAAyB,EAAxC;;AAEA,OAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,OAAO,MAA3B,EAAmC,GAAnC,EAAwC;AACtC,QAAM,OAAO,OAAO,CAAP,EAAU,KAAV,CAAgB,GAAhB,CAAb;AACA,QAAI,KAAK,CAAL,MAAY,GAAhB,EAAqB;AACnB,aAAO,MAAP,CAAc,CAAd,EAAiB,CAAjB;AACA;AACD;AACF;;AAED,MAAM,UAAU,OAAO,IAAP,CAAY,GAAZ,CAAhB;AACA,SAAO,QAAP,CAAgB,IAAhB,SAA2B,OAA3B;AACD,CAfD;;AAiBA,IAAM,UAAU,SAAV,OAAU,CAAC,QAAD,EAAW,SAAX,EAAsB,IAAtB,EAA+B;AAC7C,MAAM,OAAO,WAAW,YAAY,YAAY,MAAI,SAAJ,IAAmB,aAAW,IAAX,GAAoB,EAAvC,CAAZ,GAAyD,EAArE,CAAX,GAAsF,EAAnG;AACA,eAAa,MAAb,EAAqB,IAArB;AACD,CAHD;;AAKA,IAAM,UAAU,SAAV,OAAU,GAAM;AACpB,MAAM,OAAO,aAAa,MAAb,CAAb;AACA,MAAI,IAAJ,EAAU;AAAA,sBAC8B,KAAK,KAAL,CAAW,GAAX,CAD9B;;AAAA;;AAAA,QACA,QADA;AAAA,QACU,SADV;AAAA,QACqB,IADrB;;AAER,WAAO,EAAE,kBAAF,EAAY,oBAAZ,EAAuB,UAAvB,EAAP;AACD,GAHD,MAGO;AACL,WAAO,KAAP;AACD;AACF,CARD;;AAUA,OAAO,OAAP,GAAiB;AACf,4BADe;AAEf,wCAFe;AAGf,4BAHe;AAIf,4BAJe;AAKf,kCALe;AAMf,kBANe;AAOf;AAPe,CAAjB;;;AC/FA;;AAEA,IAAM,gBAAgB,QAAQ,kBAAR,CAAtB;AACA,IAAM,iBAAiB,QAAQ,mBAAR,CAAvB;AACA,IAAM,WAAW,QAAQ,aAAR,CAAjB;AACA,IAAM,mBAAmB,QAAQ,sBAAR,CAAzB;AACA,IAAM,oBAAoB,QAAQ,uBAAR,CAA1B;AACA,IAAM,eAAe,QAAQ,kBAAR,CAArB;AACA,IAAM,WAAW,QAAQ,aAAR,CAAjB;;AAEA,OAAO,OAAP,GAAiB;AACf,8BADe;AAEf,gCAFe;AAGf,oBAHe;AAIf,oCAJe;AAKf,sCALe;AAMf,4BANe;AAOf;AAPe,CAAjB;;;ACVA;;AAEA,IAAM,UAAU,QAAQ,iBAAR,CAAhB;;eAII,QAAQ,UAAR,C;;IADF,e,YAAA,e;;;AAGF,OAAO,OAAP,GAAiB,UAAC,QAAD,EAAW,SAAX,EAAyB;AACxC,MAAM,MAAM,gBAAgB,QAAhB,EAA0B,SAA1B,CAAZ;AACA,SAAO,QAAW,GAAX,eAAP;AACD,CAHD;;;ACRA;;AAEA,IAAM,UAAU,QAAQ,iBAAR,CAAhB;;AAEA,OAAO,OAAP,GAAiB,YAAM;AACrB,SAAO,QAAQ,2BAAR,CAAP;AACD,CAFD;;;ACJA;;AAEA,IAAM,OAAO,QAAQ,MAAR,CAAb;;AAEA,IAAM,MAAM,QAAQ,QAAR,CAAZ;;eAKI,QAAQ,UAAR,C;;IAFF,U,YAAA,U;IACA,c,YAAA,c;;gBAME,QAAQ,WAAR,C;;IAFF,Y,aAAA,Y;IACA,O,aAAA,O;;;AAGF,IAAM,MAAM,QAAQ,YAAR,CAAZ;;AAEA,IAAM,kBAAkB,SAAlB,eAAkB,CAAC,GAAD,EAAS;AAC/B,SAAO,KAAK,IAAL,CAAU;AACf,UAAM,IAAO,GAAP,aADS;AAEf,UAAM,IAAO,GAAP;AAFS,GAAV,CAAP;AAID,CALD;;AAOA,IAAM,2BAA2B,SAA3B,wBAA2B,CAAC,GAAD,EAAS;AACxC,MAAI,SAAJ,GAAgB,YAAhB;;AAEA,SAAO,gBAAgB,GAAhB,EAAqB,IAArB,CAA0B,UAAC,OAAD,EAAa;AAC5C,QAAI,gBAAJ,CAAqB,GAArB,EAA0B,OAA1B;AACA,QAAI,SAAJ,GAAgB,UAAhB,CAA2B,OAA3B;AACD,GAHM,CAAP;AAID,CAPD;;AASA,IAAM,sBAAsB,SAAtB,mBAAsB,CAAC,UAAD,EAAgB;AAC1C,SAAO,cACL,WAAW,IAAX,KAAoB,SADf,IAEL,WAAW,IAAX,KAAoB,SAFtB;AAGD,CAJD;;AAMA,OAAO,OAAP,GAAiB,UAAC,QAAD,EAAW,SAAX,EAAsB,IAAtB,EAA4B,WAA5B,EAA4C;AAC3D,SAAO,IAAI,KAAK,OAAT,CAAiB,UAAC,OAAD,EAAU,MAAV,EAAqB;AAC3C,QAAI,cAAJ,EAAoB;AAClB;AACD,KAFD,MAEO;AACL,UAAI,eAAe,QAAf,CAAJ,EAA8B;AAC5B,gBAAQ,QAAR,EAAkB,IAAI,gBAAJ,EAAlB;AACD,OAFD,MAEO;AACL,gBAAQ,QAAR,EAAkB,SAAlB,EAA6B,IAA7B;AACD;AACD,QAAE,cAAF,EAAkB,IAAlB,CAAuB,WAAvB;;AAEA,UAAI,MAAM,WAAW,QAAX,EAAqB,SAArB,EAAgC,IAAhC,CAAV;AACA,UAAI,eAAJ,CAAoB,GAApB;AACA,UAAM,aAAa,IAAI,aAAJ,CAAkB,GAAlB,CAAnB;;AAEA,UAAI,oBAAoB,UAApB,CAAJ,EAAqC;AACnC,YAAI,SAAJ,GAAgB,UAAhB,CAA2B,UAA3B;AACA;AACD,OAHD,MAGO;AACL,iCAAyB,GAAzB,EAA8B,IAA9B,CAAmC,OAAnC,EAA4C,MAA5C;AACD;AACF;AACF,GAtBM,CAAP;AAuBD,CAxBD;;;ACxCA;;AAEA,IAAM,OAAO,QAAQ,MAAR,CAAb;AACA,IAAM,MAAM,QAAQ,QAAR,CAAZ;;eAII,QAAQ,UAAR,C;;IADF,U,YAAA,U;;;AAGF,IAAM,UAAU,QAAQ,iBAAR,CAAhB;AACA,IAAM,gBAAgB,QAAQ,kBAAR,CAAtB;;AAEA,IAAM,kBAAkB,SAAlB,eAAkB,CAAC,KAAD,EAAQ,IAAR;AAAA,SAAiB,MAAS,IAAT,UAAoB,OAArC;AAAA,CAAxB;;AAEA,OAAO,OAAP,GAAiB,UAAC,MAAD,EAAY;AAC3B,SAAO,IAAI,KAAK,OAAT,CAAiB,UAAC,OAAD,EAAU,MAAV,EAAqB;AAC3C,QAAI,gBAAJ,CAAqB,MAArB;;AAEA,8CAAwC,MAAxC,EAAkD,IAAlD,CAAuD,gBAEjD;AAAA,UADJ,KACI,QADJ,KACI;;;AAEJ,UAAM,WAAW,SAAjB;AACA,UAAM,YAAY,MAAlB;;AAEA,oBAAc,QAAd,EAAwB,SAAxB,EAAmC,IAAnC,CAAwC,UAAC,IAAD,EAAU;;AAEhD,YAAM,WAAW,gBAAgB,KAAhB,EAAuB,MAAvB,CAAjB;AACA,YAAM,WAAW,gBAAgB,KAAhB,EAAuB,MAAvB,CAAjB;;;AAGA,YAAM,MAAM,WAAW,QAAX,EAAqB,SAArB,EAAgC,eAAhC,CAAZ;AACA,YAAI,gBAAJ,CAAqB,GAArB,EAA0B;AACxB,gBAAM,QADkB;AAExB,gBAAM,QAFkB;AAGxB,uBAAa;AAHW,SAA1B;;AAMA,gBAAQ;AACN,4BADM;AAEN,8BAFM;AAGN;AAHM,SAAR;AAKD,OAlBD;AAmBD,KA1BD;AA2BD,GA9BM,CAAP;AAgCD,CAjCD;;;ACdA;;AAEA,IAAM,MAAM,QAAQ,YAAR,CAAZ;;AAEA,OAAO,OAAP,GAAiB,UAAC,IAAD,EAAU;AACzB,SAAO,oCAAkC,IAAlC,SAAP;AACD,CAFD;;;ACJA;;AAEA,IAAM,UAAU,QAAQ,iBAAR,CAAhB;;AAEA,OAAO,OAAP,GAAiB,YAAM;AACrB,SAAO,QAAQ,aAAR,CAAP;AACD,CAFD;;;ACJA;;AAEA,IAAM,OAAO,QAAQ,MAAR,CAAb;AACA,IAAM,MAAM,QAAQ,QAAR,CAAZ;;AAEA,IAAM,WAAW,QAAQ,kBAAR,CAAjB;;eAII,QAAQ,WAAR,C;;IADF,O,YAAA,O;;;AAGF,OAAO,OAAP,GAAiB,YAAM;AACrB,SAAO,IAAI,KAAK,OAAT,CAAiB,UAAC,OAAD,EAAU,MAAV,EAAqB;AAAA,yBAKvC,IAAI,SAAJ,EALuC;;AAAA,QAGzC,UAHyC,kBAGzC,UAHyC;AAAA,QAIzC,UAJyC,kBAIzC,UAJyC;;;AAO3C,QAAM,OAAO;AACX,qBAAe,MADJ;AAEX,gBAAU,IAFC;AAGX,eAAS;AACP,mBAAW;AACT,qBAAW,WAAW,QAAX;AADF,SADJ;AAIP,mBAAW;AACT,qBAAW,WAAW,QAAX;AADF;AAJJ;AAHE,KAAb;;AAaA,aAAS,8BAAT,EAAyC,IAAzC,EAA+C,IAA/C,CAAoD,gBAE9C;AAAA,UADJ,EACI,QADJ,EACI;;AACJ,UAAI,gBAAJ,CAAqB,EAArB;AACA,cAAQ,SAAR,EAAmB,EAAnB;AAFI,sBAKA,QALA;AAAA,UAIF,IAJE,aAIF,IAJE;;AAMJ,QAAE,YAAF,EAAgB,IAAhB,CAAqB,QAArB;AACA,cAAQ,IAAR;AACD,KAVD;AAWD,GA/BM,CAAP;AAgCD,CAjCD;;;ACXA;;AAEA,IAAM,gBAAgB,QAAQ,WAAR,CAAtB;AACA,IAAM,SAAS,QAAQ,yBAAR,CAAf;;AAEA,OAAO,OAAP,GAAiB;AAEf,MAFe,kBAER;AACL,QAAM,KAAK,IAAI,aAAJ,EAAX;AACA,WAAO,SAAP,CAAiB,OAAjB,GAA2B,EAA3B;AACA,WAAO,EAAP;AACD;AANc,CAAjB;;;ACLA;;AAEA,IAAM,MAAM,QAAQ,QAAR,CAAZ;AACA,IAAM,kBAAkB,QAAQ,yBAAR,CAAxB;AACA,IAAM,UAAU,QAAQ,iBAAR,CAAhB;;SAMI,C;IAHF,I,MAAA,I;IACA,M,MAAA,M;IACA,I,MAAA,I;;;AAGF,IAAM,YAAY,GAAlB;;AAEA,IAAM,gBAAgB,SAAhB,aAAgB,GAAY;AAChC,OAAK,KAAL,GAAa,IAAb;AACA,OAAK,KAAL,GAAa,KAAb;AACA,OAAK,QAAL,GAAgB,EAAhB;AACA,OAAK,QAAL,GAAgB,GAAhB;AACD,CALD;;AAOA,cAAc,SAAd,GAA0B;AAExB,KAFwB,eAEpB,MAFoB,EAEZ;;AAEV,QAAM,aAAa,gBAAgB,MAAhB,EAAnB;;AAEA,QAAM,UAAU;AACd,cAAQ,OAAO,MADD;AAEd,oBAFc;AAGd,iBAAW,IAHG;AAId,mBAAa,IAJC;AAKd,4BALc;AAMd,aAAO;AANO,KAAhB;;AASA,SAAK,QAAL,CAAc,IAAd,CAAmB,OAAnB;AACA,WAAO,OAAP;AACD,GAjBuB;AAmBxB,UAnBwB,oBAmBf,SAnBe,EAmBJ;AAClB,QAAI,kBAAkB,IAAtB;AACA,QAAI,QAAQ,CAAZ;;AAEA,SAAK,KAAK,QAAV,EAAoB,UAAC,CAAD,EAAI,OAAJ,EAAgB;AAClC,UAAI,QAAQ,MAAR,KAAmB,UAAU,MAAjC,EAAyC;AACvC;AACA,YAAI,CAAC,QAAQ,SAAb,EAAwB;AACtB,kBAAQ,MAAR,GAAiB,SAAjB;AACA,kBAAQ,SAAR,GAAoB,IAApB;AACA,kBAAQ,KAAR,GAAgB,KAAhB;AACA,4BAAkB,OAAlB;AACA,iBAAO,KAAP;AACD;AACF;AACF,KAXD;;AAaA,QAAI,oBAAoB,IAAxB,EAA8B;AAC5B;AACA,wBAAkB,KAAK,GAAL,CAAS,SAAT,CAAlB;AACD;;AAED,QAAM,YAAY,UAAU,MAAV,CAAiB,YAAjB,EAAlB;AACA,oBAAgB,WAAhB,GAAiC,SAAjC,SAA8C,KAA9C;AACA,oBAAgB,KAAhB,GAAwB,KAAK,KAAL,EAAxB;AACA,WAAO,eAAP;AACD,GA7CuB;AA+CxB,eA/CwB,2BA+CR;AACd,SAAK,KAAL,GAAa,CAAb;AACA,SAAK,KAAL;AACA,SAAK,KAAK,QAAV,EAAoB,UAAC,CAAD,EAAI,OAAJ,EAAgB;AAClC,cAAQ,SAAR,GAAoB,KAApB;AACD,KAFD;AAGD,GArDuB;AAuDxB,mBAvDwB,+BAuDJ;AAClB,QAAI,UAAU,KAAd;;AAEA,SAAK,QAAL,GAAgB,KAAK,KAAK,QAAV,EAAoB,UAAC,OAAD,EAAa;AAC/C,UAAI,UAAU,CAAC,QAAQ,SAAvB;;AAEA,UAAI,QAAQ,KAAR,IAAiB,OAArB,EAA8B;AAC5B,kBAAU,IAAV;AACD;AACD,UAAI,OAAJ,EAAa;AACX,gBAAQ,UAAR,CAAmB,MAAnB;AACD;;AAED,aAAO,CAAC,OAAR;AACD,KAXe,CAAhB;;AAaA,QAAI,OAAJ,EAAa;AACX,WAAK,KAAL;AACD;AACF,GA1EuB;AA4ExB,OA5EwB,mBA4EhB;AAAA,QAEJ,QAFI,GAGF,IAHE,CAEJ,QAFI;;;AAKN,SAAK,QAAL,EAAe,UAAC,CAAD,EAAI,OAAJ,EAAgB;AAC7B,UAAI,QAAQ,GAAZ;AACA,UAAI,SAAU,MAAM,SAAS,MAA7B;AACA,UAAI,MAAM,SAAS,QAAQ,KAA3B;;AAEA,cAAQ,UAAR,CAAmB,GAAnB,CAAuB;AACrB,aAAQ,GAAR,MADqB;AAErB,eAAU,KAAV,MAFqB;AAGrB,gBAAW,MAAX;AAHqB,OAAvB;;AAMA,cAAQ,MAAR,CAAe,MAAf;AACD,KAZD;AAaD,GA9FuB;AAgGxB,QAhGwB,oBAgGf;AACP,SAAK,OAAL,CAAa,QAAb;AACD,GAlGuB;AAoGxB,SApGwB,qBAoGd;AACR,WAAO,KAAK,KAAZ;AACD,GAtGuB;AAwGxB,aAxGwB,uBAwGZ,QAxGY,EAwGF;AACpB,YAAQ,WAAR,CAAoB,QAApB;AACD,GA1GuB;AA4GxB,OA5GwB,mBA4GhB;AACN,SAAK,MAAL,GAAc,EAAd;AACA,SAAK,UAAL,GAAkB,CAAC,CAAnB;AACA,SAAK,OAAL,GAAe,CAAf;AACA,QAAI,KAAK,KAAT,EAAgB;AACd,mBAAa,KAAK,KAAlB;AACD;AACD,SAAK,OAAL,CAAa,OAAb;AACD,GApHuB;AAsHxB,UAtHwB,oBAsHf,OAtHe,EAsHN,IAtHM,EAsHA;AACtB,QAAI,KAAK,OAAL,KAAiB,SAArB,EAAgC,MAAM,yBAAN;AAChC,QAAI,MAAM,KAAK,MAAL,CAAY,MAAtB;AACA,QAAI,OAAO,CAAX,EAAc,OAAO,KAAK,OAAL,EAAP;AACd,QAAM,OAAO,KAAK,MAAL,CAAY,MAAM,CAAlB,CAAb;AACA,SAAK,IAAL,CAAU,OAAO,IAAP,EAAa;AACrB;AADqB,KAAb,CAAV;AAGD,GA9HuB;AAgIxB,SAhIwB,qBAgIL;AAAA,QAAX,IAAW,yDAAJ,CAAC,CAAG;;AACjB,QAAI,MAAM,KAAK,MAAL,CAAY,MAAtB;AACA,QAAI,MAAM,CAAN,IAAW,CAAC,IAAhB,EAAsB;AACpB,WAAK,MAAL,CAAY,MAAM,CAAlB,EAAqB,IAArB,CAA0B,IAA1B;AACD;AACD,WAAO,KAAK,MAAL,CAAY,IAAZ,CAAiB,EAAjB,CAAP;AACD,GAtIuB;AAwIxB,WAxIwB,uBAwIZ;AACV,QAAI,KAAK,UAAL,GAAkB,CAAtB,EAAyB;AACzB,SAAK,KAAL,GAAa,IAAb;AACA,QAAI,KAAK,KAAT,EAAgB;AACd,mBAAa,KAAK,KAAlB;AACD;AACD,YAAQ,gBAAR;AACD,GA/IuB;AAiJxB,YAjJwB,wBAiJX;AACX,SAAK,KAAL,GAAa,KAAb;AACA,SAAK,IAAL,CAAU,KAAK,UAAL,GAAkB,CAA5B;AACA,YAAQ,kBAAR;AACD,GArJuB;AAuJxB,MAvJwB,gBAuJnB,CAvJmB,EAuJF;AAAA,QAAd,OAAc,yDAAJ,EAAI;;AACpB,QAAM,SAAS,IAAf;;AAEA,QAAI,MAAM,CAAN,KAAY,KAAK,KAAK,MAAL,CAAY,MAA7B,IAAuC,IAAI,CAA/C,EAAkD;;AAElD,SAAK,UAAL,GAAkB,CAAlB;AACA,QAAM,QAAQ,KAAK,MAAL,CAAY,CAAZ,CAAd;AACA,UAAM,OAAN,CAAc,UAAC,IAAD,EAAU;AACtB,UAAI,OAAO,IAAP,KAAgB,QAApB,EAA8B;AAC5B,YAAI,SAAJ,GAAgB,aAAhB,CAA8B,IAA9B;AACA;AACD;AACD,WAAK,OAAL,CAAa,MAAb,CAAoB,WAApB,CAAgC,IAAhC,EAAsC,OAAtC;AACD,KAND;;AAQA,QAAI,CAAC,QAAQ,OAAb,EAAsB;AACpB,WAAK,OAAL,CAAa,SAAb;AACD;;AAED,QAAI,KAAK,KAAT,EAAgB;;AAEhB,SAAK,KAAL,GAAa,WAAW,YAAM;AAC5B,UAAI,CAAC,OAAO,QAAP,CAAgB,OAAhB,CAAL,EAA+B;AAC7B,gBAAQ,mBAAR;AACD;AACF,KAJY,EAIV,KAAK,QAJK,CAAb;AAKD,GAjLuB;AAmLxB,UAnLwB,sBAmLD;AAAA,QAAd,OAAc,yDAAJ,EAAI;;AACrB,SAAK,OAAL,CAAa,OAAb;;AAEA,QAAM,aAAa,KAAK,UAAL,GAAkB,CAArC;AACA,QAAI,aAAa,CAAjB,EAAoB;AAClB,WAAK,UAAL,GAAkB,CAAC,CAAnB;AACA,WAAK,OAAL,CAAa,SAAb;AACA,aAAO,KAAP;AACD;;AAED,SAAK,IAAI,IAAI,CAAb,EAAgB,IAAI,UAApB,EAAgC,GAAhC,EAAqC;AACnC,WAAK,IAAL,CAAU,CAAV,EAAa,OAAO,OAAP,EAAgB;AAC3B,iBAAS;AADkB,OAAhB,CAAb;AAGD;;AAED,SAAK,IAAL,CAAU,UAAV;AACA,WAAO,IAAP;AACD,GArMuB;AAuMxB,UAvMwB,sBAuMD;AAAA,QAAd,OAAc,yDAAJ,EAAI;;AACrB,QAAM,aAAa,KAAK,UAAL,GAAkB,CAArC;AACA,QAAI,cAAc,KAAK,MAAL,CAAY,MAA9B,EAAsC;AACpC,WAAK,UAAL,GAAkB,KAAK,MAAL,CAAY,MAAZ,GAAqB,CAAvC;AACA,aAAO,KAAP;AACD;;AAED,SAAK,IAAL,CAAU,UAAV,EAAsB,OAAtB;AACA,WAAO,IAAP;AACD,GAhNuB;AAkNxB,WAlNwB,uBAkNZ;AACV,SAAK,UAAL,GAAkB,CAAC,CAAnB;AACA,SAAK,UAAL;AACD,GArNuB;AAuNxB,SAvNwB,qBAuNP;AAAA,sCAAN,IAAM;AAAN,UAAM;AAAA;;AACf,QAAM,eAAe,KAAK,KAAL,EAArB;AACA,SAAK,KAAK,QAAV,EAAoB,UAAC,CAAD,EAAI,OAAJ,EAAgB;AAClC,UAAI,QAAQ,SAAZ,EAAuB;AACrB,gBAAQ,MAAR,CAAe,MAAf,CAAsB,SAAtB,CAAgC,YAAhC,EAA8C,KAA9C,CAAoD,QAAQ,MAA5D,EAAoE,IAApE;AACD;AACF,KAJD;AAKD,GA9NuB;AAgOxB,WAhOwB,qBAgOd,SAhOc,EAgOH;AACnB,QAAI,kBAAkB,IAAtB;AACA,SAAK,KAAK,QAAV,EAAoB,UAAC,CAAD,EAAI,OAAJ,EAAgB;AAClC,UAAI,QAAQ,UAAR,CAAmB,CAAnB,MAA0B,SAA9B,EAAyC;AACvC,0BAAkB,OAAlB;AACA,eAAO,KAAP;AACD;AACF,KALD;AAMA,WAAO,gBAAgB,MAAvB;AACD;AAzOuB,CAA1B;;AA4OA,OAAO,OAAP,GAAiB,aAAjB;;;ACjQA;;IAGE,K,GACE,I,CADF,K;;;AAGF,IAAM,WAAW,SAAX,QAAW,CAAC,GAAD,EAAS;AACxB,SAAO,MAAM,GAAN,EAAW,UAAC,GAAD,EAAM,KAAN,EAAgB;AAChC,WAAO,UAAU,UAAV,GAAuB,QAAvB,GAAkC,KAAzC;AACD,GAFM,CAAP;AAGD,CAJD;;AAMA,OAAO,OAAP,GAAiB,QAAjB;;;ACZA;;AAEA,IAAM,SAAS,QAAQ,WAAR,CAAf;AACA,IAAM,WAAW,QAAQ,aAAR,CAAjB;AACA,IAAM,eAAe,QAAQ,kBAAR,CAArB;;AAEA,OAAO,OAAP,GAAiB;AACf,gBADe;AAEf,oBAFe;AAGf;AAHe,CAAjB;;;ACNA;;;;AAEA,IAAM,eAAe,SAAf,YAAe,CAAC,IAAD,EAAU;AAC7B,iBAAe,IAAf,yCAAe,IAAf;AACE,SAAK,QAAL;AACE,aAAO,aAAa,IAAb,CAAP;AACF,SAAK,SAAL;AACE,aAAO,cAAc,IAAd,CAAP;AACF;AACE,aAAO,aAAa,IAAb,CAAP;AANJ;AAQD,CATD;;AAWA,IAAM,eAAe,SAAf,YAAe,CAAC,GAAD,EAAS;AAC5B,SAAO,QAAQ,EAAR,GAAa,GAAb,GAAmB,GAA1B;AACD,CAFD;;AAIA,IAAM,eAAe,SAAf,YAAe,CAAC,GAAD,EAAS;AAC5B,SAAO,QAAQ,QAAR,GAAmB,GAAnB,GAAyB,GAAhC;AACD,CAFD;;AAIA,IAAM,gBAAgB,SAAhB,aAAgB,CAAC,IAAD,EAAU;AAC9B,SAAO,OAAO,GAAP,GAAa,GAApB;AACD,CAFD;;AAIA,OAAO,OAAP,GAAiB,YAAjB;;;ACzBA;;IAGE,S,GACE,I,CADF,S;;;AAGF,IAAM,SAAS,SAAT,MAAS,CAAC,GAAD,EAAS;AACtB,SAAO,UAAU,GAAV,EAAe,UAAC,GAAD,EAAM,KAAN,EAAgB;AACpC,WAAO,UAAU,QAAV,GAAqB,UAArB,GAAkC,KAAzC;AACD,GAFM,CAAP;AAGD,CAJD;;AAMA,OAAO,OAAP,GAAiB,MAAjB;;;ACZA;;AAEA,IAAM,iBAAiB,SAAjB,cAAiB,CAAC,QAAD,EAAW,SAAX,EAAyB;AAC9C,SAAO,YAAY,SAAnB;AACD,CAFD;;AAIA,IAAM,kBAAkB,SAAlB,eAAkB,CAAC,QAAD,EAAW,SAAX,EAAyB;AAC/C,MAAI,eAAe,QAAf,CAAJ,EAA8B,OAAO,4BAAP;AAC9B,0BAAsB,QAAtB,SAAkC,SAAlC;AACD,CAHD;;AAKA,IAAM,aAAa,SAAb,UAAa,CAAC,QAAD,EAAW,SAAX,EAAsB,IAAtB,EAA+B;AAChD,MAAI,eAAe,QAAf,CAAJ,EAA8B,OAAO,4BAAP;AAC9B,0BAAsB,QAAtB,SAAkC,SAAlC,SAA+C,IAA/C;AACD,CAHD;;AAKA,OAAO,OAAP,GAAiB;AACf,gCADe;AAEf,kCAFe;AAGf;AAHe,CAAjB;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC9FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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})","'use strict';\n\nconst {\n  extend\n} = $;\n\nconst cache = {\n  lastFileUsed: '',\n  files: {}\n};\n\nconst assertFileName = (name) => {\n  if (!name) {\n    throw 'Missing file name';\n  }\n};\n\n\n/**\n * Global application cache\n */\nmodule.exports = {\n\n  getCachedFile(name) {\n    assertFileName(name);\n    return cache.files[name];\n  },\n\n  updateCachedFile(name, updates) {\n    assertFileName(name);\n    if (!cache.files[name]) {\n      cache.files[name] = {};\n    }\n    extend(cache.files[name], updates);\n  },\n\n  getLastFileUsed() {\n    return cache.lastFileUsed;\n  },\n\n  setLastFileUsed(file) {\n    cache.lastFileUsed = file;\n  }\n};","'use strict';\n\nconst Editor = require('../editor');\nconst TracerManager = require('../tracer_manager');\nconst DOM = require('../dom/setup');\n\nconst {\n  showLoadingSlider,\n  hideLoadingSlider\n} = require('../dom/loading_slider');\n\nconst Cache = require('./cache');\n\nconst state = {\n  isLoading: null,\n  editor: null,\n  tracerManager: null,\n  categories: null,\n  loadedScratch: null,\n  wikiList: null\n};\n\nconst initState = (tracerManager) => {\n  state.isLoading = false;\n  state.editor = new Editor(tracerManager);\n  state.tracerManager = tracerManager;\n  state.categories = {};\n  state.loadedScratch = null;\n  state.wikiList = [];\n};\n\n/**\n * Global application singleton.\n */\nconst App = function () {\n\n  this.getIsLoading = () => {\n    return state.isLoading;\n  };\n\n  this.setIsLoading = (loading) => {\n    state.isLoading = loading;\n    if (loading) {\n      showLoadingSlider();\n    } else {\n      hideLoadingSlider();\n    }\n  };\n\n  this.getEditor = () => {\n    return state.editor;\n  };\n\n  this.getCategories = () => {\n    return state.categories;\n  };\n\n  this.getCategory = (name) => {\n    return state.categories[name];\n  };\n\n  this.setCategories = (categories) => {\n    state.categories = categories;\n  };\n\n  this.updateCategory = (name, updates) => {\n    $.extend(state.categories[name], updates);\n  };\n\n  this.getTracerManager = () => {\n    return state.tracerManager;\n  };\n\n  this.getLoadedScratch = () => {\n    return state.loadedScratch;\n  };\n\n  this.setLoadedScratch = (loadedScratch) => {\n    state.loadedScratch = loadedScratch;\n  };\n\n  this.getWikiList = () => {\n    return state.wikiList;\n  };\n\n  this.setWikiList = (wikiList) => {\n    state.wikiList = wikiList;\n  };\n\n  this.hasWiki = (wiki) => {\n    return ~state.wikiList.indexOf(wiki);\n  };\n\n  const tracerManager = TracerManager.init();\n\n  initState(tracerManager);\n  DOM.setup(tracerManager);\n\n};\n\nApp.prototype = Cache;\n\nmodule.exports = App;\n","'use strict';\n\n/**\n * This is the main application instance.\n * Gets populated on page load. \n */\nmodule.exports = {};","'use strict';\n\nconst app = require('../app');\nconst Server = require('../server');\nconst showAlgorithm = require('./show_algorithm');\n\nconst {\n  each\n} = $;\n\nconst getAlgorithmDOM = (category, subList, algorithm) => {\n  return $('<button class=\"indent\">')\n    .append(subList[algorithm])\n    .attr('data-algorithm', algorithm)\n    .attr('data-category', category)\n    .click(function () {\n      Server.loadAlgorithm(category, algorithm).then((data) => {\n        showAlgorithm(category, algorithm, data);\n      });\n    });\n\n  $('#list').append($algorithm);\n};\n\nconst addCategoryToDOM = (category) => {\n\n  const {\n    name: categoryName,\n    list: categorySubList\n  } = app.getCategory(category);\n\n  const $category = $('<button class=\"category\">')\n    .append('<i class=\"fa fa-fw fa-caret-right\">')\n    .append(categoryName)\n    .attr('data-category', category);\n\n  $category.click(function () {\n    const $self = $(this);\n    $self.toggleClass('open');\n    $self.next().toggleClass('collapse');\n    $self.find('i.fa').toggleClass('fa-caret-right fa-caret-down');\n  });\n\n  const $algorithms = $('<div class=\"algorithms collapse\">');\n  $('#list').append($category).append($algorithms);\n\n  each(categorySubList, (algorithm) => {\n    const $algorithm = getAlgorithmDOM(category, categorySubList, algorithm);\n    $algorithms.append($algorithm);\n  });\n};\n\nmodule.exports = () => {\n  each(app.getCategories(), addCategoryToDOM);\n};\n","'use strict';\n\nconst Server = require('../server');\n\nconst {\n  each\n} = $;\n\nconst addFileToDOM = (category, algorithm, file, explanation) => {\n  var $file = $('<button>')\n    .append(file)\n    .attr('data-file', file)\n    .click(function () {\n      Server.loadFile(category, algorithm, file, explanation);\n      $('.files_bar > .wrapper > button').removeClass('active');\n      $(this).addClass('active');\n    });\n  $('.files_bar > .wrapper').append($file);\n  return $file;\n};\n\nmodule.exports = (category, algorithm, files, requestedFile) => {\n  $('.files_bar > .wrapper').empty();\n\n  each(files, (file, explanation) => {\n    var $file = addFileToDOM(category, algorithm, file, explanation);\n    if (requestedFile && requestedFile == file) $file.click();\n  });\n\n  if (!requestedFile) $('.files_bar > .wrapper > button').first().click();\n  $('.files_bar > .wrapper').scroll();\n};","'use strict';\n\nconst showAlgorithm = require('./show_algorithm');\nconst addCategories = require('./add_categories');\nconst showDescription = require('./show_description');\nconst addFiles = require('./add_files');\nconst showFirstAlgorithm = require('./show_first_algorithm');\nconst showRequestedAlgorithm = require('./show_requested_algorithm');\nconst showWiki = require('./show_wiki');\n\nmodule.exports = {\n  showAlgorithm,\n  addCategories,\n  showDescription,\n  addFiles,\n  showFirstAlgorithm,\n  showRequestedAlgorithm,\n  showWiki\n};","'use strict';\n\nconst showLoadingSlider = () => {\n  $('#loading-slider').removeClass('loaded');\n};\n\nconst hideLoadingSlider = () => {\n  $('#loading-slider').addClass('loaded');\n};\n\nmodule.exports = {\n  showLoadingSlider,\n  hideLoadingSlider\n};\n","'use strict';\n\nconst create = () => {\n  const $container = $('<section class=\"module_wrapper\">');\n  $('.module_container').append($container);\n  return $container;\n};\n\nmodule.exports = {\n  create\n};\n","'use strict';\n\nconst setupDividers = require('./setup_dividers');\nconst setupDocument = require('./setup_document');\nconst setupFilesBar = require('./setup_files_bar');\nconst setupInterval = require('./setup_interval');\nconst setupModuleContainer = require('./setup_module_container');\nconst setupTabContainer = require('./setup_tab_container');\nconst setupSideMenu = require('./setup_side_menu');\nconst setupTopMenu = require('./setup_top_menu');\nconst setupWindow = require('./setup_window');\n\n/**\n * Initializes elements once the app loads in the DOM.\n */\nconst setup = () => {\n\n  $('.btn input').click((e) => {\n    e.stopPropagation();\n  });\n\n  // dividers\n  setupDividers();\n\n  // document\n  setupDocument();\n\n  // files bar\n  setupFilesBar();\n\n  // interval\n  setupInterval();\n\n  // module container\n  setupModuleContainer();\n\n  // tab container\n  setupTabContainer();\n\n  // side menu\n  setupSideMenu();\n\n  // top menu\n  setupTopMenu();\n\n  // window\n  setupWindow();\n\n};\n\nmodule.exports = {\n  setup\n};\n","'use strict';\n\nconst app = require('../../app');\n\nconst addDividerToDom = (divider) => {\n  const [vertical, $first, $second] = divider;\n  const $parent = $first.parent();\n  const thickness = 5;\n\n  const $divider = $('<div class=\"divider\">');\n\n  let dragging = false;\n  if (vertical) {\n    $divider.addClass('vertical');\n\n    let _left = -thickness / 2;\n    $divider.css({\n      top: 0,\n      bottom: 0,\n      left: _left,\n      width: thickness\n    });\n\n    let x;\n    $divider.mousedown(({\n      pageX\n    }) => {\n      x = pageX;\n      dragging = true;\n    });\n\n    $(document).mousemove(({\n      pageX\n    }) => {\n      if (dragging) {\n        const new_left = $second.position().left + pageX - x;\n        let percent = new_left / $parent.width() * 100;\n        percent = Math.min(90, Math.max(10, percent));\n        $first.css('right', (100 - percent) + '%');\n        $second.css('left', percent + '%');\n        x = pageX;\n        app.getTracerManager().resize();\n        $('.files_bar > .wrapper').scroll();\n      }\n    });\n\n    $(document).mouseup(function(e) {\n      dragging = false;\n    });\n\n  } else {\n\n    $divider.addClass('horizontal');\n    const _top = -thickness / 2;\n    $divider.css({\n      top: _top,\n      height: thickness,\n      left: 0,\n      right: 0\n    });\n\n    let y;\n    $divider.mousedown(function({\n      pageY\n    }) {\n      y = pageY;\n      dragging = true;\n    });\n\n    $(document).mousemove(function({\n      pageY\n    }) {\n      if (dragging) {\n        const new_top = $second.position().top + pageY - y;\n        let percent = new_top / $parent.height() * 100;\n        percent = Math.min(90, Math.max(10, percent));\n        $first.css('bottom', (100 - percent) + '%');\n        $second.css('top', percent + '%');\n        y = pageY;\n        app.getTracerManager().resize();\n      }\n    });\n\n    $(document).mouseup(function(e) {\n      dragging = false;\n    });\n  }\n\n  $second.append($divider);\n};\n\nmodule.exports = () => {\n  const dividers = [\n    ['v', $('.sidemenu'), $('.workspace')],\n    ['v', $('.viewer_container'), $('.editor_container')],\n    ['h', $('.data_container'), $('.code_container')]\n  ];\n  for (let i = 0; i < dividers.length; i++) {\n    addDividerToDom(dividers[i]);\n  }\n};","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = () => {\n  $(document).on('click', 'a', function (e) {\n    const href = $(this).attr('href');\n    if (/^(https?:\\/\\/).+/.test(href)) {\n      e.preventDefault();\n      if (!window.open(href, '_blank')) {\n        alert('Please allow popups for this site');\n      }\n    }\n  });\n\n  $(document).mouseup(function (e) {\n    app.getTracerManager().command('mouseup', e);\n  });\n};\n","'use strict';\n\nconst definitelyBigger = (x, y) => x > (y + 2);\n\nmodule.exports = () => {\n\n  $('.files_bar > .btn-left').click(() => {\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const scrollLeft = $wrapper.scrollLeft();\n\n    $($wrapper.children('button').get().reverse()).each(function() {\n      const left = $(this).position().left;\n      const right = left + $(this).outerWidth();\n      if (0 > left) {\n        $wrapper.scrollLeft(scrollLeft + right - clipWidth);\n        return false;\n      }\n    });\n  });\n\n  $('.files_bar > .btn-right').click(() => {\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const scrollLeft = $wrapper.scrollLeft();\n\n    $wrapper.children('button').each(function() {\n      const left = $(this).position().left;\n      const right = left + $(this).outerWidth();\n      if (clipWidth < right) {\n        $wrapper.scrollLeft(scrollLeft + left);\n        return false;\n      }\n    });\n  });\n\n  $('.files_bar > .wrapper').scroll(function() {\n\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const $left = $wrapper.children('button:first-child');\n    const $right = $wrapper.children('button:last-child');\n    const left = $left.position().left;\n    const right = $right.position().left + $right.outerWidth();\n\n    if (definitelyBigger(0, left) && definitelyBigger(clipWidth, right)) {\n      const scrollLeft = $wrapper.scrollLeft();\n      $wrapper.scrollLeft(scrollLeft + clipWidth - right);\n      return;\n    }\n\n    const lefter = definitelyBigger(0, left);\n    const righter = definitelyBigger(right, clipWidth);\n    $wrapper.toggleClass('shadow-left', lefter);\n    $wrapper.toggleClass('shadow-right', righter);\n    $('.files_bar > .btn-left').attr('disabled', !lefter);\n    $('.files_bar > .btn-right').attr('disabled', !righter);\n  });\n}\n","'use strict';\n\nconst app = require('../../app');\nconst Toast = require('../toast');\n\nconst {\n  parseFloat\n} = Number;\n\nconst minInterval = 0.1;\nconst maxInterval = 10;\nconst startInterval = 0.5;\nconst stepInterval = 0.1;\n\nconst normalize = (sec) => {\n\n\n  let interval;\n  let message;\n  if (sec < minInterval) {\n    interval = minInterval;\n    message = `Interval of ${sec} seconds is too low. Setting to min allowed interval of ${minInterval} second(s).`;\n  } else if (sec > maxInterval) {\n    interval = maxInterval;\n    message = `Interval of ${sec} seconds is too high. Setting to max allowed interval of ${maxInterval} second(s).`;\n  } else {\n    interval = sec;\n    message = `Interval has been set to ${sec} second(s).`\n  }\n\n  return [interval, message];\n};\n\nmodule.exports = () => {\n\n  const $interval = $('#interval');\n  $interval.val(startInterval);\n  $interval.attr({\n    max: maxInterval,\n    min: minInterval,\n    step: stepInterval\n  });\n\n  $('#interval').on('change', function() {\n    const tracerManager = app.getTracerManager();\n    const [seconds, message] = normalize(parseFloat($(this).val()));\n\n    $(this).val(seconds);\n    tracerManager.interval = seconds * 1000;\n    Toast.showInfoToast(message);\n  });\n};\n","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = () => {\n\n  const $module_container = $('.module_container');\n\n  $module_container.on('mousedown', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousedown(e);\n  });\n\n  $module_container.on('mousemove', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousemove(e);\n  });\n\n  $module_container.on('DOMMouseScroll mousewheel', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousewheel(e);\n  });\n}\n","'use strict';\n\nconst app = require('../../app');\nconst Server = require('../../server');\nconst showAlgorithm = require('../show_algorithm');\n\nlet sidemenu_percent;\n\nmodule.exports = () => {\n  $('#navigation').click(() => {\n    const $sidemenu = $('.sidemenu');\n    const $workspace = $('.workspace');\n\n    $sidemenu.toggleClass('active');\n    $('.nav-dropdown').toggleClass('fa-caret-down fa-caret-up');\n\n    if ($sidemenu.hasClass('active')) {\n      $sidemenu.css('right', (100 - sidemenu_percent) + '%');\n      $workspace.css('left', sidemenu_percent + '%');\n\n    } else {\n      sidemenu_percent = $workspace.position().left / $('body').width() * 100;\n      $sidemenu.css('right', 0);\n      $workspace.css('left', 0);\n    }\n\n    app.getTracerManager().resize();\n  });\n\n  $('#documentation').click(function () {\n    $('#btn_doc').click();\n  });\n\n  $('#powered-by').click(() => {\n    $('#powered-by-list button').toggleClass('collapse');\n  });\n\n  $('#scratch-paper').click(() => {\n    const category = 'scratch';\n    const algorithm = app.getLoadedScratch();\n    Server.loadAlgorithm(category, algorithm).then((data) => {\n      showAlgorithm(category, algorithm, data);\n    });\n  });\n};","'use strict';\n\nmodule.exports = () => {\n  $('.tab_bar > button').click(function () {\n    $('.tab_bar > button').removeClass('active');\n    $('.tab_container > .tab').removeClass('active');\n    $(this).addClass('active');\n    $($(this).attr('data-target')).addClass('active');\n  });\n};","'use strict';\n\nconst app = require('../../app');\nconst Server = require('../../server');\nconst Toast = require('../toast');\nconst TopMenu = require('../top_menu');\n\nmodule.exports = () => {\n\n  // shared\n  $('#shared').mouseup(function () {\n    $(this).select();\n  });\n\n  $('#btn_share').click(function () {\n\n    const $icon = $(this).find('.fa-share');\n    $icon.addClass('fa-spin fa-spin-faster');\n\n    Server.shareScratchPaper().then((url) => {\n      $icon.removeClass('fa-spin fa-spin-faster');\n      $('#shared').removeClass('collapse');\n      $('#shared').val(url);\n      Toast.showInfoToast('Shareable link is created.');\n    });\n  });\n\n  // control\n\n  const $btnRun = $('#btn_run');\n  const $btnTrace = $('#btn_trace');\n  const $btnPause = $('#btn_pause');\n  const $btnPrev = $('#btn_prev');\n  const $btnNext = $('#btn_next');\n\n  // initially, control buttons are disabled\n  TopMenu.disableFlowControl();\n\n  $btnRun.click(() => {\n    $btnTrace.click();\n    $btnPause.removeClass('active');\n    $btnRun.addClass('active');\n    TopMenu.enableFlowControl();\n    var err = app.getEditor().execute();\n    if (err) {\n      console.error(err);\n      Toast.showErrorToast(err);\n      TopMenu.resetTopMenuButtons();\n    }\n  });\n\n  $btnPause.click(() => {\n    $btnRun.toggleClass('active');\n    $btnPause.toggleClass('active');\n    if (app.getTracerManager().isPause()) {\n      app.getTracerManager().resumeStep();\n    } else {\n      app.getTracerManager().pauseStep();\n    }\n  });\n\n  $btnPrev.click(() => {\n    $btnRun.removeClass('active');\n    $btnPause.addClass('active');\n    app.getTracerManager().pauseStep();\n    app.getTracerManager().prevStep();\n  });\n\n  $btnNext.click(() => {\n    $btnRun.removeClass('active');\n    $btnPause.addClass('active');\n    app.getTracerManager().pauseStep();\n    app.getTracerManager().nextStep();\n  });\n\n};\n","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = function() {\n  $(window).resize(function() {\n    app.getTracerManager().resize();\n  });\n};\n","'use strict';\n\nconst app = require('../app');\n\nconst {\n  isScratchPaper\n} = require('../utils');\n\nconst showDescription = require('./show_description');\nconst addFiles = require('./add_files');\n\nmodule.exports = (category, algorithm, data, requestedFile) => {\n  let $menu;\n  let category_name;\n  let algorithm_name;\n\n  if (isScratchPaper(category)) {\n    $menu = $('#scratch-paper');\n    category_name = 'Scratch Paper';\n    algorithm_name = algorithm ? 'Shared' : 'Temporary';\n  } else {\n    $menu = $(`[data-category=\"${category}\"][data-algorithm=\"${algorithm}\"]`);\n    const categoryObj = app.getCategory(category);\n    category_name = categoryObj.name;\n    algorithm_name = categoryObj.list[algorithm];\n  }\n\n  $('.sidemenu button').removeClass('active');\n  $menu.addClass('active');\n\n  $('#category').html(category_name);\n  $('#algorithm').html(algorithm_name);\n  $('#tab_desc > .wrapper').empty();\n  $('.files_bar > .wrapper').empty();\n  $('#explanation').html('');\n\n  app.setLastFileUsed(null);\n  app.getEditor().clearContent();\n\n  const {\n    files\n  } = data;\n\n  delete data.files;\n\n  showDescription(data);\n  addFiles(category, algorithm, files, requestedFile);\n};","'use strict';\n\nconst {\n  isArray\n} = Array;\n\nconst {\n  each\n} = $;\n\nmodule.exports = (data) => {\n  const $container = $('#tab_desc > .wrapper');\n  $container.empty();\n\n  each(data, (key, value) => {\n\n    if (key) {\n      $container.append($('<h3>').html(key));\n    }\n\n    if (typeof value === 'string') {\n      $container.append($('<p>').html(value));\n\n    } else if (isArray(value)) {\n\n      const $ul = $('<ul class=\"applications\">');\n      $container.append($ul);\n\n      value.forEach((li) => {\n        $ul.append($('<li>').html(li));\n      });\n\n    } else if (typeof value === 'object') {\n\n      const $ul = $('<ul class=\"complexities\">');\n      $container.append($ul);\n\n      each(value, (prop) => {\n        const $wrapper = $('<div class=\"complexity\">');\n        const $type = $('<span class=\"complexity-type\">').html(`${prop}: `);\n        const $value = $('<span class=\"complexity-value\">').html(`${value[prop]}`);\n\n        $wrapper.append($type).append($value);\n\n        $ul.append($('<li>').append($wrapper));\n      });\n    }\n  });\n};\n","'use strict';\n\n// click the first algorithm in the first category\nmodule.exports = () => {\n  $('#list .category').first().click();\n  $('#list .category + .algorithms > .indent').first().click();\n};\n","'use strict';\n\nconst Server = require('../server');\nconst showAlgorithm = require('./show_algorithm');\n\nmodule.exports = (category, algorithm, file) => {\n  $(`.category[data-category=\"${category}\"]`).click();\n  Server.loadAlgorithm(category, algorithm).then((data) => {\n    showAlgorithm(category, algorithm, data, file);\n  });\n};\n","'use strict';\n\nconst app = require('../app');\nconst Server = require('../server');\nconst converter = new showdown.Converter({tables: true});\n\nmodule.exports = (wiki) => {\n  Server.loadWiki(wiki).then((data) => {\n    $('#tab_doc > .wrapper').html(converter.makeHtml(`#${wiki}\\n${data}`));\n    $('#tab_doc').scrollTop(0);\n    $('#tab_doc > .wrapper a').click(function (e) {\n      const href = $(this).attr('href');\n      if (app.hasWiki(href)) {\n        e.preventDefault();\n        module.exports(href);\n      }\n    });\n  });\n};","'use strict';\n\nconst showToast = (data, type) => {\n  const $toast = $(`<div class=\"toast ${type}\">`).append(data);\n\n  $('.toast_container').append($toast);\n  setTimeout(() => {\n    $toast.fadeOut(() => {\n      $toast.remove();\n    });\n  }, 3000);\n};\n\nconst showErrorToast = (err) => {\n  showToast(err, 'error');\n};\n\nconst showInfoToast = (err) => {\n  showToast(err, 'info');\n};\n\nmodule.exports = {\n  showErrorToast,\n  showInfoToast\n};","'use strict';\n\nconst app = require('../app');\n\nconst flowControlBtns = [ $('#btn_pause'), $('#btn_prev'), $('#btn_next') ];\nconst setFlowControlState = (isDisabled) => {\n  flowControlBtns.forEach($btn => $btn.attr('disabled', isDisabled));\n};\n\nconst enableFlowControl = () => {\n  setFlowControlState(false);\n};\n\nconst disableFlowControl = () => {\n  setFlowControlState(true);\n};\n\nconst resetTopMenuButtons = () => {\n  $('.top-menu-buttons button').removeClass('active');\n  disableFlowControl();\n  app.getEditor().unhighlightLine();\n};\n\nconst setInterval = (val) => {\n  $('#interval').val(interval);\n};\n\nconst activateBtnPause = () => {\n  $('#btn_pause').addClass('active');\n};\n\nconst deactivateBtnPause = () => {\n  $('#btn_pause').removeClass('active');\n};\n\nmodule.exports = {\n  enableFlowControl,\n  disableFlowControl,\n  resetTopMenuButtons,\n  setInterval,\n  activateBtnPause,\n  deactivateBtnPause\n};\n","'use strict';\n\nmodule.exports = function(id) {\n  const editor = ace.edit(id);\n\n  editor.setOptions({\n    enableBasicAutocompletion: true,\n    enableSnippets: true,\n    enableLiveAutocompletion: true\n  });\n\n  editor.setTheme('ace/theme/tomorrow_night_eighties');\n  editor.session.setMode('ace/mode/javascript');\n  editor.$blockScrolling = Infinity;\n\n  return editor;\n};","'use strict';\n\nconst execute = (tracerManager, code, dataLines) => {\n  // all modules available to eval are obtained from window\n  try {\n    tracerManager.deallocateAll();\n    const lines = code.split('\\n');\n    const newLines = [];\n    lines.forEach((line, i) => {\n      newLines.push(line.replace(/(.+\\. *_wait *)(\\( *\\))/g, `$1(${i - dataLines})`));\n    });\n    eval(newLines.join('\\n'));\n    tracerManager.visualize();\n  } catch (err) {\n    return err;\n  } finally {\n    tracerManager.removeUnallocated();\n  }\n};\n\nconst executeData = (tracerManager, algoData) => {\n  return execute(tracerManager, algoData);\n};\n\nconst executeDataAndCode = (tracerManager, algoData, algoCode) => {\n  const dataLines = algoData.split('\\n').length;\n  return execute(tracerManager, `${algoData}\\n${algoCode}`, dataLines);\n};\n\nmodule.exports = {\n  executeData,\n  executeDataAndCode\n};","'use strict';\n\nconst app = require('../app');\nconst createEditor = require('./create');\nconst Executor = require('./executor');\nconst TopMenu = require('../dom/top_menu');\n\nfunction Editor(tracerManager) {\n  if (!tracerManager) {\n    throw 'Cannot create Editor. Missing the tracerManager';\n  }\n\n  ace.require('ace/ext/language_tools');\n  const Range = ace.require(\"ace/range\").Range;\n\n  this.dataEditor = createEditor('data');\n  this.codeEditor = createEditor('code');\n\n  // Setting data\n\n  this.setData = (data) => {\n    this.dataEditor.setValue(data, -1);\n  };\n\n  this.setCode = (code) => {\n    this.codeEditor.setValue(code, -1);\n  };\n\n  this.setContent = (({\n    data,\n    code\n  }) => {\n    this.setData(data);\n    this.setCode(code);\n  });\n\n  // Clearing data\n\n  this.clearData = () => {\n    this.dataEditor.setValue('');\n  };\n\n  this.clearCode = () => {\n    this.codeEditor.setValue('');\n  };\n\n  this.clearContent = () => {\n    this.clearData();\n    this.clearCode();\n  };\n\n  this.execute = () => {\n    const data = this.dataEditor.getValue();\n    const code = this.codeEditor.getValue();\n    return Executor.executeDataAndCode(tracerManager, data, code);\n  };\n\n  this.highlightLine = (lineNumber) => {\n    const session = this.codeEditor.getSession();\n    if (this.marker) session.removeMarker(this.marker);\n    this.marker = session.addMarker(new Range(lineNumber, 0, lineNumber, Infinity), \"executing\", \"line\", true);\n  };\n\n  this.unhighlightLine = () => {\n    const session = this.codeEditor.getSession();\n    if (this.marker) session.removeMarker(this.marker);\n  };\n\n  // listeners\n\n  this.dataEditor.on('change', () => {\n    const data = this.dataEditor.getValue();\n    const lastFileUsed = app.getLastFileUsed();\n    if (lastFileUsed) {\n      app.updateCachedFile(lastFileUsed, {\n        data\n      });\n    }\n    Executor.executeData(tracerManager, data);\n    TopMenu.resetTopMenuButtons();\n  });\n\n  this.codeEditor.on('change', () => {\n    const code = this.codeEditor.getValue();\n    const lastFileUsed = app.getLastFileUsed();\n    if (lastFileUsed) {\n      app.updateCachedFile(lastFileUsed, {\n        code\n      });\n    }\n    tracerManager.reset();\n    TopMenu.resetTopMenuButtons();\n  });\n}\n\nmodule.exports = Editor;","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('./app');\nconst AppConstructor = require('./app/constructor');\nconst DOM = require('./dom');\nconst Server = require('./server');\n\nconst modules = require('./module');\n\nconst {\n  extend\n} = $;\n\n$.ajaxSetup({\n  cache: false,\n  dataType: 'text'\n});\n\nconst {\n  isScratchPaper\n} = require('./utils');\n\nconst {\n  getHashValue,\n  getParameterByName,\n  getPath\n} = require('./server/helpers');\n\n// set global promise error handler\nRSVP.on('error', function (reason) {\n  console.assert(false, reason);\n});\n\n$(() => {\n\n  // initialize the application and attach in to the instance module\n  const appConstructor = new AppConstructor();\n  extend(true, app, appConstructor);\n\n  // load modules to the global scope so they can be evaled\n  extend(true, window, modules);\n\n  Server.loadCategories().then((data) => {\n    app.setCategories(data);\n    DOM.addCategories();\n\n    // determine if the app is loading a pre-existing scratch-pad\n    // or the home page\n    const {\n      category,\n      algorithm,\n      file\n    } = getPath();\n    if (isScratchPaper(category)) {\n      if (algorithm) {\n        Server.loadScratchPaper(algorithm).then(({category, algorithm, data}) => {\n          DOM.showAlgorithm(category, algorithm, data);\n        });\n      } else {\n        Server.loadAlgorithm(category).then((data) => {\n          DOM.showAlgorithm(category, null, data);\n        });\n      }\n    } else if (category && algorithm) {\n      DOM.showRequestedAlgorithm(category, algorithm, file);\n    } else {\n      DOM.showFirstAlgorithm();\n    }\n  });\n\n  Server.loadWikiList().then((data) => {\n    app.setWikiList(data.wikis);\n\n    DOM.showWiki('Tracer');\n  });\n\n  var v1LoadedScratch = getHashValue('scratch-paper');\n  var v2LoadedScratch = getParameterByName('scratch-paper');\n  var vLoadedScratch = v1LoadedScratch || v2LoadedScratch;\n  if (vLoadedScratch) {\n    window.location.href = window.location.protocol + '//' + window.location.host + window.location.pathname + '#path=scratch/' + vLoadedScratch;\n  }\n\n});","'use strict';\n\nconst Array2D = require('./array2d');\n\nconst random = (N, min, max) => {\n  return Array2D.random(1, N, min, max)[0];\n};\n\nconst randomSorted = (N, min, max)=> {\n  return Array2D.randomSorted(1, N, min, max)[0];\n};\n\nmodule.exports = {\n  random,\n  randomSorted\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, M, min, max) => {\n  if (!N) N = 10;\n  if (!M) M = 10;\n  if (min === undefined) min = 1;\n  if (max === undefined) max = 9;\n  var D = [];\n  for (var i = 0; i < N; i++) {\n    D.push([]);\n    for (var j = 0; j < M; j++) {\n      D[i].push(Integer.random(min, max));\n    }\n  }\n  return D;\n};\n\nconst randomSorted = (N, M, min, max) => {\n  return random(N, M, min, max).map(function (arr) {\n    return arr.sort(function (a, b) {\n      return a - b;\n    });\n  });\n};\n\nmodule.exports = {\n  random,\n  randomSorted\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, min, max) => {\n  if (!N) N = 7;\n  if (!min) min = 1;\n  if (!max) max = 10;\n  var C = new Array(N);\n  for (var i = 0; i < N; i++) C[i] = new Array(2);\n  for (var i = 0; i < N; i++)\n    for (var j = 0; j < C[i].length; j++)\n      C[i][j] = Integer.random(min, max);\n  return C;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst random = (N, ratio) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) {\n    G[i] = new Array(N);\n    for (var j = 0; j < N; j++) {\n      if (i != j) {\n        G[i][j] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\nconst Array1D = require('./array1d');\nconst Array2D = require('./array2d');\nconst CoordinateSystem = require('./coordinate_system');\nconst DirectedGraph = require('./directed_graph');\nconst UndirectedGraph = require('./undirected_graph');\nconst WeightedDirectedGraph = require('./weighted_directed_graph');\nconst WeightedUndirectedGraph = require('./weighted_undirected_graph');\n\nmodule.exports = {\n  Integer,\n  Array1D,\n  Array2D,\n  CoordinateSystem,\n  DirectedGraph,\n  UndirectedGraph,\n  WeightedDirectedGraph,\n  WeightedUndirectedGraph\n};","'use strict';\n\nconst random = (min, max) => {\n  return (Math.random() * (max - min + 1) | 0) + min;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst random = (N, ratio) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) G[i] = new Array(N);\n  for (var i = 0; i < N; i++) {\n    for (var j = 0; j < N; j++) {\n      if (i > j) {\n        G[i][j] = G[j][i] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, ratio, min, max) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  if (!min) min = 1;\n  if (!max) max = 5;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) {\n    G[i] = new Array(N);\n    for (var j = 0; j < N; j++) {\n      if (i != j && (Math.random() * (1 / ratio) | 0) == 0) {\n        G[i][j] = Integer.random(min, max);\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, ratio, min, max) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  if (!min) min = 1;\n  if (!max) max = 5;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) G[i] = new Array(N);\n  for (var i = 0; i < N; i++) {\n    for (var j = 0; j < N; j++) {\n      if (i > j && (Math.random() * (1 / ratio) | 0) == 0) {\n        G[i][j] = G[j][i] = Integer.random(min, max);\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nvar tracers = require('./tracer');\nvar datas = require('./data');\n\nconst {\n  extend\n} = $;\n\nmodule.exports = extend(true, {}, tracers, datas);","'use strict';\n\nconst Array2DTracer = require('./array2d');\n\nclass Array1DTracer extends Array2DTracer {\n  static getClassName() {\n    return 'Array1DTracer';\n  }\n\n  constructor(name) {\n    super(name);\n  }\n\n  _notify(idx, v) {\n    super._notify(0, idx, v);\n    return this;\n  }\n\n  _denotify(idx) {\n    super._denotify(0, idx);\n    return this;\n  }\n\n  _select(s, e) {\n    if (e === undefined) {\n      super._select(0, s);\n    } else {\n      super._selectRow(0, s, e);\n    }\n    return this;\n  }\n\n  _deselect(s, e) {\n    if (e === undefined) {\n      super._deselect(0, s);\n    } else {\n      super._deselectRow(0, s, e);\n    }\n    return this;\n  }\n\n  processStep(step, options) {\n    super.processStep(step, options);\n    if (this.chartTracer) {\n      const newStep = $.extend(true, {}, step);\n      newStep.capsule = this.chartTracer.capsule;\n      newStep.s = newStep.sy;\n      newStep.e = newStep.ey;\n      if (newStep.s === undefined) newStep.s = newStep.y;\n      delete newStep.x;\n      delete newStep.y;\n      delete newStep.sx;\n      delete newStep.sy;\n      delete newStep.ex;\n      delete newStep.ey;\n      this.chartTracer.processStep(newStep, options);\n    }\n  }\n\n  setData(D) {\n    return super.setData([D]);\n  }\n}\n\nmodule.exports = Array1DTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass Array2DTracer extends Tracer {\n  static getClassName() {\n    return 'Array2DTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.colorClass = {\n      selected: 'selected',\n      notified: 'notified'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  _notify(x, y, v) {\n    this.manager.pushStep(this.capsule, {\n      type: 'notify',\n      x: x,\n      y: y,\n      v: v\n    });\n    return this;\n  }\n\n  _denotify(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'denotify',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _select(sx, sy, ex, ey) {\n    this.pushSelectingStep('select', null, arguments);\n    return this;\n  }\n\n  _selectRow(x, sy, ey) {\n    this.pushSelectingStep('select', 'row', arguments);\n    return this;\n  }\n\n  _selectCol(y, sx, ex) {\n    this.pushSelectingStep('select', 'col', arguments);\n    return this;\n  }\n\n  _deselect(sx, sy, ex, ey) {\n    this.pushSelectingStep('deselect', null, arguments);\n    return this;\n  }\n\n  _deselectRow(x, sy, ey) {\n    this.pushSelectingStep('deselect', 'row', arguments);\n    return this;\n  }\n\n  _deselectCol(y, sx, ex) {\n    this.pushSelectingStep('deselect', 'col', arguments);\n    return this;\n  }\n\n  _separate(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'separate',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _separateRow(x) {\n    this._separate(x, -1);\n    return this;\n  }\n\n  _separateCol(y) {\n    this._separate(-1, y);\n    return this;\n  }\n\n  _deseparate(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'deseparate',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _deseparateRow(x) {\n    this._deseparate(x, -1);\n    return this;\n  }\n\n  _deseparateCol(y) {\n    this._deseparate(-1, y);\n    return this;\n  }\n\n  pushSelectingStep() {\n    var args = Array.prototype.slice.call(arguments);\n    var type = args.shift();\n    var mode = args.shift();\n    args = Array.prototype.slice.call(args.shift());\n    var coord;\n    switch (mode) {\n      case 'row':\n        coord = {\n          x: args[0],\n          sy: args[1],\n          ey: args[2]\n        };\n        break;\n      case 'col':\n        coord = {\n          y: args[0],\n          sx: args[1],\n          ex: args[2]\n        };\n        break;\n      default:\n        if (args[2] === undefined && args[3] === undefined) {\n          coord = {\n            x: args[0],\n            y: args[1]\n          };\n        } else {\n          coord = {\n            sx: args[0],\n            sy: args[1],\n            ex: args[2],\n            ey: args[3]\n          };\n        }\n    }\n    var step = {\n      type: type\n    };\n    $.extend(step, coord);\n    this.manager.pushStep(this.capsule, step);\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'notify':\n        if (step.v !== undefined) {\n          var $row = this.$table.find('.mtbl-row').eq(step.x);\n          var $col = $row.find('.mtbl-col').eq(step.y);\n          $col.text(refineByType(step.v));\n        }\n      case 'denotify':\n      case 'select':\n      case 'deselect':\n        var colorClass = step.type == 'select' || step.type == 'deselect' ? this.colorClass.selected : this.colorClass.notified;\n        var addClass = step.type == 'select' || step.type == 'notify';\n        var sx = step.sx;\n        var sy = step.sy;\n        var ex = step.ex;\n        var ey = step.ey;\n        if (sx === undefined) sx = step.x;\n        if (sy === undefined) sy = step.y;\n        if (ex === undefined) ex = step.x;\n        if (ey === undefined) ey = step.y;\n        this.paintColor(sx, sy, ex, ey, colorClass, addClass);\n        break;\n      case 'separate':\n        this.deseparate(step.x, step.y);\n        this.separate(step.x, step.y);\n        break;\n      case 'deseparate':\n        this.deseparate(step.x, step.y);\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  setData(D) {\n    this.viewX = this.viewY = 0;\n    this.paddingH = 6;\n    this.paddingV = 3;\n    this.fontSize = 16;\n\n    if (super.setData.apply(this, arguments)) {\n      this.$table.find('.mtbl-row').each(function (i) {\n        $(this).find('.mtbl-col').each(function (j) {\n          $(this).text(refineByType(D[i][j]));\n        });\n      });\n      return true;\n    }\n\n    this.$table.empty();\n    for (var i = 0; i < D.length; i++) {\n      var $row = $('<div class=\"mtbl-row\">');\n      this.$table.append($row);\n      for (var j = 0; j < D[i].length; j++) {\n        var $col = $('<div class=\"mtbl-col\">')\n          .css(this.getCellCss())\n          .text(refineByType(D[i][j]));\n        $row.append($col);\n      }\n    }\n    this.resize();\n\n    return false;\n  }\n\n  resize() {\n    super.resize();\n\n    this.refresh();\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearColor();\n    this.deseparateAll();\n  }\n\n  getCellCss() {\n    return {\n      padding: this.paddingV.toFixed(1) + 'px ' + this.paddingH.toFixed(1) + 'px',\n      'font-size': this.fontSize.toFixed(1) + 'px'\n    };\n  }\n\n  refresh() {\n    super.refresh();\n\n    var $parent = this.$table.parent();\n    var top = $parent.height() / 2 - this.$table.height() / 2 + this.viewY;\n    var left = $parent.width() / 2 - this.$table.width() / 2 + this.viewX;\n    this.$table.css('margin-top', top);\n    this.$table.css('margin-left', left);\n  }\n\n  mousedown(e) {\n    super.mousedown(e);\n\n    this.dragX = e.pageX;\n    this.dragY = e.pageY;\n    this.dragging = true;\n  }\n\n  mousemove(e) {\n    super.mousemove(e);\n\n    if (this.dragging) {\n      this.viewX += e.pageX - this.dragX;\n      this.viewY += e.pageY - this.dragY;\n      this.dragX = e.pageX;\n      this.dragY = e.pageY;\n      this.refresh();\n    }\n  }\n\n  mouseup(e) {\n    super.mouseup(e);\n\n    this.dragging = false;\n  }\n\n  mousewheel(e) {\n    super.mousewheel(e);\n\n    e.preventDefault();\n    e = e.originalEvent;\n    var delta = (e.wheelDelta !== undefined && e.wheelDelta) ||\n      (e.detail !== undefined && -e.detail);\n    var weight = 1.01;\n    var ratio = delta > 0 ? 1 / weight : weight;\n    if (this.fontSize < 4 && ratio < 1) return;\n    if (this.fontSize > 40 && ratio > 1) return;\n    this.paddingV *= ratio;\n    this.paddingH *= ratio;\n    this.fontSize *= ratio;\n    this.$table.find('.mtbl-col').css(this.getCellCss());\n    this.refresh();\n  }\n\n  paintColor(sx, sy, ex, ey, colorClass, addClass) {\n    for (var i = sx; i <= ex; i++) {\n      var $row = this.$table.find('.mtbl-row').eq(i);\n      for (var j = sy; j <= ey; j++) {\n        var $col = $row.find('.mtbl-col').eq(j);\n        if (addClass) $col.addClass(colorClass);\n        else $col.removeClass(colorClass);\n      }\n    }\n  }\n\n  clearColor() {\n    this.$table.find('.mtbl-col').removeClass(Object.keys(this.colorClass).join(' '));\n  }\n\n  separate(x, y) {\n    this.$table.find('.mtbl-row').each(function (i) {\n      var $row = $(this);\n      if (i == x) {\n        $row.after($('<div class=\"mtbl-empty-row\">').attr('data-row', i))\n      }\n      $row.find('.mtbl-col').each(function (j) {\n        var $col = $(this);\n        if (j == y) {\n          $col.after($('<div class=\"mtbl-empty-col\">').attr('data-col', j));\n        }\n      });\n    });\n  }\n\n  deseparate(x, y) {\n    this.$table.find('[data-row=' + x + ']').remove();\n    this.$table.find('[data-col=' + y + ']').remove();\n  }\n\n  deseparateAll() {\n    this.$table.find('.mtbl-empty-row, .mtbl-empty-col').remove();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$table = tracer.capsule.$table = $('<div class=\"mtbl-table\">');\n  tracer.$container.append(tracer.$table);\n};\n\nmodule.exports = Array2DTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nclass ChartTracer extends Tracer {\n  static getClassName() {\n    return 'ChartTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.color = {\n      selected: 'rgb(0, 0, 255)',\n      notified: 'rgb(255, 0, 0)',\n      default: 'rgb(136, 136, 136)'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (super.setData.apply(this, arguments)) {\n      this.chart.config.data.datasets[0].data = C;\n      this.chart.update();\n      return true;\n    }\n\n    var color = [];\n    for (var i = 0; i < C.length; i++) color.push(this.color.default);\n    this.chart.config.data = {\n      labels: C.map(String),\n      datasets: [{\n        backgroundColor: color,\n        data: C\n      }]\n    };\n    this.chart.update();\n  }\n\n  _notify(s, v) {\n    this.manager.pushStep(this.capsule, {\n      type: 'notify',\n      s: s,\n      v: v\n    });\n    return this;\n  }\n\n  _denotify(s) {\n    this.manager.pushStep(this.capsule, {\n      type: 'denotify',\n      s: s\n    });\n    return this;\n  }\n\n  _select(s, e) {\n    this.manager.pushStep(this.capsule, {\n      type: 'select',\n      s: s,\n      e: e\n    });\n    return this;\n  }\n\n  _deselect(s, e) {\n    this.manager.pushStep(this.capsule, {\n      type: 'deselect',\n      s: s,\n      e: e\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'notify':\n        if (step.v !== undefined) {\n          this.chart.config.data.datasets[0].data[step.s] = step.v;\n          this.chart.config.data.labels[step.s] = step.v.toString();\n        }\n      case 'denotify':\n      case 'select':\n      case 'deselect':\n        let color = step.type == 'notify' ? this.color.notified : step.type == 'select' ? this.color.selected : this.color.default;\n        if (step.e !== undefined)\n          for (var i = step.s; i <= step.e; i++)\n            this.chart.config.data.datasets[0].backgroundColor[i] = color;\n        else\n          this.chart.config.data.datasets[0].backgroundColor[step.s] = color;\n        this.chart.update();\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  resize() {\n    super.resize();\n\n    this.chart.resize();\n  }\n\n  clear() {\n    super.clear();\n\n    const data = this.chart.config.data;\n    if (data.datasets.length) {\n      const backgroundColor = data.datasets[0].backgroundColor;\n      for (let i = 0; i < backgroundColor.length; i++) {\n        backgroundColor[i] = this.color.default;\n      }\n      this.chart.update();\n    }\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$wrapper = tracer.capsule.$wrapper = $('<canvas class=\"mchrt-chart\">');\n  tracer.$container.append(tracer.$wrapper);\n  tracer.chart = tracer.capsule.chart = new Chart(tracer.$wrapper, {\n    type: 'bar',\n    data: {\n      labels: [],\n      datasets: []\n    },\n    options: {\n      scales: {\n        yAxes: [{\n          ticks: {\n            beginAtZero: true\n          }\n        }]\n      },\n      animation: false,\n      legend: false,\n      responsive: true,\n      maintainAspectRatio: false\n    }\n  });\n};\n\nmodule.exports = ChartTracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nclass CoordinateSystemTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'CoordinateSystemTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (Tracer.prototype.setData.apply(this, arguments)) return true;\n\n    this.graph.clear();\n    var nodes = [];\n    var edges = [];\n    for (var i = 0; i < C.length; i++)\n      nodes.push({\n        id: this.n(i),\n        x: C[i][0],\n        y: C[i][1],\n        label: '' + i,\n        size: 1,\n        color: this.color.default\n      });\n    this.graph.read({\n      nodes: nodes,\n      edges: edges\n    });\n    this.s.camera.goTo({\n      x: 0,\n      y: 0,\n      angle: 0,\n      ratio: 1\n    });\n    this.refresh();\n\n    return false;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          if (this.graph.edges(edgeId)) {\n            var edge = this.graph.edges(edgeId);\n            edge.color = color;\n            this.graph.dropEdge(edgeId).addEdge(edge);\n          } else {\n            this.graph.addEdge({\n              id: this.e(step.target, step.source),\n              source: this.n(step.source),\n              target: this.n(step.target),\n              color: color,\n              size: 1\n            });\n          }\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  e(v1, v2) {\n    if (v1 > v2) {\n      var temp = v1;\n      v1 = v2;\n      v2 = temp;\n    }\n    return 'e' + v1 + '_' + v2;\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#0ff';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n\n  drawEdge(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(\n      source[prefix + 'x'],\n      source[prefix + 'y']\n    );\n    context.lineTo(\n      target[prefix + 'x'],\n      target[prefix + 'y']\n    );\n    context.stroke();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = CoordinateSystemTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass DirectedGraphTracer extends Tracer {\n  static getClassName() {\n    return 'DirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.color = {\n      selected: '#0f0',\n      visited: '#f00',\n      left: '#000',\n      default: '#888'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  _setTreeData(G, root) {\n    this.manager.pushStep(this.capsule, {\n      type: 'setTreeData',\n      arguments: arguments\n    });\n    return this;\n  }\n\n  _visit(target, source) {\n    this.manager.pushStep(this.capsule, {\n      type: 'visit',\n      target: target,\n      source: source\n    });\n    return this;\n  }\n\n  _leave(target, source) {\n    this.manager.pushStep(this.capsule, {\n      type: 'leave',\n      target: target,\n      source: source\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'setTreeData':\n        this.setTreeData.apply(this, step.arguments);\n        break;\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          var edge = this.graph.edges(edgeId);\n          edge.color = color;\n          this.graph.dropEdge(edgeId).addEdge(edge);\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  setTreeData(G, root, undirected) {\n    var tracer = this;\n\n    root = root || 0;\n    var maxDepth = -1;\n\n    var chk = new Array(G.length);\n    var getDepth = function (node, depth) {\n      if (chk[node]) throw \"the given graph is not a tree because it forms a circuit\";\n      chk[node] = true;\n      if (maxDepth < depth) maxDepth = depth;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) getDepth(i, depth + 1);\n      }\n    };\n    getDepth(root, 1);\n\n    if (this.setData(G, undirected)) return true;\n\n    var place = function (node, x, y) {\n      var temp = tracer.graph.nodes(tracer.n(node));\n      temp.x = x;\n      temp.y = y;\n    };\n\n    var wgap = 1 / (maxDepth - 1);\n    var dfs = function (node, depth, top, bottom) {\n      place(node, top + bottom, depth * wgap);\n      var children = 0;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) children++;\n      }\n      var vgap = (bottom - top) / children;\n      var cnt = 0;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) dfs(i, depth + 1, top + vgap * cnt, top + vgap * ++cnt);\n      }\n    };\n    dfs(root, 0, 0, 1);\n\n    this.refresh();\n  }\n\n  setData(G, undirected) {\n    if (super.setData.apply(this, arguments)) return true;\n\n    this.graph.clear();\n    const nodes = [];\n    const edges = [];\n    const unitAngle = 2 * Math.PI / G.length;\n    let currentAngle = 0;\n    for (let i = 0; i < G.length; i++) {\n      currentAngle += unitAngle;\n      nodes.push({\n        id: this.n(i),\n        label: '' + i,\n        x: .5 + Math.sin(currentAngle) / 2,\n        y: .5 + Math.cos(currentAngle) / 2,\n        size: 1,\n        color: this.color.default,\n        weight: 0\n      });\n\n      if (undirected) {\n        for (let j = 0; j <= i; j++) {\n          const value = G[i][j] || G[j][i];\n          if (value) {\n            edges.push({\n              id: this.e(i, j),\n              source: this.n(i),\n              target: this.n(j),\n              color: this.color.default,\n              size: 1,\n              weight: refineByType(value)\n            });\n          }\n        }\n      } else {\n        for (let j = 0; j < G[i].length; j++) {\n          if (G[i][j]) {\n            edges.push({\n              id: this.e(i, j),\n              source: this.n(i),\n              target: this.n(j),\n              color: this.color.default,\n              size: 1,\n              weight: refineByType(G[i][j])\n            });\n          }\n        }\n      }\n    }\n\n    this.graph.read({\n      nodes: nodes,\n      edges: edges\n    });\n    this.s.camera.goTo({\n      x: 0,\n      y: 0,\n      angle: 0,\n      ratio: 1\n    });\n    this.refresh();\n\n    return false;\n  }\n\n  resize() {\n    super.resize();\n\n    this.s.renderers[0].resize();\n    this.refresh();\n  }\n\n  refresh() {\n    super.refresh();\n\n    this.s.refresh();\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearGraphColor();\n    this.refresh();\n  }\n\n  clearGraphColor() {\n    var tracer = this;\n\n    this.graph.nodes().forEach(function (node) {\n      node.color = tracer.color.default;\n    });\n    this.graph.edges().forEach(function (edge) {\n      edge.color = tracer.color.default;\n    });\n  }\n\n  n(v) {\n    return 'n' + v;\n  }\n\n  e(v1, v2) {\n    return 'e' + v1 + '_' + v2;\n  }\n\n  getColor(edge, source, target, settings) {\n    var color = edge.color,\n      edgeColor = settings('edgeColor'),\n      defaultNodeColor = settings('defaultNodeColor'),\n      defaultEdgeColor = settings('defaultEdgeColor');\n    if (!color)\n      switch (edgeColor) {\n        case 'source':\n          color = source.color || defaultNodeColor;\n          break;\n        case 'target':\n          color = target.color || defaultNodeColor;\n          break;\n        default:\n          color = defaultEdgeColor;\n          break;\n      }\n\n    return color;\n  }\n\n  drawLabel(node, context, settings) {\n    var fontSize,\n      prefix = settings('prefix') || '',\n      size = node[prefix + 'size'];\n\n    if (size < settings('labelThreshold'))\n      return;\n\n    if (!node.label || typeof node.label !== 'string')\n      return;\n\n    fontSize = (settings('labelSize') === 'fixed') ?\n      settings('defaultLabelSize') :\n    settings('labelSizeRatio') * size;\n\n    context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') +\n      fontSize + 'px ' + settings('font');\n    context.fillStyle = (settings('labelColor') === 'node') ?\n      (node.color || settings('defaultNodeColor')) :\n      settings('defaultLabelColor');\n\n    context.textAlign = 'center';\n    context.fillText(\n      node.label,\n      Math.round(node[prefix + 'x']),\n      Math.round(node[prefix + 'y'] + fontSize / 3)\n    );\n  }\n\n  drawArrow(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1,\n      tSize = target[prefix + 'size'],\n      sX = source[prefix + 'x'],\n      sY = source[prefix + 'y'],\n      tX = target[prefix + 'x'],\n      tY = target[prefix + 'y'],\n      angle = Math.atan2(tY - sY, tX - sX),\n      dist = 3;\n    sX += Math.sin(angle) * dist;\n    tX += Math.sin(angle) * dist;\n    sY += -Math.cos(angle) * dist;\n    tY += -Math.cos(angle) * dist;\n    var aSize = Math.max(size * 2.5, settings('minArrowSize')),\n      d = Math.sqrt(Math.pow(tX - sX, 2) + Math.pow(tY - sY, 2)),\n      aX = sX + (tX - sX) * (d - aSize - tSize) / d,\n      aY = sY + (tY - sY) * (d - aSize - tSize) / d,\n      vX = (tX - sX) * aSize / d,\n      vY = (tY - sY) * aSize / d;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(sX, sY);\n    context.lineTo(\n      aX,\n      aY\n    );\n    context.stroke();\n\n    context.fillStyle = color;\n    context.beginPath();\n    context.moveTo(aX + vX, aY + vY);\n    context.lineTo(aX + vY * 0.6, aY - vX * 0.6);\n    context.lineTo(aX - vY * 0.6, aY + vX * 0.6);\n    context.lineTo(aX + vX, aY + vY);\n    context.closePath();\n    context.fill();\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawArrow(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#ff0';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawArrow(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s = tracer.capsule.s = new sigma({\n    renderer: {\n      container: tracer.$container[0],\n      type: 'canvas'\n    },\n    settings: {\n      minArrowSize: 8,\n      defaultEdgeType: 'arrow',\n      maxEdgeSize: 2.5,\n      labelThreshold: 4,\n      font: 'Roboto',\n      defaultLabelColor: '#fff',\n      zoomMin: 0.6,\n      zoomMax: 1.2,\n      skipErrors: true,\n      minNodeSize: .5,\n      maxNodeSize: 12,\n      labelSize: 'proportional',\n      labelSizeRatio: 1.3,\n      funcLabelsDef(node, context, settings) {\n        tracer.drawLabel(node, context, settings);\n      },\n      funcHoversDef(node, context, settings, next) {\n        tracer.drawOnHover(node, context, settings, next);\n      },\n      funcEdgesArrow(edge, source, target, context, settings) {\n        var color = tracer.getColor(edge, source, target, settings);\n        tracer.drawArrow(edge, source, target, color, context, settings);\n      }\n    }\n  });\n  sigma.plugins.dragNodes(tracer.s, tracer.s.renderers[0]);\n  tracer.graph = tracer.capsule.graph = tracer.s.graph;\n};\n\nsigma.canvas.labels.def = function (node, context, settings) {\n  var func = settings('funcLabelsDef');\n  if (func) {\n    func(node, context, settings);\n  }\n};\nsigma.canvas.hovers.def = function (node, context, settings) {\n  var func = settings('funcHoversDef');\n  if (func) {\n    func(node, context, settings);\n  }\n};\nsigma.canvas.edges.def = function (edge, source, target, context, settings) {\n  var func = settings('funcEdgesDef');\n  if (func) {\n    func(edge, source, target, context, settings);\n  }\n};\nsigma.canvas.edges.arrow = function (edge, source, target, context, settings) {\n  var func = settings('funcEdgesArrow');\n  if (func) {\n    func(edge, source, target, context, settings);\n  }\n};\n\nmodule.exports = DirectedGraphTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\nconst LogTracer = require('./log');\nconst Array1DTracer = require('./array1d');\nconst Array2DTracer = require('./array2d');\nconst ChartTracer = require('./chart');\nconst CoordinateSystemTracer = require('./coordinate_system');\nconst DirectedGraphTracer = require('./directed_graph');\nconst UndirectedGraphTracer = require('./undirected_graph');\nconst WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nconst WeightedUndirectedGraphTracer = require('./weighted_undirected_graph');\n\nmodule.exports = {\n  Tracer,\n  LogTracer,\n  Array1DTracer,\n  Array2DTracer,\n  ChartTracer,\n  CoordinateSystemTracer,\n  DirectedGraphTracer,\n  UndirectedGraphTracer,\n  WeightedDirectedGraphTracer,\n  WeightedUndirectedGraphTracer\n};","'use strict';\n\nconst Tracer = require('./tracer');\n\nclass LogTracer extends Tracer {\n  static getClassName() {\n    return 'LogTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  _print(msg) {\n    this.manager.pushStep(this.capsule, {\n      type: 'print',\n      msg: msg\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'print':\n        this.print(step.msg);\n        break;\n    }\n  }\n\n  refresh() {\n    this.scrollToEnd(Math.min(50, this.interval));\n  }\n\n  clear() {\n    super.clear();\n\n    this.$wrapper.empty();\n  }\n\n  print(message) {\n    this.$wrapper.append($('<span>').append(message + '<br/>'));\n  }\n\n  scrollToEnd(duration) {\n    this.$container.animate({\n      scrollTop: this.$container[0].scrollHeight\n    }, duration);\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$wrapper = tracer.capsule.$wrapper = $('<div class=\"wrapper\">');\n  tracer.$container.append(tracer.$wrapper);\n};\n\nmodule.exports = LogTracer;\n","'use strict';\n\nconst app = require('../../app');\n\nconst {\n  toJSON,\n  fromJSON\n} = require('../../tracer_manager/util/index');\n\nclass Tracer {\n  static getClassName() {\n    return 'Tracer';\n  }\n\n  constructor(name) {\n    this.module = this.constructor;\n\n    this.manager = app.getTracerManager();\n    this.capsule = this.manager.allocate(this);\n    $.extend(this, this.capsule);\n\n    this.setName(name);\n  }\n\n  _setData(...args) {\n    this.manager.pushStep(this.capsule, {\n      type: 'setData',\n      args: toJSON(args)\n    });\n    return this;\n  }\n\n  _clear() {\n    this.manager.pushStep(this.capsule, {\n      type: 'clear'\n    });\n    return this;\n  }\n\n  _wait(line) {\n    this.manager.newStep(line);\n    return this;\n  }\n\n  processStep(step, options) {\n    const {\n      type,\n      args\n    } = step;\n\n    switch (type) {\n      case 'setData':\n        this.setData(...fromJSON(args));\n        break;\n      case 'clear':\n        this.clear();\n        break;\n    }\n  }\n\n  setName(name) {\n    let $name;\n    if (this.isNew) {\n      $name = $('<span class=\"name\">');\n      this.$container.append($name);\n    } else {\n      $name = this.$container.find('span.name');\n    }\n    $name.text(name || this.defaultName);\n  }\n\n  setData() {\n    const data = toJSON(arguments);\n    if (!this.isNew && this.lastData === data) {\n      return true;\n    }\n    this.lastData = this.capsule.lastData = data;\n    return false;\n  }\n\n  resize() {\n  }\n\n  refresh() {\n  }\n\n  clear() {\n  }\n\n  attach(tracer) {\n    switch (tracer.module) {\n      case LogTracer:\n        this.logTracer = tracer;\n        break;\n      case ChartTracer:\n        this.chartTracer = tracer;\n        break;\n    }\n    return this;\n  }\n\n  mousedown(e) {\n  }\n\n  mousemove(e) {\n  }\n\n  mouseup(e) {\n  }\n\n  mousewheel(e) {\n  }\n}\n\nmodule.exports = Tracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nclass UndirectedGraphTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'UndirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  setTreeData(G, root) {\n    return super.setTreeData(G, root, true);\n  }\n\n  setData(G) {\n    return super.setData(G, true);\n  }\n\n  e(v1, v2) {\n    if (v1 > v2) {\n      var temp = v1;\n      v1 = v2;\n      v2 = temp;\n    }\n    return 'e' + v1 + '_' + v2;\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#0ff';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n\n  drawEdge(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(\n      source[prefix + 'x'],\n      source[prefix + 'y']\n    );\n    context.lineTo(\n      target[prefix + 'x'],\n      target[prefix + 'y']\n    );\n    context.stroke();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = UndirectedGraphTracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass WeightedDirectedGraphTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'WeightedDirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  _weight(target, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'weight',\n      target: target,\n      weight: weight\n    });\n    return this;\n  }\n\n  _visit(target, source, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'visit',\n      target: target,\n      source: source,\n      weight: weight\n    });\n    return this;\n  }\n\n  _leave(target, source, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'leave',\n      target: target,\n      source: source,\n      weight: weight\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'weight':\n        var targetNode = this.graph.nodes(this.n(step.target));\n        if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n        break;\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? step.weight === undefined ? this.color.selected : this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          var edge = this.graph.edges(edgeId);\n          edge.color = color;\n          this.graph.dropEdge(edgeId).addEdge(edge);\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearWeights();\n  }\n\n  clearWeights() {\n    this.graph.nodes().forEach(function (node) {\n      node.weight = 0;\n    });\n  }\n\n  drawEdgeWeight(edge, source, target, color, context, settings) {\n    if (source == target)\n      return;\n\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    if (size < settings('edgeLabelThreshold'))\n      return;\n\n    if (0 === settings('edgeLabelSizePowRatio'))\n      throw '\"edgeLabelSizePowRatio\" must not be 0.';\n\n    var fontSize,\n      x = (source[prefix + 'x'] + target[prefix + 'x']) / 2,\n      y = (source[prefix + 'y'] + target[prefix + 'y']) / 2,\n      dX = target[prefix + 'x'] - source[prefix + 'x'],\n      dY = target[prefix + 'y'] - source[prefix + 'y'],\n      angle = Math.atan2(dY, dX);\n\n    fontSize = (settings('edgeLabelSize') === 'fixed') ?\n      settings('defaultEdgeLabelSize') :\n    settings('defaultEdgeLabelSize') *\n    size *\n    Math.pow(size, -1 / settings('edgeLabelSizePowRatio'));\n\n    context.save();\n\n    if (edge.active) {\n      context.font = [\n        settings('activeFontStyle'),\n        fontSize + 'px',\n        settings('activeFont') || settings('font')\n      ].join(' ');\n\n      context.fillStyle = color;\n    } else {\n      context.font = [\n        settings('fontStyle'),\n        fontSize + 'px',\n        settings('font')\n      ].join(' ');\n\n      context.fillStyle = color;\n    }\n\n    context.textAlign = 'center';\n    context.textBaseline = 'alphabetic';\n\n    context.translate(x, y);\n    context.rotate(angle);\n    context.fillText(\n      edge.weight,\n      0,\n      (-size / 2) - 3\n    );\n\n    context.restore();\n  }\n\n  drawNodeWeight(node, context, settings) {\n    var fontSize,\n      prefix = settings('prefix') || '',\n      size = node[prefix + 'size'];\n\n    if (size < settings('labelThreshold'))\n      return;\n\n    fontSize = (settings('labelSize') === 'fixed') ?\n      settings('defaultLabelSize') :\n    settings('labelSizeRatio') * size;\n\n    context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') +\n      fontSize + 'px ' + settings('font');\n    context.fillStyle = (settings('labelColor') === 'node') ?\n      (node.color || settings('defaultNodeColor')) :\n      settings('defaultLabelColor');\n\n    context.textAlign = 'left';\n    context.fillText(\n      node.weight,\n      Math.round(node[prefix + 'x'] + size * 1.5),\n      Math.round(node[prefix + 'y'] + fontSize / 3)\n    );\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    edgeLabelSize: 'proportional',\n    defaultEdgeLabelSize: 20,\n    edgeLabelSizePowRatio: 0.8,\n    funcLabelsDef(node, context, settings) {\n      tracer.drawNodeWeight(node, context, settings);\n      tracer.drawLabel(node, context, settings);\n    },\n    funcHoversDef(node, context, settings) {\n      tracer.drawOnHover(node, context, settings, tracer.drawEdgeWeight);\n    },\n    funcEdgesArrow(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawArrow(edge, source, target, color, context, settings);\n      tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = WeightedDirectedGraphTracer;\n","'use strict';\n\nconst WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nconst UndirectedGraphTracer = require('./undirected_graph');\n\nclass WeightedUndirectedGraphTracer extends WeightedDirectedGraphTracer {\n  static getClassName() {\n    return 'WeightedUndirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.e = UndirectedGraphTracer.prototype.e;\n    this.drawOnHover = UndirectedGraphTracer.prototype.drawOnHover;\n    this.drawEdge = UndirectedGraphTracer.prototype.drawEdge;\n\n    if (this.isNew) initView(this);\n  }\n\n  setTreeData(G, root) {\n    return super.setTreeData(G, root, true);\n  }\n\n  setData(G) {\n    return super.setData(G, true);\n  }\n\n  drawEdgeWeight(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '';\n    if (source[prefix + 'x'] > target[prefix + 'x']) {\n      var temp = source;\n      source = target;\n      target = temp;\n    }\n    WeightedDirectedGraphTracer.prototype.drawEdgeWeight.call(this, edge, source, target, color, context, settings);\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n      tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = WeightedUndirectedGraphTracer;\n","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = (url) => {\n  return request(url, {\n    type: 'GET'\n  });\n};","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = function(url) {\n  return request(url, {\n    dataType: 'json',\n    type: 'GET'\n  });\n};","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = function(url, data) {\n  return request(url, {\n    dataType: 'json',\n    type: 'POST',\n    data: JSON.stringify(data),\n  });\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../../app');\n\nconst {\n  ajax,\n  extend\n} = $;\n\nconst defaults = {\n\n};\n\nmodule.exports = function(url, options = {}) {\n  app.setIsLoading(true);\n\n  return new RSVP.Promise((resolve, reject) => {\n    const callbacks = {\n      success(response) {\n        app.setIsLoading(false);\n        resolve(response);\n      },\n      error(reason) {\n        app.setIsLoading(false);\n        reject(reason);\n      }\n    };\n\n    const opts = extend({}, defaults, options, callbacks, {\n      url\n    });\n\n    ajax(opts);\n  });\n};","'use strict';\n\nconst app = require('../app');\nconst Toast = require('../dom/toast');\n\nconst checkLoading = () => {\n  if (app.getIsLoading()) {\n    Toast.showErrorToast('Wait until it completes loading of previous file.');\n    return true;\n  }\n  return false;\n};\n\nconst getParameterByName = (name) => {\n  const url = window.location.href;\n  const regex = new RegExp(`[?&]${name}(=([^&#]*)|&|#|$)`);\n\n  const results = regex.exec(url);\n\n  if (!results || results.length !== 3) {\n    return null;\n  }\n\n  const [, , id] = results;\n\n  return id;\n};\n\nconst getHashValue = (key)=> {\n  if (!key) return null;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n  for (let i = 0; i < params.length; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      return pair[1];\n    }\n  }\n  return null;\n};\n\nconst setHashValue = (key, value)=> {\n  if (!key || !value) return;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n\n  let found = false;\n  for (let i = 0; i < params.length && !found; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      pair[1] = value;\n      params[i] = pair.join('=');\n      found = true;\n    }\n  }\n  if (!found) {\n    params.push([key, value].join('='));\n  }\n\n  const newHash = params.join('&');\n  window.location.hash = `#${newHash}`;\n};\n\nconst removeHashValue = (key) => {\n  if (!key) return;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n\n  for (let i = 0; i < params.length; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      params.splice(i, 1);\n      break;\n    }\n  }\n\n  const newHash = params.join('&');\n  window.location.hash = `#${newHash}`;\n};\n\nconst setPath = (category, algorithm, file) => {\n  const path = category ? category + (algorithm ? `/${algorithm}` + (file ? `/${file}` : '') : '') : '';\n  setHashValue('path', path);\n};\n\nconst getPath = () => {\n  const hash = getHashValue('path');\n  if (hash) {\n    const [ category, algorithm, file ] = hash.split('/');\n    return { category, algorithm, file };\n  } else {\n    return false;\n  }\n};\n\nmodule.exports = {\n  checkLoading,\n  getParameterByName,\n  getHashValue,\n  setHashValue,\n  removeHashValue,\n  setPath,\n  getPath\n};\n","'use strict';\n\nconst loadAlgorithm = require('./load_algorithm');\nconst loadCategories = require('./load_categories');\nconst loadFile = require('./load_file');\nconst loadScratchPaper = require('./load_scratch_paper');\nconst shareScratchPaper = require('./share_scratch_paper');\nconst loadWikiList = require('./load_wiki_list');\nconst loadWiki = require('./load_wiki');\n\nmodule.exports = {\n  loadAlgorithm,\n  loadCategories,\n  loadFile,\n  loadScratchPaper,\n  shareScratchPaper,\n  loadWikiList,\n  loadWiki\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nconst {\n  getAlgorithmDir\n} = require('../utils');\n\nmodule.exports = (category, algorithm) => {\n  const dir = getAlgorithmDir(category, algorithm);\n  return getJSON(`${dir}desc.json`);\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nmodule.exports = () => {\n  return getJSON('./algorithm/category.json');\n};","'use strict';\n\nconst RSVP = require('rsvp');\n\nconst app = require('../app');\n\nconst {\n  getFileDir,\n  isScratchPaper\n} = require('../utils');\n\nconst {\n  checkLoading,\n  setPath\n} = require('./helpers');\n\nconst get = require('./ajax/get');\n\nconst loadDataAndCode = (dir) => {\n  return RSVP.hash({\n    data: get(`${dir}data.js`),\n    code: get(`${dir}code.js`)\n  });\n};\n\nconst loadFileAndUpdateContent = (dir) => {\n  app.getEditor().clearContent();\n\n  return loadDataAndCode(dir).then((content) => {\n    app.updateCachedFile(dir, content);\n    app.getEditor().setContent(content);\n  });\n};\n\nconst cachedContentExists = (cachedFile) => {\n  return cachedFile &&\n    cachedFile.data !== undefined &&\n    cachedFile.code !== undefined;\n};\n\nmodule.exports = (category, algorithm, file, explanation) => {\n  return new RSVP.Promise((resolve, reject) => {\n    if (checkLoading()) {\n      reject();\n    } else {\n      if (isScratchPaper(category)) {\n        setPath(category, app.getLoadedScratch());\n      } else {\n        setPath(category, algorithm, file);\n      }\n      $('#explanation').html(explanation);\n\n      let dir = getFileDir(category, algorithm, file);\n      app.setLastFileUsed(dir);\n      const cachedFile = app.getCachedFile(dir);\n\n      if (cachedContentExists(cachedFile)) {\n        app.getEditor().setContent(cachedFile);\n        resolve();\n      } else {\n        loadFileAndUpdateContent(dir).then(resolve, reject);\n      }\n    }\n  });\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../app');\n\nconst {\n  getFileDir\n} = require('../utils');\n\nconst getJSON = require('./ajax/get_json');\nconst loadAlgorithm = require('./load_algorithm');\n\nconst extractGistCode = (files, name) => files[`${name}.js`].content;\n\nmodule.exports = (gistID) => {\n  return new RSVP.Promise((resolve, reject) => {\n    app.setLoadedScratch(gistID);\n\n    getJSON(`https://api.github.com/gists/${gistID}`).then(({\n      files\n    }) => {\n\n      const category = 'scratch';\n      const algorithm = gistID;\n\n      loadAlgorithm(category, algorithm).then((data) => {\n\n        const algoData = extractGistCode(files, 'data');\n        const algoCode = extractGistCode(files, 'code');\n\n        // update scratch paper algo code with the loaded gist code\n        const dir = getFileDir(category, algorithm, 'scratch_paper');\n        app.updateCachedFile(dir, {\n          data: algoData,\n          code: algoCode,\n          'CREDIT.md': 'Shared by an anonymous user from http://parkjs814.github.io/AlgorithmVisualizer'\n        });\n\n        resolve({\n          category,\n          algorithm,\n          data\n        });\n      });\n    });\n  });\n\n};","'use strict';\n\nconst get = require('./ajax/get');\n\nmodule.exports = (wiki) => {\n  return get(`./AlgorithmVisualizer.wiki/${wiki}.md`);\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nmodule.exports = () => {\n  return getJSON('./wiki.json');\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../app');\n\nconst postJSON = require('./ajax/post_json');\n\nconst {\n  setPath\n} = require('./helpers');\n\nmodule.exports = () => {\n  return new RSVP.Promise((resolve, reject) => {\n\n    const {\n      dataEditor,\n      codeEditor\n    } = app.getEditor();\n\n    const gist = {\n      'description': 'temp',\n      'public': true,\n      'files': {\n        'data.js': {\n          'content': dataEditor.getValue()\n        },\n        'code.js': {\n          'content': codeEditor.getValue()\n        }\n      }\n    };\n\n    postJSON('https://api.github.com/gists', gist).then(({\n      id\n    }) => {\n      app.setLoadedScratch(id);\n      setPath('scratch', id);\n      const {\n        href\n      } = location;\n      $('#algorithm').html('Shared');\n      resolve(href);\n    });\n  });\n};","'use strict';\n\nconst TracerManager = require('./manager');\nconst Tracer = require('../module/tracer/tracer');\n\nmodule.exports = {\n\n  init() {\n    const tm = new TracerManager();\n    Tracer.prototype.manager = tm;\n    return tm;\n  }\n\n};","'use strict';\n\nconst app = require('../app');\nconst ModuleContainer = require('../dom/module_container');\nconst TopMenu = require('../dom/top_menu');\n\nconst {\n  each,\n  extend,\n  grep\n} = $;\n\nconst stepLimit = 1e6;\n\nconst TracerManager = function () {\n  this.timer = null;\n  this.pause = false;\n  this.capsules = [];\n  this.interval = 500;\n};\n\nTracerManager.prototype = {\n\n  add(tracer) {\n\n    const $container = ModuleContainer.create();\n\n    const capsule = {\n      module: tracer.module,\n      tracer,\n      allocated: true,\n      defaultName: null,\n      $container,\n      isNew: true\n    };\n\n    this.capsules.push(capsule);\n    return capsule;\n  },\n\n  allocate(newTracer) {\n    let selectedCapsule = null;\n    let count = 0;\n\n    each(this.capsules, (i, capsule) => {\n      if (capsule.module === newTracer.module) {\n        count++;\n        if (!capsule.allocated) {\n          capsule.tracer = newTracer;\n          capsule.allocated = true;\n          capsule.isNew = false;\n          selectedCapsule = capsule;\n          return false;\n        }\n      }\n    });\n\n    if (selectedCapsule === null) {\n      count++;\n      selectedCapsule = this.add(newTracer);\n    }\n\n    const className = newTracer.module.getClassName();\n    selectedCapsule.defaultName = `${className} ${count}`;\n    selectedCapsule.order = this.order++;\n    return selectedCapsule;\n  },\n\n  deallocateAll() {\n    this.order = 0;\n    this.reset();\n    each(this.capsules, (i, capsule) => {\n      capsule.allocated = false;\n    });\n  },\n\n  removeUnallocated() {\n    let changed = false;\n\n    this.capsules = grep(this.capsules, (capsule) => {\n      let removed = !capsule.allocated;\n\n      if (capsule.isNew || removed) {\n        changed = true;\n      }\n      if (removed) {\n        capsule.$container.remove();\n      }\n\n      return !removed;\n    });\n\n    if (changed) {\n      this.place();\n    }\n  },\n\n  place() {\n    const {\n      capsules\n    } = this;\n\n    each(capsules, (i, capsule) => {\n      let width = 100;\n      let height = (100 / capsules.length);\n      let top = height * capsule.order;\n\n      capsule.$container.css({\n        top: `${top}%`,\n        width: `${width}%`,\n        height: `${height}%`\n      });\n\n      capsule.tracer.resize();\n    });\n  },\n\n  resize() {\n    this.command('resize');\n  },\n\n  isPause() {\n    return this.pause;\n  },\n\n  setInterval(interval) {\n    TopMenu.setInterval(interval);\n  },\n\n  reset() {\n    this.traces = [];\n    this.traceIndex = -1;\n    this.stepCnt = 0;\n    if (this.timer) {\n      clearTimeout(this.timer);\n    }\n    this.command('clear');\n  },\n\n  pushStep(capsule, step) {\n    if (this.stepCnt++ > stepLimit) throw \"Tracer's stack overflow\";\n    let len = this.traces.length;\n    if (len == 0) len += this.newStep();\n    const last = this.traces[len - 1];\n    last.push(extend(step, {\n      capsule\n    }));\n  },\n\n  newStep(line = -1) {\n    let len = this.traces.length;\n    if (len > 0 && ~line) {\n      this.traces[len - 1].push(line);\n    }\n    return this.traces.push([]);\n  },\n\n  pauseStep() {\n    if (this.traceIndex < 0) return;\n    this.pause = true;\n    if (this.timer) {\n      clearTimeout(this.timer);\n    }\n    TopMenu.activateBtnPause();\n  },\n\n  resumeStep() {\n    this.pause = false;\n    this.step(this.traceIndex + 1);\n    TopMenu.deactivateBtnPause();\n  },\n\n  step(i, options = {}) {\n    const tracer = this;\n\n    if (isNaN(i) || i >= this.traces.length || i < 0) return;\n\n    this.traceIndex = i;\n    const trace = this.traces[i];\n    trace.forEach((step) => {\n      if (typeof step === 'number') {\n        app.getEditor().highlightLine(step);\n        return;\n      }\n      step.capsule.tracer.processStep(step, options);\n    });\n\n    if (!options.virtual) {\n      this.command('refresh');\n    }\n\n    if (this.pause) return;\n\n    this.timer = setTimeout(() => {\n      if (!tracer.nextStep(options)) {\n        TopMenu.resetTopMenuButtons();\n      }\n    }, this.interval);\n  },\n\n  prevStep(options = {}) {\n    this.command('clear');\n\n    const finalIndex = this.traceIndex - 1;\n    if (finalIndex < 0) {\n      this.traceIndex = -1;\n      this.command('refresh');\n      return false;\n    }\n\n    for (let i = 0; i < finalIndex; i++) {\n      this.step(i, extend(options, {\n        virtual: true\n      }));\n    }\n\n    this.step(finalIndex);\n    return true;\n  },\n\n  nextStep(options = {}) {\n    const finalIndex = this.traceIndex + 1;\n    if (finalIndex >= this.traces.length) {\n      this.traceIndex = this.traces.length - 1;\n      return false;\n    }\n\n    this.step(finalIndex, options);\n    return true;\n  },\n\n  visualize() {\n    this.traceIndex = -1;\n    this.resumeStep();\n  },\n\n  command(...args) {\n    const functionName = args.shift();\n    each(this.capsules, (i, capsule) => {\n      if (capsule.allocated) {\n        capsule.tracer.module.prototype[functionName].apply(capsule.tracer, args);\n      }\n    });\n  },\n\n  findOwner(container) {\n    let selectedCapsule = null;\n    each(this.capsules, (i, capsule) => {\n      if (capsule.$container[0] === container) {\n        selectedCapsule = capsule;\n        return false;\n      }\n    });\n    return selectedCapsule.tracer;\n  }\n};\n\nmodule.exports = TracerManager;\n","'use strict';\n\nconst {\n  parse\n} = JSON;\n\nconst fromJSON = (obj) => {\n  return parse(obj, (key, value) => {\n    return value === 'Infinity' ? Infinity : value;\n  });\n};\n\nmodule.exports = fromJSON;\n","'use strict';\n\nconst toJSON = require('./to_json');\nconst fromJSON = require('./from_json');\nconst refineByType = require('./refine_by_type');\n\nmodule.exports = {\n  toJSON,\n  fromJSON,\n  refineByType\n};\n","'use strict';\n\nconst refineByType = (item) => {\n  switch (typeof(item)) {\n    case 'number':\n      return refineNumber(item);\n    case 'boolean':\n      return refineBoolean(item);\n    default:\n      return refineString(item);\n  }\n};\n\nconst refineString = (str) => {\n  return str === '' ? ' ' : str;\n};\n\nconst refineNumber = (num) => {\n  return num === Infinity ? '∞' : num;\n};\n\nconst refineBoolean = (bool) => {\n  return bool ? 'T' : 'F';\n};\n\nmodule.exports = refineByType;\n","'use strict';\n\nconst {\n  stringify\n} = JSON;\n\nconst toJSON = (obj) => {\n  return stringify(obj, (key, value) => {\n    return value === Infinity ? 'Infinity' : value;\n  });\n};\n\nmodule.exports = toJSON;\n","'use strict';\n\nconst isScratchPaper = (category, algorithm) => {\n  return category == 'scratch';\n};\n\nconst getAlgorithmDir = (category, algorithm) => {\n  if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n  return `./algorithm/${category}/${algorithm}/`;\n};\n\nconst getFileDir = (category, algorithm, file) => {\n  if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n  return `./algorithm/${category}/${algorithm}/${file}/`;\n};\n\nmodule.exports = {\n  isScratchPaper,\n  getAlgorithmDir,\n  getFileDir\n};","// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = setTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    clearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        setTimeout(drainQueue, 0);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\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\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","/*!\n * @overview RSVP - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors\n * @license   Licensed under MIT license\n *            See https://raw.githubusercontent.com/tildeio/rsvp.js/master/LICENSE\n * @version   3.2.1\n */\n\n(function() {\n    \"use strict\";\n    function lib$rsvp$utils$$objectOrFunction(x) {\n      return typeof x === 'function' || (typeof x === 'object' && x !== null);\n    }\n\n    function lib$rsvp$utils$$isFunction(x) {\n      return typeof x === 'function';\n    }\n\n    function lib$rsvp$utils$$isMaybeThenable(x) {\n      return typeof x === 'object' && x !== null;\n    }\n\n    var lib$rsvp$utils$$_isArray;\n    if (!Array.isArray) {\n      lib$rsvp$utils$$_isArray = function (x) {\n        return Object.prototype.toString.call(x) === '[object Array]';\n      };\n    } else {\n      lib$rsvp$utils$$_isArray = Array.isArray;\n    }\n\n    var lib$rsvp$utils$$isArray = lib$rsvp$utils$$_isArray;\n\n    var lib$rsvp$utils$$now = Date.now || function() { return new Date().getTime(); };\n\n    function lib$rsvp$utils$$F() { }\n\n    var lib$rsvp$utils$$o_create = (Object.create || function (o) {\n      if (arguments.length > 1) {\n        throw new Error('Second argument not supported');\n      }\n      if (typeof o !== 'object') {\n        throw new TypeError('Argument must be an object');\n      }\n      lib$rsvp$utils$$F.prototype = o;\n      return new lib$rsvp$utils$$F();\n    });\n    function lib$rsvp$events$$indexOf(callbacks, callback) {\n      for (var i=0, l=callbacks.length; i<l; i++) {\n        if (callbacks[i] === callback) { return i; }\n      }\n\n      return -1;\n    }\n\n    function lib$rsvp$events$$callbacksFor(object) {\n      var callbacks = object._promiseCallbacks;\n\n      if (!callbacks) {\n        callbacks = object._promiseCallbacks = {};\n      }\n\n      return callbacks;\n    }\n\n    var lib$rsvp$events$$default = {\n\n      /**\n        `RSVP.EventTarget.mixin` extends an object with EventTarget methods. For\n        Example:\n\n        ```javascript\n        var object = {};\n\n        RSVP.EventTarget.mixin(object);\n\n        object.on('finished', function(event) {\n          // handle event\n        });\n\n        object.trigger('finished', { detail: value });\n        ```\n\n        `EventTarget.mixin` also works with prototypes:\n\n        ```javascript\n        var Person = function() {};\n        RSVP.EventTarget.mixin(Person.prototype);\n\n        var yehuda = new Person();\n        var tom = new Person();\n\n        yehuda.on('poke', function(event) {\n          console.log('Yehuda says OW');\n        });\n\n        tom.on('poke', function(event) {\n          console.log('Tom says OW');\n        });\n\n        yehuda.trigger('poke');\n        tom.trigger('poke');\n        ```\n\n        @method mixin\n        @for RSVP.EventTarget\n        @private\n        @param {Object} object object to extend with EventTarget methods\n      */\n      'mixin': function(object) {\n        object['on']      = this['on'];\n        object['off']     = this['off'];\n        object['trigger'] = this['trigger'];\n        object._promiseCallbacks = undefined;\n        return object;\n      },\n\n      /**\n        Registers a callback to be executed when `eventName` is triggered\n\n        ```javascript\n        object.on('event', function(eventInfo){\n          // handle the event\n        });\n\n        object.trigger('event');\n        ```\n\n        @method on\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName name of the event to listen for\n        @param {Function} callback function to be called when the event is triggered.\n      */\n      'on': function(eventName, callback) {\n        if (typeof callback !== 'function') {\n          throw new TypeError('Callback must be a function');\n        }\n\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks;\n\n        callbacks = allCallbacks[eventName];\n\n        if (!callbacks) {\n          callbacks = allCallbacks[eventName] = [];\n        }\n\n        if (lib$rsvp$events$$indexOf(callbacks, callback) === -1) {\n          callbacks.push(callback);\n        }\n      },\n\n      /**\n        You can use `off` to stop firing a particular callback for an event:\n\n        ```javascript\n        function doStuff() { // do stuff! }\n        object.on('stuff', doStuff);\n\n        object.trigger('stuff'); // doStuff will be called\n\n        // Unregister ONLY the doStuff callback\n        object.off('stuff', doStuff);\n        object.trigger('stuff'); // doStuff will NOT be called\n        ```\n\n        If you don't pass a `callback` argument to `off`, ALL callbacks for the\n        event will not be executed when the event fires. For example:\n\n        ```javascript\n        var callback1 = function(){};\n        var callback2 = function(){};\n\n        object.on('stuff', callback1);\n        object.on('stuff', callback2);\n\n        object.trigger('stuff'); // callback1 and callback2 will be executed.\n\n        object.off('stuff');\n        object.trigger('stuff'); // callback1 and callback2 will not be executed!\n        ```\n\n        @method off\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName event to stop listening to\n        @param {Function} callback optional argument. If given, only the function\n        given will be removed from the event's callback queue. If no `callback`\n        argument is given, all callbacks will be removed from the event's callback\n        queue.\n      */\n      'off': function(eventName, callback) {\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, index;\n\n        if (!callback) {\n          allCallbacks[eventName] = [];\n          return;\n        }\n\n        callbacks = allCallbacks[eventName];\n\n        index = lib$rsvp$events$$indexOf(callbacks, callback);\n\n        if (index !== -1) { callbacks.splice(index, 1); }\n      },\n\n      /**\n        Use `trigger` to fire custom events. For example:\n\n        ```javascript\n        object.on('foo', function(){\n          console.log('foo event happened!');\n        });\n        object.trigger('foo');\n        // 'foo event happened!' logged to the console\n        ```\n\n        You can also pass a value as a second argument to `trigger` that will be\n        passed as an argument to all event listeners for the event:\n\n        ```javascript\n        object.on('foo', function(value){\n          console.log(value.name);\n        });\n\n        object.trigger('foo', { name: 'bar' });\n        // 'bar' logged to the console\n        ```\n\n        @method trigger\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName name of the event to be triggered\n        @param {*} options optional value to be passed to any event handlers for\n        the given `eventName`\n      */\n      'trigger': function(eventName, options, label) {\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, callback;\n\n        if (callbacks = allCallbacks[eventName]) {\n          // Don't cache the callbacks.length since it may grow\n          for (var i=0; i<callbacks.length; i++) {\n            callback = callbacks[i];\n\n            callback(options, label);\n          }\n        }\n      }\n    };\n\n    var lib$rsvp$config$$config = {\n      instrument: false\n    };\n\n    lib$rsvp$events$$default['mixin'](lib$rsvp$config$$config);\n\n    function lib$rsvp$config$$configure(name, value) {\n      if (name === 'onerror') {\n        // handle for legacy users that expect the actual\n        // error to be passed to their function added via\n        // `RSVP.configure('onerror', someFunctionHere);`\n        lib$rsvp$config$$config['on']('error', value);\n        return;\n      }\n\n      if (arguments.length === 2) {\n        lib$rsvp$config$$config[name] = value;\n      } else {\n        return lib$rsvp$config$$config[name];\n      }\n    }\n\n    var lib$rsvp$instrument$$queue = [];\n\n    function lib$rsvp$instrument$$scheduleFlush() {\n      setTimeout(function() {\n        var entry;\n        for (var i = 0; i < lib$rsvp$instrument$$queue.length; i++) {\n          entry = lib$rsvp$instrument$$queue[i];\n\n          var payload = entry.payload;\n\n          payload.guid = payload.key + payload.id;\n          payload.childGuid = payload.key + payload.childId;\n          if (payload.error) {\n            payload.stack = payload.error.stack;\n          }\n\n          lib$rsvp$config$$config['trigger'](entry.name, entry.payload);\n        }\n        lib$rsvp$instrument$$queue.length = 0;\n      }, 50);\n    }\n\n    function lib$rsvp$instrument$$instrument(eventName, promise, child) {\n      if (1 === lib$rsvp$instrument$$queue.push({\n        name: eventName,\n        payload: {\n          key: promise._guidKey,\n          id:  promise._id,\n          eventName: eventName,\n          detail: promise._result,\n          childId: child && child._id,\n          label: promise._label,\n          timeStamp: lib$rsvp$utils$$now(),\n          error: lib$rsvp$config$$config[\"instrument-with-stack\"] ? new Error(promise._label) : null\n        }})) {\n          lib$rsvp$instrument$$scheduleFlush();\n        }\n      }\n    var lib$rsvp$instrument$$default = lib$rsvp$instrument$$instrument;\n    function lib$rsvp$then$$then(onFulfillment, onRejection, label) {\n      var parent = this;\n      var state = parent._state;\n\n      if (state === lib$rsvp$$internal$$FULFILLED && !onFulfillment || state === lib$rsvp$$internal$$REJECTED && !onRejection) {\n        lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, parent);\n        return parent;\n      }\n\n      parent._onError = null;\n\n      var child = new parent.constructor(lib$rsvp$$internal$$noop, label);\n      var result = parent._result;\n\n      lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, child);\n\n      if (state) {\n        var callback = arguments[state - 1];\n        lib$rsvp$config$$config.async(function(){\n          lib$rsvp$$internal$$invokeCallback(state, child, callback, result);\n        });\n      } else {\n        lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection);\n      }\n\n      return child;\n    }\n    var lib$rsvp$then$$default = lib$rsvp$then$$then;\n    function lib$rsvp$promise$resolve$$resolve(object, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n\n      if (object && typeof object === 'object' && object.constructor === Constructor) {\n        return object;\n      }\n\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      lib$rsvp$$internal$$resolve(promise, object);\n      return promise;\n    }\n    var lib$rsvp$promise$resolve$$default = lib$rsvp$promise$resolve$$resolve;\n    function lib$rsvp$enumerator$$makeSettledResult(state, position, value) {\n      if (state === lib$rsvp$$internal$$FULFILLED) {\n        return {\n          state: 'fulfilled',\n          value: value\n        };\n      } else {\n         return {\n          state: 'rejected',\n          reason: value\n        };\n      }\n    }\n\n    function lib$rsvp$enumerator$$Enumerator(Constructor, input, abortOnReject, label) {\n      this._instanceConstructor = Constructor;\n      this.promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      this._abortOnReject = abortOnReject;\n\n      if (this._validateInput(input)) {\n        this._input     = input;\n        this.length     = input.length;\n        this._remaining = input.length;\n\n        this._init();\n\n        if (this.length === 0) {\n          lib$rsvp$$internal$$fulfill(this.promise, this._result);\n        } else {\n          this.length = this.length || 0;\n          this._enumerate();\n          if (this._remaining === 0) {\n            lib$rsvp$$internal$$fulfill(this.promise, this._result);\n          }\n        }\n      } else {\n        lib$rsvp$$internal$$reject(this.promise, this._validationError());\n      }\n    }\n\n    var lib$rsvp$enumerator$$default = lib$rsvp$enumerator$$Enumerator;\n\n    lib$rsvp$enumerator$$Enumerator.prototype._validateInput = function(input) {\n      return lib$rsvp$utils$$isArray(input);\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._validationError = function() {\n      return new Error('Array Methods must be provided an Array');\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._init = function() {\n      this._result = new Array(this.length);\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._enumerate = function() {\n      var length     = this.length;\n      var promise    = this.promise;\n      var input      = this._input;\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        this._eachEntry(input[i], i);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._settleMaybeThenable = function(entry, i) {\n      var c = this._instanceConstructor;\n      var resolve = c.resolve;\n\n      if (resolve === lib$rsvp$promise$resolve$$default) {\n        var then = lib$rsvp$$internal$$getThen(entry);\n\n        if (then === lib$rsvp$then$$default &&\n            entry._state !== lib$rsvp$$internal$$PENDING) {\n          entry._onError = null;\n          this._settledAt(entry._state, i, entry._result);\n        } else if (typeof then !== 'function') {\n          this._remaining--;\n          this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n        } else if (c === lib$rsvp$promise$$default) {\n          var promise = new c(lib$rsvp$$internal$$noop);\n          lib$rsvp$$internal$$handleMaybeThenable(promise, entry, then);\n          this._willSettleAt(promise, i);\n        } else {\n          this._willSettleAt(new c(function(resolve) { resolve(entry); }), i);\n        }\n      } else {\n        this._willSettleAt(resolve(entry), i);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._eachEntry = function(entry, i) {\n      if (lib$rsvp$utils$$isMaybeThenable(entry)) {\n        this._settleMaybeThenable(entry, i);\n      } else {\n        this._remaining--;\n        this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._settledAt = function(state, i, value) {\n      var promise = this.promise;\n\n      if (promise._state === lib$rsvp$$internal$$PENDING) {\n        this._remaining--;\n\n        if (this._abortOnReject && state === lib$rsvp$$internal$$REJECTED) {\n          lib$rsvp$$internal$$reject(promise, value);\n        } else {\n          this._result[i] = this._makeResult(state, i, value);\n        }\n      }\n\n      if (this._remaining === 0) {\n        lib$rsvp$$internal$$fulfill(promise, this._result);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._makeResult = function(state, i, value) {\n      return value;\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._willSettleAt = function(promise, i) {\n      var enumerator = this;\n\n      lib$rsvp$$internal$$subscribe(promise, undefined, function(value) {\n        enumerator._settledAt(lib$rsvp$$internal$$FULFILLED, i, value);\n      }, function(reason) {\n        enumerator._settledAt(lib$rsvp$$internal$$REJECTED, i, reason);\n      });\n    };\n    function lib$rsvp$promise$all$$all(entries, label) {\n      return new lib$rsvp$enumerator$$default(this, entries, true /* abort on reject */, label).promise;\n    }\n    var lib$rsvp$promise$all$$default = lib$rsvp$promise$all$$all;\n    function lib$rsvp$promise$race$$race(entries, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n\n      if (!lib$rsvp$utils$$isArray(entries)) {\n        lib$rsvp$$internal$$reject(promise, new TypeError('You must pass an array to race.'));\n        return promise;\n      }\n\n      var length = entries.length;\n\n      function onFulfillment(value) {\n        lib$rsvp$$internal$$resolve(promise, value);\n      }\n\n      function onRejection(reason) {\n        lib$rsvp$$internal$$reject(promise, reason);\n      }\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        lib$rsvp$$internal$$subscribe(Constructor.resolve(entries[i]), undefined, onFulfillment, onRejection);\n      }\n\n      return promise;\n    }\n    var lib$rsvp$promise$race$$default = lib$rsvp$promise$race$$race;\n    function lib$rsvp$promise$reject$$reject(reason, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      lib$rsvp$$internal$$reject(promise, reason);\n      return promise;\n    }\n    var lib$rsvp$promise$reject$$default = lib$rsvp$promise$reject$$reject;\n\n    var lib$rsvp$promise$$guidKey = 'rsvp_' + lib$rsvp$utils$$now() + '-';\n    var lib$rsvp$promise$$counter = 0;\n\n    function lib$rsvp$promise$$needsResolver() {\n      throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n    }\n\n    function lib$rsvp$promise$$needsNew() {\n      throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n    }\n\n    function lib$rsvp$promise$$Promise(resolver, label) {\n      this._id = lib$rsvp$promise$$counter++;\n      this._label = label;\n      this._state = undefined;\n      this._result = undefined;\n      this._subscribers = [];\n\n      lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('created', this);\n\n      if (lib$rsvp$$internal$$noop !== resolver) {\n        typeof resolver !== 'function' && lib$rsvp$promise$$needsResolver();\n        this instanceof lib$rsvp$promise$$Promise ? lib$rsvp$$internal$$initializePromise(this, resolver) : lib$rsvp$promise$$needsNew();\n      }\n    }\n\n    var lib$rsvp$promise$$default = lib$rsvp$promise$$Promise;\n\n    // deprecated\n    lib$rsvp$promise$$Promise.cast = lib$rsvp$promise$resolve$$default;\n    lib$rsvp$promise$$Promise.all = lib$rsvp$promise$all$$default;\n    lib$rsvp$promise$$Promise.race = lib$rsvp$promise$race$$default;\n    lib$rsvp$promise$$Promise.resolve = lib$rsvp$promise$resolve$$default;\n    lib$rsvp$promise$$Promise.reject = lib$rsvp$promise$reject$$default;\n\n    lib$rsvp$promise$$Promise.prototype = {\n      constructor: lib$rsvp$promise$$Promise,\n\n      _guidKey: lib$rsvp$promise$$guidKey,\n\n      _onError: function (reason) {\n        var promise = this;\n        lib$rsvp$config$$config.after(function() {\n          if (promise._onError) {\n            lib$rsvp$config$$config['trigger']('error', reason, promise._label);\n          }\n        });\n      },\n\n    /**\n      The primary way of interacting with a promise is through its `then` method,\n      which registers callbacks to receive either a promise's eventual value or the\n      reason why the promise cannot be fulfilled.\n\n      ```js\n      findUser().then(function(user){\n        // user is available\n      }, function(reason){\n        // user is unavailable, and you are given the reason why\n      });\n      ```\n\n      Chaining\n      --------\n\n      The return value of `then` is itself a promise.  This second, 'downstream'\n      promise is resolved with the return value of the first promise's fulfillment\n      or rejection handler, or rejected if the handler throws an exception.\n\n      ```js\n      findUser().then(function (user) {\n        return user.name;\n      }, function (reason) {\n        return 'default name';\n      }).then(function (userName) {\n        // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n        // will be `'default name'`\n      });\n\n      findUser().then(function (user) {\n        throw new Error('Found user, but still unhappy');\n      }, function (reason) {\n        throw new Error('`findUser` rejected and we're unhappy');\n      }).then(function (value) {\n        // never reached\n      }, function (reason) {\n        // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n        // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n      });\n      ```\n      If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n\n      ```js\n      findUser().then(function (user) {\n        throw new PedagogicalException('Upstream error');\n      }).then(function (value) {\n        // never reached\n      }).then(function (value) {\n        // never reached\n      }, function (reason) {\n        // The `PedgagocialException` is propagated all the way down to here\n      });\n      ```\n\n      Assimilation\n      ------------\n\n      Sometimes the value you want to propagate to a downstream promise can only be\n      retrieved asynchronously. This can be achieved by returning a promise in the\n      fulfillment or rejection handler. The downstream promise will then be pending\n      until the returned promise is settled. This is called *assimilation*.\n\n      ```js\n      findUser().then(function (user) {\n        return findCommentsByAuthor(user);\n      }).then(function (comments) {\n        // The user's comments are now available\n      });\n      ```\n\n      If the assimliated promise rejects, then the downstream promise will also reject.\n\n      ```js\n      findUser().then(function (user) {\n        return findCommentsByAuthor(user);\n      }).then(function (comments) {\n        // If `findCommentsByAuthor` fulfills, we'll have the value here\n      }, function (reason) {\n        // If `findCommentsByAuthor` rejects, we'll have the reason here\n      });\n      ```\n\n      Simple Example\n      --------------\n\n      Synchronous Example\n\n      ```javascript\n      var result;\n\n      try {\n        result = findResult();\n        // success\n      } catch(reason) {\n        // failure\n      }\n      ```\n\n      Errback Example\n\n      ```js\n      findResult(function(result, err){\n        if (err) {\n          // failure\n        } else {\n          // success\n        }\n      });\n      ```\n\n      Promise Example;\n\n      ```javascript\n      findResult().then(function(result){\n        // success\n      }, function(reason){\n        // failure\n      });\n      ```\n\n      Advanced Example\n      --------------\n\n      Synchronous Example\n\n      ```javascript\n      var author, books;\n\n      try {\n        author = findAuthor();\n        books  = findBooksByAuthor(author);\n        // success\n      } catch(reason) {\n        // failure\n      }\n      ```\n\n      Errback Example\n\n      ```js\n\n      function foundBooks(books) {\n\n      }\n\n      function failure(reason) {\n\n      }\n\n      findAuthor(function(author, err){\n        if (err) {\n          failure(err);\n          // failure\n        } else {\n          try {\n            findBoooksByAuthor(author, function(books, err) {\n              if (err) {\n                failure(err);\n              } else {\n                try {\n                  foundBooks(books);\n                } catch(reason) {\n                  failure(reason);\n                }\n              }\n            });\n          } catch(error) {\n            failure(err);\n          }\n          // success\n        }\n      });\n      ```\n\n      Promise Example;\n\n      ```javascript\n      findAuthor().\n        then(findBooksByAuthor).\n        then(function(books){\n          // found books\n      }).catch(function(reason){\n        // something went wrong\n      });\n      ```\n\n      @method then\n      @param {Function} onFulfillment\n      @param {Function} onRejection\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      then: lib$rsvp$then$$default,\n\n    /**\n      `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n      as the catch block of a try/catch statement.\n\n      ```js\n      function findAuthor(){\n        throw new Error('couldn't find that author');\n      }\n\n      // synchronous\n      try {\n        findAuthor();\n      } catch(reason) {\n        // something went wrong\n      }\n\n      // async with promises\n      findAuthor().catch(function(reason){\n        // something went wrong\n      });\n      ```\n\n      @method catch\n      @param {Function} onRejection\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      'catch': function(onRejection, label) {\n        return this.then(undefined, onRejection, label);\n      },\n\n    /**\n      `finally` will be invoked regardless of the promise's fate just as native\n      try/catch/finally behaves\n\n      Synchronous example:\n\n      ```js\n      findAuthor() {\n        if (Math.random() > 0.5) {\n          throw new Error();\n        }\n        return new Author();\n      }\n\n      try {\n        return findAuthor(); // succeed or fail\n      } catch(error) {\n        return findOtherAuther();\n      } finally {\n        // always runs\n        // doesn't affect the return value\n      }\n      ```\n\n      Asynchronous example:\n\n      ```js\n      findAuthor().catch(function(reason){\n        return findOtherAuther();\n      }).finally(function(){\n        // author was either found, or not\n      });\n      ```\n\n      @method finally\n      @param {Function} callback\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      'finally': function(callback, label) {\n        var promise = this;\n        var constructor = promise.constructor;\n\n        return promise.then(function(value) {\n          return constructor.resolve(callback()).then(function() {\n            return value;\n          });\n        }, function(reason) {\n          return constructor.resolve(callback()).then(function() {\n            return constructor.reject(reason);\n          });\n        }, label);\n      }\n    };\n    function  lib$rsvp$$internal$$withOwnPromise() {\n      return new TypeError('A promises callback cannot return that same promise.');\n    }\n\n    function lib$rsvp$$internal$$noop() {}\n\n    var lib$rsvp$$internal$$PENDING   = void 0;\n    var lib$rsvp$$internal$$FULFILLED = 1;\n    var lib$rsvp$$internal$$REJECTED  = 2;\n\n    var lib$rsvp$$internal$$GET_THEN_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n    function lib$rsvp$$internal$$getThen(promise) {\n      try {\n        return promise.then;\n      } catch(error) {\n        lib$rsvp$$internal$$GET_THEN_ERROR.error = error;\n        return lib$rsvp$$internal$$GET_THEN_ERROR;\n      }\n    }\n\n    function lib$rsvp$$internal$$tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n      try {\n        then.call(value, fulfillmentHandler, rejectionHandler);\n      } catch(e) {\n        return e;\n      }\n    }\n\n    function lib$rsvp$$internal$$handleForeignThenable(promise, thenable, then) {\n      lib$rsvp$config$$config.async(function(promise) {\n        var sealed = false;\n        var error = lib$rsvp$$internal$$tryThen(then, thenable, function(value) {\n          if (sealed) { return; }\n          sealed = true;\n          if (thenable !== value) {\n            lib$rsvp$$internal$$resolve(promise, value, undefined);\n          } else {\n            lib$rsvp$$internal$$fulfill(promise, value);\n          }\n        }, function(reason) {\n          if (sealed) { return; }\n          sealed = true;\n\n          lib$rsvp$$internal$$reject(promise, reason);\n        }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n        if (!sealed && error) {\n          sealed = true;\n          lib$rsvp$$internal$$reject(promise, error);\n        }\n      }, promise);\n    }\n\n    function lib$rsvp$$internal$$handleOwnThenable(promise, thenable) {\n      if (thenable._state === lib$rsvp$$internal$$FULFILLED) {\n        lib$rsvp$$internal$$fulfill(promise, thenable._result);\n      } else if (thenable._state === lib$rsvp$$internal$$REJECTED) {\n        thenable._onError = null;\n        lib$rsvp$$internal$$reject(promise, thenable._result);\n      } else {\n        lib$rsvp$$internal$$subscribe(thenable, undefined, function(value) {\n          if (thenable !== value) {\n            lib$rsvp$$internal$$resolve(promise, value, undefined);\n          } else {\n            lib$rsvp$$internal$$fulfill(promise, value);\n          }\n        }, function(reason) {\n          lib$rsvp$$internal$$reject(promise, reason);\n        });\n      }\n    }\n\n    function lib$rsvp$$internal$$handleMaybeThenable(promise, maybeThenable, then) {\n      if (maybeThenable.constructor === promise.constructor &&\n          then === lib$rsvp$then$$default &&\n          constructor.resolve === lib$rsvp$promise$resolve$$default) {\n        lib$rsvp$$internal$$handleOwnThenable(promise, maybeThenable);\n      } else {\n        if (then === lib$rsvp$$internal$$GET_THEN_ERROR) {\n          lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$GET_THEN_ERROR.error);\n        } else if (then === undefined) {\n          lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n        } else if (lib$rsvp$utils$$isFunction(then)) {\n          lib$rsvp$$internal$$handleForeignThenable(promise, maybeThenable, then);\n        } else {\n          lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n        }\n      }\n    }\n\n    function lib$rsvp$$internal$$resolve(promise, value) {\n      if (promise === value) {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      } else if (lib$rsvp$utils$$objectOrFunction(value)) {\n        lib$rsvp$$internal$$handleMaybeThenable(promise, value, lib$rsvp$$internal$$getThen(value));\n      } else {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      }\n    }\n\n    function lib$rsvp$$internal$$publishRejection(promise) {\n      if (promise._onError) {\n        promise._onError(promise._result);\n      }\n\n      lib$rsvp$$internal$$publish(promise);\n    }\n\n    function lib$rsvp$$internal$$fulfill(promise, value) {\n      if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n\n      promise._result = value;\n      promise._state = lib$rsvp$$internal$$FULFILLED;\n\n      if (promise._subscribers.length === 0) {\n        if (lib$rsvp$config$$config.instrument) {\n          lib$rsvp$instrument$$default('fulfilled', promise);\n        }\n      } else {\n        lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, promise);\n      }\n    }\n\n    function lib$rsvp$$internal$$reject(promise, reason) {\n      if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n      promise._state = lib$rsvp$$internal$$REJECTED;\n      promise._result = reason;\n      lib$rsvp$config$$config.async(lib$rsvp$$internal$$publishRejection, promise);\n    }\n\n    function lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection) {\n      var subscribers = parent._subscribers;\n      var length = subscribers.length;\n\n      parent._onError = null;\n\n      subscribers[length] = child;\n      subscribers[length + lib$rsvp$$internal$$FULFILLED] = onFulfillment;\n      subscribers[length + lib$rsvp$$internal$$REJECTED]  = onRejection;\n\n      if (length === 0 && parent._state) {\n        lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, parent);\n      }\n    }\n\n    function lib$rsvp$$internal$$publish(promise) {\n      var subscribers = promise._subscribers;\n      var settled = promise._state;\n\n      if (lib$rsvp$config$$config.instrument) {\n        lib$rsvp$instrument$$default(settled === lib$rsvp$$internal$$FULFILLED ? 'fulfilled' : 'rejected', promise);\n      }\n\n      if (subscribers.length === 0) { return; }\n\n      var child, callback, detail = promise._result;\n\n      for (var i = 0; i < subscribers.length; i += 3) {\n        child = subscribers[i];\n        callback = subscribers[i + settled];\n\n        if (child) {\n          lib$rsvp$$internal$$invokeCallback(settled, child, callback, detail);\n        } else {\n          callback(detail);\n        }\n      }\n\n      promise._subscribers.length = 0;\n    }\n\n    function lib$rsvp$$internal$$ErrorObject() {\n      this.error = null;\n    }\n\n    var lib$rsvp$$internal$$TRY_CATCH_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n    function lib$rsvp$$internal$$tryCatch(callback, detail) {\n      try {\n        return callback(detail);\n      } catch(e) {\n        lib$rsvp$$internal$$TRY_CATCH_ERROR.error = e;\n        return lib$rsvp$$internal$$TRY_CATCH_ERROR;\n      }\n    }\n\n    function lib$rsvp$$internal$$invokeCallback(settled, promise, callback, detail) {\n      var hasCallback = lib$rsvp$utils$$isFunction(callback),\n          value, error, succeeded, failed;\n\n      if (hasCallback) {\n        value = lib$rsvp$$internal$$tryCatch(callback, detail);\n\n        if (value === lib$rsvp$$internal$$TRY_CATCH_ERROR) {\n          failed = true;\n          error = value.error;\n          value = null;\n        } else {\n          succeeded = true;\n        }\n\n        if (promise === value) {\n          lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$withOwnPromise());\n          return;\n        }\n\n      } else {\n        value = detail;\n        succeeded = true;\n      }\n\n      if (promise._state !== lib$rsvp$$internal$$PENDING) {\n        // noop\n      } else if (hasCallback && succeeded) {\n        lib$rsvp$$internal$$resolve(promise, value);\n      } else if (failed) {\n        lib$rsvp$$internal$$reject(promise, error);\n      } else if (settled === lib$rsvp$$internal$$FULFILLED) {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      } else if (settled === lib$rsvp$$internal$$REJECTED) {\n        lib$rsvp$$internal$$reject(promise, value);\n      }\n    }\n\n    function lib$rsvp$$internal$$initializePromise(promise, resolver) {\n      var resolved = false;\n      try {\n        resolver(function resolvePromise(value){\n          if (resolved) { return; }\n          resolved = true;\n          lib$rsvp$$internal$$resolve(promise, value);\n        }, function rejectPromise(reason) {\n          if (resolved) { return; }\n          resolved = true;\n          lib$rsvp$$internal$$reject(promise, reason);\n        });\n      } catch(e) {\n        lib$rsvp$$internal$$reject(promise, e);\n      }\n    }\n\n    function lib$rsvp$all$settled$$AllSettled(Constructor, entries, label) {\n      this._superConstructor(Constructor, entries, false /* don't abort on reject */, label);\n    }\n\n    lib$rsvp$all$settled$$AllSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n    lib$rsvp$all$settled$$AllSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$all$settled$$AllSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n    lib$rsvp$all$settled$$AllSettled.prototype._validationError = function() {\n      return new Error('allSettled must be called with an array');\n    };\n\n    function lib$rsvp$all$settled$$allSettled(entries, label) {\n      return new lib$rsvp$all$settled$$AllSettled(lib$rsvp$promise$$default, entries, label).promise;\n    }\n    var lib$rsvp$all$settled$$default = lib$rsvp$all$settled$$allSettled;\n    function lib$rsvp$all$$all(array, label) {\n      return lib$rsvp$promise$$default.all(array, label);\n    }\n    var lib$rsvp$all$$default = lib$rsvp$all$$all;\n    var lib$rsvp$asap$$len = 0;\n    var lib$rsvp$asap$$toString = {}.toString;\n    var lib$rsvp$asap$$vertxNext;\n    function lib$rsvp$asap$$asap(callback, arg) {\n      lib$rsvp$asap$$queue[lib$rsvp$asap$$len] = callback;\n      lib$rsvp$asap$$queue[lib$rsvp$asap$$len + 1] = arg;\n      lib$rsvp$asap$$len += 2;\n      if (lib$rsvp$asap$$len === 2) {\n        // If len is 1, that means that we need to schedule an async flush.\n        // If additional callbacks are queued before the queue is flushed, they\n        // will be processed by this flush that we are scheduling.\n        lib$rsvp$asap$$scheduleFlush();\n      }\n    }\n\n    var lib$rsvp$asap$$default = lib$rsvp$asap$$asap;\n\n    var lib$rsvp$asap$$browserWindow = (typeof window !== 'undefined') ? window : undefined;\n    var lib$rsvp$asap$$browserGlobal = lib$rsvp$asap$$browserWindow || {};\n    var lib$rsvp$asap$$BrowserMutationObserver = lib$rsvp$asap$$browserGlobal.MutationObserver || lib$rsvp$asap$$browserGlobal.WebKitMutationObserver;\n    var lib$rsvp$asap$$isNode = typeof self === 'undefined' &&\n      typeof process !== 'undefined' && {}.toString.call(process) === '[object process]';\n\n    // test for web worker but not in IE10\n    var lib$rsvp$asap$$isWorker = typeof Uint8ClampedArray !== 'undefined' &&\n      typeof importScripts !== 'undefined' &&\n      typeof MessageChannel !== 'undefined';\n\n    // node\n    function lib$rsvp$asap$$useNextTick() {\n      var nextTick = process.nextTick;\n      // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n      // setImmediate should be used instead instead\n      var version = process.versions.node.match(/^(?:(\\d+)\\.)?(?:(\\d+)\\.)?(\\*|\\d+)$/);\n      if (Array.isArray(version) && version[1] === '0' && version[2] === '10') {\n        nextTick = setImmediate;\n      }\n      return function() {\n        nextTick(lib$rsvp$asap$$flush);\n      };\n    }\n\n    // vertx\n    function lib$rsvp$asap$$useVertxTimer() {\n      return function() {\n        lib$rsvp$asap$$vertxNext(lib$rsvp$asap$$flush);\n      };\n    }\n\n    function lib$rsvp$asap$$useMutationObserver() {\n      var iterations = 0;\n      var observer = new lib$rsvp$asap$$BrowserMutationObserver(lib$rsvp$asap$$flush);\n      var node = document.createTextNode('');\n      observer.observe(node, { characterData: true });\n\n      return function() {\n        node.data = (iterations = ++iterations % 2);\n      };\n    }\n\n    // web worker\n    function lib$rsvp$asap$$useMessageChannel() {\n      var channel = new MessageChannel();\n      channel.port1.onmessage = lib$rsvp$asap$$flush;\n      return function () {\n        channel.port2.postMessage(0);\n      };\n    }\n\n    function lib$rsvp$asap$$useSetTimeout() {\n      return function() {\n        setTimeout(lib$rsvp$asap$$flush, 1);\n      };\n    }\n\n    var lib$rsvp$asap$$queue = new Array(1000);\n    function lib$rsvp$asap$$flush() {\n      for (var i = 0; i < lib$rsvp$asap$$len; i+=2) {\n        var callback = lib$rsvp$asap$$queue[i];\n        var arg = lib$rsvp$asap$$queue[i+1];\n\n        callback(arg);\n\n        lib$rsvp$asap$$queue[i] = undefined;\n        lib$rsvp$asap$$queue[i+1] = undefined;\n      }\n\n      lib$rsvp$asap$$len = 0;\n    }\n\n    function lib$rsvp$asap$$attemptVertex() {\n      try {\n        var r = require;\n        var vertx = r('vertx');\n        lib$rsvp$asap$$vertxNext = vertx.runOnLoop || vertx.runOnContext;\n        return lib$rsvp$asap$$useVertxTimer();\n      } catch(e) {\n        return lib$rsvp$asap$$useSetTimeout();\n      }\n    }\n\n    var lib$rsvp$asap$$scheduleFlush;\n    // Decide what async method to use to triggering processing of queued callbacks:\n    if (lib$rsvp$asap$$isNode) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useNextTick();\n    } else if (lib$rsvp$asap$$BrowserMutationObserver) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMutationObserver();\n    } else if (lib$rsvp$asap$$isWorker) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMessageChannel();\n    } else if (lib$rsvp$asap$$browserWindow === undefined && typeof require === 'function') {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$attemptVertex();\n    } else {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useSetTimeout();\n    }\n    function lib$rsvp$defer$$defer(label) {\n      var deferred = {};\n\n      deferred['promise'] = new lib$rsvp$promise$$default(function(resolve, reject) {\n        deferred['resolve'] = resolve;\n        deferred['reject'] = reject;\n      }, label);\n\n      return deferred;\n    }\n    var lib$rsvp$defer$$default = lib$rsvp$defer$$defer;\n    function lib$rsvp$filter$$filter(promises, filterFn, label) {\n      return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n        if (!lib$rsvp$utils$$isFunction(filterFn)) {\n          throw new TypeError(\"You must pass a function as filter's second argument.\");\n        }\n\n        var length = values.length;\n        var filtered = new Array(length);\n\n        for (var i = 0; i < length; i++) {\n          filtered[i] = filterFn(values[i]);\n        }\n\n        return lib$rsvp$promise$$default.all(filtered, label).then(function(filtered) {\n          var results = new Array(length);\n          var newLength = 0;\n\n          for (var i = 0; i < length; i++) {\n            if (filtered[i]) {\n              results[newLength] = values[i];\n              newLength++;\n            }\n          }\n\n          results.length = newLength;\n\n          return results;\n        });\n      });\n    }\n    var lib$rsvp$filter$$default = lib$rsvp$filter$$filter;\n\n    function lib$rsvp$promise$hash$$PromiseHash(Constructor, object, label) {\n      this._superConstructor(Constructor, object, true, label);\n    }\n\n    var lib$rsvp$promise$hash$$default = lib$rsvp$promise$hash$$PromiseHash;\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n    lib$rsvp$promise$hash$$PromiseHash.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$promise$hash$$PromiseHash.prototype._init = function() {\n      this._result = {};\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._validateInput = function(input) {\n      return input && typeof input === 'object';\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._validationError = function() {\n      return new Error('Promise.hash must be called with an object');\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._enumerate = function() {\n      var enumerator = this;\n      var promise    = enumerator.promise;\n      var input      = enumerator._input;\n      var results    = [];\n\n      for (var key in input) {\n        if (promise._state === lib$rsvp$$internal$$PENDING && Object.prototype.hasOwnProperty.call(input, key)) {\n          results.push({\n            position: key,\n            entry: input[key]\n          });\n        }\n      }\n\n      var length = results.length;\n      enumerator._remaining = length;\n      var result;\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        result = results[i];\n        enumerator._eachEntry(result.entry, result.position);\n      }\n    };\n\n    function lib$rsvp$hash$settled$$HashSettled(Constructor, object, label) {\n      this._superConstructor(Constructor, object, false, label);\n    }\n\n    lib$rsvp$hash$settled$$HashSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$promise$hash$$default.prototype);\n    lib$rsvp$hash$settled$$HashSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$hash$settled$$HashSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n\n    lib$rsvp$hash$settled$$HashSettled.prototype._validationError = function() {\n      return new Error('hashSettled must be called with an object');\n    };\n\n    function lib$rsvp$hash$settled$$hashSettled(object, label) {\n      return new lib$rsvp$hash$settled$$HashSettled(lib$rsvp$promise$$default, object, label).promise;\n    }\n    var lib$rsvp$hash$settled$$default = lib$rsvp$hash$settled$$hashSettled;\n    function lib$rsvp$hash$$hash(object, label) {\n      return new lib$rsvp$promise$hash$$default(lib$rsvp$promise$$default, object, label).promise;\n    }\n    var lib$rsvp$hash$$default = lib$rsvp$hash$$hash;\n    function lib$rsvp$map$$map(promises, mapFn, label) {\n      return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n        if (!lib$rsvp$utils$$isFunction(mapFn)) {\n          throw new TypeError(\"You must pass a function as map's second argument.\");\n        }\n\n        var length = values.length;\n        var results = new Array(length);\n\n        for (var i = 0; i < length; i++) {\n          results[i] = mapFn(values[i]);\n        }\n\n        return lib$rsvp$promise$$default.all(results, label);\n      });\n    }\n    var lib$rsvp$map$$default = lib$rsvp$map$$map;\n\n    function lib$rsvp$node$$Result() {\n      this.value = undefined;\n    }\n\n    var lib$rsvp$node$$ERROR = new lib$rsvp$node$$Result();\n    var lib$rsvp$node$$GET_THEN_ERROR = new lib$rsvp$node$$Result();\n\n    function lib$rsvp$node$$getThen(obj) {\n      try {\n       return obj.then;\n      } catch(error) {\n        lib$rsvp$node$$ERROR.value= error;\n        return lib$rsvp$node$$ERROR;\n      }\n    }\n\n\n    function lib$rsvp$node$$tryApply(f, s, a) {\n      try {\n        f.apply(s, a);\n      } catch(error) {\n        lib$rsvp$node$$ERROR.value = error;\n        return lib$rsvp$node$$ERROR;\n      }\n    }\n\n    function lib$rsvp$node$$makeObject(_, argumentNames) {\n      var obj = {};\n      var name;\n      var i;\n      var length = _.length;\n      var args = new Array(length);\n\n      for (var x = 0; x < length; x++) {\n        args[x] = _[x];\n      }\n\n      for (i = 0; i < argumentNames.length; i++) {\n        name = argumentNames[i];\n        obj[name] = args[i + 1];\n      }\n\n      return obj;\n    }\n\n    function lib$rsvp$node$$arrayResult(_) {\n      var length = _.length;\n      var args = new Array(length - 1);\n\n      for (var i = 1; i < length; i++) {\n        args[i - 1] = _[i];\n      }\n\n      return args;\n    }\n\n    function lib$rsvp$node$$wrapThenable(then, promise) {\n      return {\n        then: function(onFulFillment, onRejection) {\n          return then.call(promise, onFulFillment, onRejection);\n        }\n      };\n    }\n\n    function lib$rsvp$node$$denodeify(nodeFunc, options) {\n      var fn = function() {\n        var self = this;\n        var l = arguments.length;\n        var args = new Array(l + 1);\n        var arg;\n        var promiseInput = false;\n\n        for (var i = 0; i < l; ++i) {\n          arg = arguments[i];\n\n          if (!promiseInput) {\n            // TODO: clean this up\n            promiseInput = lib$rsvp$node$$needsPromiseInput(arg);\n            if (promiseInput === lib$rsvp$node$$GET_THEN_ERROR) {\n              var p = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n              lib$rsvp$$internal$$reject(p, lib$rsvp$node$$GET_THEN_ERROR.value);\n              return p;\n            } else if (promiseInput && promiseInput !== true) {\n              arg = lib$rsvp$node$$wrapThenable(promiseInput, arg);\n            }\n          }\n          args[i] = arg;\n        }\n\n        var promise = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n\n        args[l] = function(err, val) {\n          if (err)\n            lib$rsvp$$internal$$reject(promise, err);\n          else if (options === undefined)\n            lib$rsvp$$internal$$resolve(promise, val);\n          else if (options === true)\n            lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$arrayResult(arguments));\n          else if (lib$rsvp$utils$$isArray(options))\n            lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$makeObject(arguments, options));\n          else\n            lib$rsvp$$internal$$resolve(promise, val);\n        };\n\n        if (promiseInput) {\n          return lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self);\n        } else {\n          return lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self);\n        }\n      };\n\n      fn.__proto__ = nodeFunc;\n\n      return fn;\n    }\n\n    var lib$rsvp$node$$default = lib$rsvp$node$$denodeify;\n\n    function lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self) {\n      var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n      if (result === lib$rsvp$node$$ERROR) {\n        lib$rsvp$$internal$$reject(promise, result.value);\n      }\n      return promise;\n    }\n\n    function lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self){\n      return lib$rsvp$promise$$default.all(args).then(function(args){\n        var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n        if (result === lib$rsvp$node$$ERROR) {\n          lib$rsvp$$internal$$reject(promise, result.value);\n        }\n        return promise;\n      });\n    }\n\n    function lib$rsvp$node$$needsPromiseInput(arg) {\n      if (arg && typeof arg === 'object') {\n        if (arg.constructor === lib$rsvp$promise$$default) {\n          return true;\n        } else {\n          return lib$rsvp$node$$getThen(arg);\n        }\n      } else {\n        return false;\n      }\n    }\n    var lib$rsvp$platform$$platform;\n\n    /* global self */\n    if (typeof self === 'object') {\n      lib$rsvp$platform$$platform = self;\n\n    /* global global */\n    } else if (typeof global === 'object') {\n      lib$rsvp$platform$$platform = global;\n    } else {\n      throw new Error('no global: `self` or `global` found');\n    }\n\n    var lib$rsvp$platform$$default = lib$rsvp$platform$$platform;\n    function lib$rsvp$race$$race(array, label) {\n      return lib$rsvp$promise$$default.race(array, label);\n    }\n    var lib$rsvp$race$$default = lib$rsvp$race$$race;\n    function lib$rsvp$reject$$reject(reason, label) {\n      return lib$rsvp$promise$$default.reject(reason, label);\n    }\n    var lib$rsvp$reject$$default = lib$rsvp$reject$$reject;\n    function lib$rsvp$resolve$$resolve(value, label) {\n      return lib$rsvp$promise$$default.resolve(value, label);\n    }\n    var lib$rsvp$resolve$$default = lib$rsvp$resolve$$resolve;\n    function lib$rsvp$rethrow$$rethrow(reason) {\n      setTimeout(function() {\n        throw reason;\n      });\n      throw reason;\n    }\n    var lib$rsvp$rethrow$$default = lib$rsvp$rethrow$$rethrow;\n\n    // defaults\n    lib$rsvp$config$$config.async = lib$rsvp$asap$$default;\n    lib$rsvp$config$$config.after = function(cb) {\n      setTimeout(cb, 0);\n    };\n    var lib$rsvp$$cast = lib$rsvp$resolve$$default;\n    function lib$rsvp$$async(callback, arg) {\n      lib$rsvp$config$$config.async(callback, arg);\n    }\n\n    function lib$rsvp$$on() {\n      lib$rsvp$config$$config['on'].apply(lib$rsvp$config$$config, arguments);\n    }\n\n    function lib$rsvp$$off() {\n      lib$rsvp$config$$config['off'].apply(lib$rsvp$config$$config, arguments);\n    }\n\n    // Set up instrumentation through `window.__PROMISE_INTRUMENTATION__`\n    if (typeof window !== 'undefined' && typeof window['__PROMISE_INSTRUMENTATION__'] === 'object') {\n      var lib$rsvp$$callbacks = window['__PROMISE_INSTRUMENTATION__'];\n      lib$rsvp$config$$configure('instrument', true);\n      for (var lib$rsvp$$eventName in lib$rsvp$$callbacks) {\n        if (lib$rsvp$$callbacks.hasOwnProperty(lib$rsvp$$eventName)) {\n          lib$rsvp$$on(lib$rsvp$$eventName, lib$rsvp$$callbacks[lib$rsvp$$eventName]);\n        }\n      }\n    }\n\n    var lib$rsvp$umd$$RSVP = {\n      'race': lib$rsvp$race$$default,\n      'Promise': lib$rsvp$promise$$default,\n      'allSettled': lib$rsvp$all$settled$$default,\n      'hash': lib$rsvp$hash$$default,\n      'hashSettled': lib$rsvp$hash$settled$$default,\n      'denodeify': lib$rsvp$node$$default,\n      'on': lib$rsvp$$on,\n      'off': lib$rsvp$$off,\n      'map': lib$rsvp$map$$default,\n      'filter': lib$rsvp$filter$$default,\n      'resolve': lib$rsvp$resolve$$default,\n      'reject': lib$rsvp$reject$$default,\n      'all': lib$rsvp$all$$default,\n      'rethrow': lib$rsvp$rethrow$$default,\n      'defer': lib$rsvp$defer$$default,\n      'EventTarget': lib$rsvp$events$$default,\n      'configure': lib$rsvp$config$$configure,\n      'async': lib$rsvp$$async\n    };\n\n    /* global define:true module:true window: true */\n    if (typeof define === 'function' && define['amd']) {\n      define(function() { return lib$rsvp$umd$$RSVP; });\n    } else if (typeof module !== 'undefined' && module['exports']) {\n      module['exports'] = lib$rsvp$umd$$RSVP;\n    } else if (typeof lib$rsvp$platform$$default !== 'undefined') {\n      lib$rsvp$platform$$default['RSVP'] = lib$rsvp$umd$$RSVP;\n    }\n}).call(this);\n\n"]} //# sourceMappingURL=algorithm_visualizer.js.map diff --git a/public/algorithm_visualizer.js.map b/public/algorithm_visualizer.js.map index bf4fa63..d74ee0e 100644 --- a/public/algorithm_visualizer.js.map +++ b/public/algorithm_visualizer.js.map @@ -1 +1 @@ -{"version":3,"names":[],"mappings":"","sources":["algorithm_visualizer.js"],"sourcesContent":["/**\n * algorithm-visualizer - Algorithm Visualizer\n * @version v0.1.0\n * @author Jason Park & contributors\n * @link https://github.com/parkjs814/AlgorithmVisualizer#readme\n * @license MIT\n */\n(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})({1:[function(require,module,exports){\n'use strict';\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\nvar cache = {\n lastFileUsed: '',\n files: {}\n};\n\nvar assertFileName = function assertFileName(name) {\n if (!name) {\n throw 'Missing file name';\n }\n};\n\n/**\n * Global application cache\n */\nmodule.exports = {\n getCachedFile: function getCachedFile(name) {\n assertFileName(name);\n return cache.files[name];\n },\n updateCachedFile: function updateCachedFile(name, updates) {\n assertFileName(name);\n if (!cache.files[name]) {\n cache.files[name] = {};\n }\n extend(cache.files[name], updates);\n },\n getLastFileUsed: function getLastFileUsed() {\n return cache.lastFileUsed;\n },\n setLastFileUsed: function setLastFileUsed(file) {\n cache.lastFileUsed = file;\n }\n};\n\n},{}],2:[function(require,module,exports){\n'use strict';\n\nvar Editor = require('../editor');\nvar TracerManager = require('../tracer_manager');\nvar DOM = require('../dom/setup');\n\nvar _require = require('../dom/loading_slider');\n\nvar showLoadingSlider = _require.showLoadingSlider;\nvar hideLoadingSlider = _require.hideLoadingSlider;\n\n\nvar Cache = require('./cache');\n\nvar state = {\n isLoading: null,\n editor: null,\n tracerManager: null,\n categories: null,\n loadedScratch: null,\n wikiList: null\n};\n\nvar initState = function initState(tracerManager) {\n state.isLoading = false;\n state.editor = new Editor(tracerManager);\n state.tracerManager = tracerManager;\n state.categories = {};\n state.loadedScratch = null;\n state.wikiList = [];\n};\n\n/**\n * Global application singleton.\n */\nvar App = function App() {\n\n this.getIsLoading = function () {\n return state.isLoading;\n };\n\n this.setIsLoading = function (loading) {\n state.isLoading = loading;\n if (loading) {\n showLoadingSlider();\n } else {\n hideLoadingSlider();\n }\n };\n\n this.getEditor = function () {\n return state.editor;\n };\n\n this.getCategories = function () {\n return state.categories;\n };\n\n this.getCategory = function (name) {\n return state.categories[name];\n };\n\n this.setCategories = function (categories) {\n state.categories = categories;\n };\n\n this.updateCategory = function (name, updates) {\n $.extend(state.categories[name], updates);\n };\n\n this.getTracerManager = function () {\n return state.tracerManager;\n };\n\n this.getLoadedScratch = function () {\n return state.loadedScratch;\n };\n\n this.setLoadedScratch = function (loadedScratch) {\n state.loadedScratch = loadedScratch;\n };\n\n this.getWikiList = function () {\n return state.wikiList;\n };\n\n this.setWikiList = function (wikiList) {\n state.wikiList = wikiList;\n };\n\n this.hasWiki = function (wiki) {\n return ~state.wikiList.indexOf(wiki);\n };\n\n var tracerManager = TracerManager.init();\n\n initState(tracerManager);\n DOM.setup(tracerManager);\n};\n\nApp.prototype = Cache;\n\nmodule.exports = App;\n\n},{\"../dom/loading_slider\":7,\"../dom/setup\":9,\"../editor\":28,\"../tracer_manager\":64,\"./cache\":1}],3:[function(require,module,exports){\n'use strict';\n\n/**\n * This is the main application instance.\n * Gets populated on page load. \n */\n\nmodule.exports = {};\n\n},{}],4:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar Server = require('../server');\nvar showAlgorithm = require('./show_algorithm');\n\nvar _$ = $;\nvar each = _$.each;\n\n\nvar getAlgorithmDOM = function getAlgorithmDOM(category, subList, algorithm) {\n return $('<button class=\"indent\">').append(subList[algorithm]).attr('data-algorithm', algorithm).attr('data-category', category).click(function () {\n Server.loadAlgorithm(category, algorithm).then(function (data) {\n showAlgorithm(category, algorithm, data);\n });\n });\n\n $('#list').append($algorithm);\n};\n\nvar addCategoryToDOM = function addCategoryToDOM(category) {\n var _app$getCategory = app.getCategory(category);\n\n var categoryName = _app$getCategory.name;\n var categorySubList = _app$getCategory.list;\n\n\n var $category = $('<button class=\"category\">').append('<i class=\"fa fa-fw fa-caret-right\">').append(categoryName).attr('data-category', category);\n\n $category.click(function () {\n var $self = $(this);\n $self.toggleClass('open');\n $self.next().toggleClass('collapse');\n $self.find('i.fa').toggleClass('fa-caret-right fa-caret-down');\n });\n\n var $algorithms = $('<div class=\"algorithms collapse\">');\n $('#list').append($category).append($algorithms);\n\n each(categorySubList, function (algorithm) {\n var $algorithm = getAlgorithmDOM(category, categorySubList, algorithm);\n $algorithms.append($algorithm);\n });\n};\n\nmodule.exports = function () {\n each(app.getCategories(), addCategoryToDOM);\n};\n\n},{\"../app\":3,\"../server\":56,\"./show_algorithm\":19}],5:[function(require,module,exports){\n'use strict';\n\nvar Server = require('../server');\n\nvar _$ = $;\nvar each = _$.each;\n\n\nvar addFileToDOM = function addFileToDOM(category, algorithm, file, explanation) {\n var $file = $('<button>').append(file).attr('data-file', file).click(function () {\n Server.loadFile(category, algorithm, file, explanation);\n $('.files_bar > .wrapper > button').removeClass('active');\n $(this).addClass('active');\n });\n $('.files_bar > .wrapper').append($file);\n return $file;\n};\n\nmodule.exports = function (category, algorithm, files, requestedFile) {\n $('.files_bar > .wrapper').empty();\n\n each(files, function (file, explanation) {\n var $file = addFileToDOM(category, algorithm, file, explanation);\n if (requestedFile && requestedFile == file) $file.click();\n });\n\n if (!requestedFile) $('.files_bar > .wrapper > button').first().click();\n $('.files_bar > .wrapper').scroll();\n};\n\n},{\"../server\":56}],6:[function(require,module,exports){\n'use strict';\n\nvar showAlgorithm = require('./show_algorithm');\nvar addCategories = require('./add_categories');\nvar showDescription = require('./show_description');\nvar addFiles = require('./add_files');\nvar showFirstAlgorithm = require('./show_first_algorithm');\nvar showRequestedAlgorithm = require('./show_requested_algorithm');\nvar showWiki = require('./show_wiki');\n\nmodule.exports = {\n showAlgorithm: showAlgorithm,\n addCategories: addCategories,\n showDescription: showDescription,\n addFiles: addFiles,\n showFirstAlgorithm: showFirstAlgorithm,\n showRequestedAlgorithm: showRequestedAlgorithm,\n showWiki: showWiki\n};\n\n},{\"./add_categories\":4,\"./add_files\":5,\"./show_algorithm\":19,\"./show_description\":20,\"./show_first_algorithm\":21,\"./show_requested_algorithm\":22,\"./show_wiki\":23}],7:[function(require,module,exports){\n'use strict';\n\nvar showLoadingSlider = function showLoadingSlider() {\n $('#loading-slider').removeClass('loaded');\n};\n\nvar hideLoadingSlider = function hideLoadingSlider() {\n $('#loading-slider').addClass('loaded');\n};\n\nmodule.exports = {\n showLoadingSlider: showLoadingSlider,\n hideLoadingSlider: hideLoadingSlider\n};\n\n},{}],8:[function(require,module,exports){\n'use strict';\n\nvar create = function create() {\n var $container = $('<section class=\"module_wrapper\">');\n $('.module_container').append($container);\n return $container;\n};\n\nmodule.exports = {\n create: create\n};\n\n},{}],9:[function(require,module,exports){\n'use strict';\n\nvar setupDividers = require('./setup_dividers');\nvar setupDocument = require('./setup_document');\nvar setupFilesBar = require('./setup_files_bar');\nvar setupInterval = require('./setup_interval');\nvar setupModuleContainer = require('./setup_module_container');\nvar setupTabContainer = require('./setup_tab_container');\nvar setupSideMenu = require('./setup_side_menu');\nvar setupTopMenu = require('./setup_top_menu');\nvar setupWindow = require('./setup_window');\n\n/**\n * Initializes elements once the app loads in the DOM.\n */\nvar setup = function setup() {\n\n $('.btn input').click(function (e) {\n e.stopPropagation();\n });\n\n // dividers\n setupDividers();\n\n // document\n setupDocument();\n\n // files bar\n setupFilesBar();\n\n // interval\n setupInterval();\n\n // module container\n setupModuleContainer();\n\n // tab container\n setupTabContainer();\n\n // side menu\n setupSideMenu();\n\n // top menu\n setupTopMenu();\n\n // window\n setupWindow();\n};\n\nmodule.exports = {\n setup: setup\n};\n\n},{\"./setup_dividers\":10,\"./setup_document\":11,\"./setup_files_bar\":12,\"./setup_interval\":13,\"./setup_module_container\":14,\"./setup_side_menu\":15,\"./setup_tab_container\":16,\"./setup_top_menu\":17,\"./setup_window\":18}],10:[function(require,module,exports){\n'use strict';\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar app = require('../../app');\n\nvar addDividerToDom = function addDividerToDom(divider) {\n var _divider = _slicedToArray(divider, 3);\n\n var vertical = _divider[0];\n var $first = _divider[1];\n var $second = _divider[2];\n\n var $parent = $first.parent();\n var thickness = 5;\n\n var $divider = $('<div class=\"divider\">');\n\n var dragging = false;\n if (vertical) {\n (function () {\n $divider.addClass('vertical');\n\n var _left = -thickness / 2;\n $divider.css({\n top: 0,\n bottom: 0,\n left: _left,\n width: thickness\n });\n\n var x = void 0;\n $divider.mousedown(function (_ref) {\n var pageX = _ref.pageX;\n\n x = pageX;\n dragging = true;\n });\n\n $(document).mousemove(function (_ref2) {\n var pageX = _ref2.pageX;\n\n if (dragging) {\n var new_left = $second.position().left + pageX - x;\n var percent = new_left / $parent.width() * 100;\n percent = Math.min(90, Math.max(10, percent));\n $first.css('right', 100 - percent + '%');\n $second.css('left', percent + '%');\n x = pageX;\n app.getTracerManager().resize();\n $('.files_bar > .wrapper').scroll();\n }\n });\n\n $(document).mouseup(function (e) {\n dragging = false;\n });\n })();\n } else {\n (function () {\n\n $divider.addClass('horizontal');\n var _top = -thickness / 2;\n $divider.css({\n top: _top,\n height: thickness,\n left: 0,\n right: 0\n });\n\n var y = void 0;\n $divider.mousedown(function (_ref3) {\n var pageY = _ref3.pageY;\n\n y = pageY;\n dragging = true;\n });\n\n $(document).mousemove(function (_ref4) {\n var pageY = _ref4.pageY;\n\n if (dragging) {\n var new_top = $second.position().top + pageY - y;\n var percent = new_top / $parent.height() * 100;\n percent = Math.min(90, Math.max(10, percent));\n $first.css('bottom', 100 - percent + '%');\n $second.css('top', percent + '%');\n y = pageY;\n app.getTracerManager().resize();\n }\n });\n\n $(document).mouseup(function (e) {\n dragging = false;\n });\n })();\n }\n\n $second.append($divider);\n};\n\nmodule.exports = function () {\n var dividers = [['v', $('.sidemenu'), $('.workspace')], ['v', $('.viewer_container'), $('.editor_container')], ['h', $('.data_container'), $('.code_container')]];\n for (var i = 0; i < dividers.length; i++) {\n addDividerToDom(dividers[i]);\n }\n};\n\n},{\"../../app\":3}],11:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n $(document).on('click', 'a', function (e) {\n var href = $(this).attr('href');\n if (/^(https?:\\/\\/).+/.test(href)) {\n e.preventDefault();\n if (!window.open(href, '_blank')) {\n alert('Please allow popups for this site');\n }\n }\n });\n\n $(document).mouseup(function (e) {\n app.getTracerManager().command('mouseup', e);\n });\n};\n\n},{\"../../app\":3}],12:[function(require,module,exports){\n'use strict';\n\nvar definitelyBigger = function definitelyBigger(x, y) {\n return x > y + 2;\n};\n\nmodule.exports = function () {\n\n $('.files_bar > .btn-left').click(function () {\n var $wrapper = $('.files_bar > .wrapper');\n var clipWidth = $wrapper.width();\n var scrollLeft = $wrapper.scrollLeft();\n\n $($wrapper.children('button').get().reverse()).each(function () {\n var left = $(this).position().left;\n var right = left + $(this).outerWidth();\n if (0 > left) {\n $wrapper.scrollLeft(scrollLeft + right - clipWidth);\n return false;\n }\n });\n });\n\n $('.files_bar > .btn-right').click(function () {\n var $wrapper = $('.files_bar > .wrapper');\n var clipWidth = $wrapper.width();\n var scrollLeft = $wrapper.scrollLeft();\n\n $wrapper.children('button').each(function () {\n var left = $(this).position().left;\n var right = left + $(this).outerWidth();\n if (clipWidth < right) {\n $wrapper.scrollLeft(scrollLeft + left);\n return false;\n }\n });\n });\n\n $('.files_bar > .wrapper').scroll(function () {\n\n var $wrapper = $('.files_bar > .wrapper');\n var clipWidth = $wrapper.width();\n var $left = $wrapper.children('button:first-child');\n var $right = $wrapper.children('button:last-child');\n var left = $left.position().left;\n var right = $right.position().left + $right.outerWidth();\n\n if (definitelyBigger(0, left) && definitelyBigger(clipWidth, right)) {\n var scrollLeft = $wrapper.scrollLeft();\n $wrapper.scrollLeft(scrollLeft + clipWidth - right);\n return;\n }\n\n var lefter = definitelyBigger(0, left);\n var righter = definitelyBigger(right, clipWidth);\n $wrapper.toggleClass('shadow-left', lefter);\n $wrapper.toggleClass('shadow-right', righter);\n $('.files_bar > .btn-left').attr('disabled', !lefter);\n $('.files_bar > .btn-right').attr('disabled', !righter);\n });\n};\n\n},{}],13:[function(require,module,exports){\n'use strict';\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar app = require('../../app');\nvar Toast = require('../toast');\n\nvar parseFloat = Number.parseFloat;\n\n\nvar minInterval = 0.1;\nvar maxInterval = 10;\nvar startInterval = 0.5;\nvar stepInterval = 0.1;\n\nvar normalize = function normalize(sec) {\n\n var interval = void 0;\n var message = void 0;\n if (sec < minInterval) {\n interval = minInterval;\n message = 'Interval of ' + sec + ' seconds is too low. Setting to min allowed interval of ' + minInterval + ' second(s).';\n } else if (sec > maxInterval) {\n interval = maxInterval;\n message = 'Interval of ' + sec + ' seconds is too high. Setting to max allowed interval of ' + maxInterval + ' second(s).';\n } else {\n interval = sec;\n message = 'Interval has been set to ' + sec + ' second(s).';\n }\n\n return [interval, message];\n};\n\nmodule.exports = function () {\n\n var $interval = $('#interval');\n $interval.val(startInterval);\n $interval.attr({\n max: maxInterval,\n min: minInterval,\n step: stepInterval\n });\n\n $('#interval').on('change', function () {\n var tracerManager = app.getTracerManager();\n\n var _normalize = normalize(parseFloat($(this).val()));\n\n var _normalize2 = _slicedToArray(_normalize, 2);\n\n var seconds = _normalize2[0];\n var message = _normalize2[1];\n\n\n $(this).val(seconds);\n tracerManager.interval = seconds * 1000;\n Toast.showInfoToast(message);\n });\n};\n\n},{\"../../app\":3,\"../toast\":24}],14:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n\n var $module_container = $('.module_container');\n\n $module_container.on('mousedown', '.module_wrapper', function (e) {\n app.getTracerManager().findOwner(this).mousedown(e);\n });\n\n $module_container.on('mousemove', '.module_wrapper', function (e) {\n app.getTracerManager().findOwner(this).mousemove(e);\n });\n\n $module_container.on('DOMMouseScroll mousewheel', '.module_wrapper', function (e) {\n app.getTracerManager().findOwner(this).mousewheel(e);\n });\n};\n\n},{\"../../app\":3}],15:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\nvar Server = require('../../server');\nvar showAlgorithm = require('../show_algorithm');\n\nvar sidemenu_percent = void 0;\n\nmodule.exports = function () {\n $('#navigation').click(function () {\n var $sidemenu = $('.sidemenu');\n var $workspace = $('.workspace');\n\n $sidemenu.toggleClass('active');\n $('.nav-dropdown').toggleClass('fa-caret-down fa-caret-up');\n\n if ($sidemenu.hasClass('active')) {\n $sidemenu.css('right', 100 - sidemenu_percent + '%');\n $workspace.css('left', sidemenu_percent + '%');\n } else {\n sidemenu_percent = $workspace.position().left / $('body').width() * 100;\n $sidemenu.css('right', 0);\n $workspace.css('left', 0);\n }\n\n app.getTracerManager().resize();\n });\n\n $('#documentation').click(function () {\n $('#btn_doc').click();\n });\n\n $('#powered-by').click(function () {\n $('#powered-by-list button').toggleClass('collapse');\n });\n\n $('#scratch-paper').click(function () {\n var category = 'scratch';\n var algorithm = app.getLoadedScratch();\n Server.loadAlgorithm(category, algorithm).then(function (data) {\n showAlgorithm(category, algorithm, data);\n });\n });\n};\n\n},{\"../../app\":3,\"../../server\":56,\"../show_algorithm\":19}],16:[function(require,module,exports){\n'use strict';\n\nmodule.exports = function () {\n $('.tab_bar > button').click(function () {\n $('.tab_bar > button').removeClass('active');\n $('.tab_container > .tab').removeClass('active');\n $(this).addClass('active');\n $($(this).attr('data-target')).addClass('active');\n });\n};\n\n},{}],17:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\nvar Server = require('../../server');\nvar Toast = require('../toast');\nvar TopMenu = require('../top_menu');\n\nmodule.exports = function () {\n\n // shared\n $('#shared').mouseup(function () {\n $(this).select();\n });\n\n $('#btn_share').click(function () {\n\n var $icon = $(this).find('.fa-share');\n $icon.addClass('fa-spin fa-spin-faster');\n\n Server.shareScratchPaper().then(function (url) {\n $icon.removeClass('fa-spin fa-spin-faster');\n $('#shared').removeClass('collapse');\n $('#shared').val(url);\n Toast.showInfoToast('Shareable link is created.');\n });\n });\n\n // control\n\n var $btnRun = $('#btn_run');\n var $btnTrace = $('#btn_trace');\n var $btnPause = $('#btn_pause');\n var $btnPrev = $('#btn_prev');\n var $btnNext = $('#btn_next');\n\n // initially, control buttons are disabled\n TopMenu.disableFlowControl();\n\n $btnRun.click(function () {\n $btnTrace.click();\n $btnPause.removeClass('active');\n $btnRun.addClass('active');\n TopMenu.enableFlowControl();\n var err = app.getEditor().execute();\n if (err) {\n console.error(err);\n Toast.showErrorToast(err);\n TopMenu.resetTopMenuButtons();\n }\n });\n\n $btnPause.click(function () {\n $btnRun.toggleClass('active');\n $btnPause.toggleClass('active');\n if (app.getTracerManager().isPause()) {\n app.getTracerManager().resumeStep();\n } else {\n app.getTracerManager().pauseStep();\n }\n });\n\n $btnPrev.click(function () {\n $btnRun.removeClass('active');\n $btnPause.addClass('active');\n app.getTracerManager().pauseStep();\n app.getTracerManager().prevStep();\n });\n\n $btnNext.click(function () {\n $btnRun.removeClass('active');\n $btnPause.addClass('active');\n app.getTracerManager().pauseStep();\n app.getTracerManager().nextStep();\n });\n};\n\n},{\"../../app\":3,\"../../server\":56,\"../toast\":24,\"../top_menu\":25}],18:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n $(window).resize(function () {\n app.getTracerManager().resize();\n });\n};\n\n},{\"../../app\":3}],19:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\n\nvar _require = require('../utils');\n\nvar isScratchPaper = _require.isScratchPaper;\n\n\nvar showDescription = require('./show_description');\nvar addFiles = require('./add_files');\n\nmodule.exports = function (category, algorithm, data, requestedFile) {\n var $menu = void 0;\n var category_name = void 0;\n var algorithm_name = void 0;\n\n if (isScratchPaper(category)) {\n $menu = $('#scratch-paper');\n category_name = 'Scratch Paper';\n algorithm_name = algorithm ? 'Shared' : 'Temporary';\n } else {\n $menu = $('[data-category=\"' + category + '\"][data-algorithm=\"' + algorithm + '\"]');\n var categoryObj = app.getCategory(category);\n category_name = categoryObj.name;\n algorithm_name = categoryObj.list[algorithm];\n }\n\n $('.sidemenu button').removeClass('active');\n $menu.addClass('active');\n\n $('#category').html(category_name);\n $('#algorithm').html(algorithm_name);\n $('#tab_desc > .wrapper').empty();\n $('.files_bar > .wrapper').empty();\n $('#explanation').html('');\n\n app.setLastFileUsed(null);\n app.getEditor().clearContent();\n\n var files = data.files;\n\n\n delete data.files;\n\n showDescription(data);\n addFiles(category, algorithm, files, requestedFile);\n};\n\n},{\"../app\":3,\"../utils\":70,\"./add_files\":5,\"./show_description\":20}],20:[function(require,module,exports){\n'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol ? \"symbol\" : typeof obj; };\n\nvar isArray = Array.isArray;\nvar _$ = $;\nvar each = _$.each;\n\n\nmodule.exports = function (data) {\n var $container = $('#tab_desc > .wrapper');\n $container.empty();\n\n each(data, function (key, value) {\n\n if (key) {\n $container.append($('<h3>').html(key));\n }\n\n if (typeof value === 'string') {\n $container.append($('<p>').html(value));\n } else if (isArray(value)) {\n (function () {\n\n var $ul = $('<ul class=\"applications\">');\n $container.append($ul);\n\n value.forEach(function (li) {\n $ul.append($('<li>').html(li));\n });\n })();\n } else if ((typeof value === 'undefined' ? 'undefined' : _typeof(value)) === 'object') {\n (function () {\n\n var $ul = $('<ul class=\"complexities\">');\n $container.append($ul);\n\n each(value, function (prop) {\n var $wrapper = $('<div class=\"complexity\">');\n var $type = $('<span class=\"complexity-type\">').html(prop + ': ');\n var $value = $('<span class=\"complexity-value\">').html('' + value[prop]);\n\n $wrapper.append($type).append($value);\n\n $ul.append($('<li>').append($wrapper));\n });\n })();\n }\n });\n};\n\n},{}],21:[function(require,module,exports){\n'use strict';\n\n// click the first algorithm in the first category\n\nmodule.exports = function () {\n $('#list .category').first().click();\n $('#list .category + .algorithms > .indent').first().click();\n};\n\n},{}],22:[function(require,module,exports){\n'use strict';\n\nvar Server = require('../server');\nvar showAlgorithm = require('./show_algorithm');\n\nmodule.exports = function (category, algorithm, file) {\n $('.category[data-category=\"' + category + '\"]').click();\n Server.loadAlgorithm(category, algorithm).then(function (data) {\n showAlgorithm(category, algorithm, data, file);\n });\n};\n\n},{\"../server\":56,\"./show_algorithm\":19}],23:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar Server = require('../server');\nvar converter = new showdown.Converter({ tables: true });\n\nmodule.exports = function (wiki) {\n Server.loadWiki(wiki).then(function (data) {\n $('#tab_doc > .wrapper').html(converter.makeHtml('#' + wiki + '\\n' + data));\n $('#tab_doc').scrollTop(0);\n $('#tab_doc > .wrapper a').click(function (e) {\n var href = $(this).attr('href');\n if (app.hasWiki(href)) {\n e.preventDefault();\n module.exports(href);\n }\n });\n });\n};\n\n},{\"../app\":3,\"../server\":56}],24:[function(require,module,exports){\n'use strict';\n\nvar showToast = function showToast(data, type) {\n var $toast = $('<div class=\"toast ' + type + '\">').append(data);\n\n $('.toast_container').append($toast);\n setTimeout(function () {\n $toast.fadeOut(function () {\n $toast.remove();\n });\n }, 3000);\n};\n\nvar showErrorToast = function showErrorToast(err) {\n showToast(err, 'error');\n};\n\nvar showInfoToast = function showInfoToast(err) {\n showToast(err, 'info');\n};\n\nmodule.exports = {\n showErrorToast: showErrorToast,\n showInfoToast: showInfoToast\n};\n\n},{}],25:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\n\nvar flowControlBtns = [$('#btn_pause'), $('#btn_prev'), $('#btn_next')];\nvar setFlowControlState = function setFlowControlState(isDisabled) {\n flowControlBtns.forEach(function ($btn) {\n return $btn.attr('disabled', isDisabled);\n });\n};\n\nvar enableFlowControl = function enableFlowControl() {\n setFlowControlState(false);\n};\n\nvar disableFlowControl = function disableFlowControl() {\n setFlowControlState(true);\n};\n\nvar resetTopMenuButtons = function resetTopMenuButtons() {\n $('.top-menu-buttons button').removeClass('active');\n disableFlowControl();\n app.getEditor().unhighlightLine();\n};\n\nvar setInterval = function setInterval(val) {\n $('#interval').val(interval);\n};\n\nvar activateBtnPause = function activateBtnPause() {\n $('#btn_pause').addClass('active');\n};\n\nvar deactivateBtnPause = function deactivateBtnPause() {\n $('#btn_pause').removeClass('active');\n};\n\nmodule.exports = {\n enableFlowControl: enableFlowControl,\n disableFlowControl: disableFlowControl,\n resetTopMenuButtons: resetTopMenuButtons,\n setInterval: setInterval,\n activateBtnPause: activateBtnPause,\n deactivateBtnPause: deactivateBtnPause\n};\n\n},{\"../app\":3}],26:[function(require,module,exports){\n'use strict';\n\nmodule.exports = function (id) {\n var editor = ace.edit(id);\n\n editor.setOptions({\n enableBasicAutocompletion: true,\n enableSnippets: true,\n enableLiveAutocompletion: true\n });\n\n editor.setTheme('ace/theme/tomorrow_night_eighties');\n editor.session.setMode('ace/mode/javascript');\n editor.$blockScrolling = Infinity;\n\n return editor;\n};\n\n},{}],27:[function(require,module,exports){\n'use strict';\n\nvar execute = function execute(tracerManager, code, dataLines) {\n // all modules available to eval are obtained from window\n try {\n (function () {\n tracerManager.deallocateAll();\n var lines = code.split('\\n');\n var newLines = [];\n lines.forEach(function (line, i) {\n newLines.push(line.replace(/(.+\\. *_wait *)(\\( *\\))/g, '$1(' + (i - dataLines) + ')'));\n });\n eval(newLines.join('\\n'));\n tracerManager.visualize();\n })();\n } catch (err) {\n return err;\n } finally {\n tracerManager.removeUnallocated();\n }\n};\n\nvar executeData = function executeData(tracerManager, algoData) {\n return execute(tracerManager, algoData);\n};\n\nvar executeDataAndCode = function executeDataAndCode(tracerManager, algoData, algoCode) {\n var dataLines = algoData.split('\\n').length;\n return execute(tracerManager, algoData + '\\n' + algoCode, dataLines);\n};\n\nmodule.exports = {\n executeData: executeData,\n executeDataAndCode: executeDataAndCode\n};\n\n},{}],28:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar createEditor = require('./create');\nvar Executor = require('./executor');\nvar TopMenu = require('../dom/top_menu');\n\nfunction Editor(tracerManager) {\n var _this = this;\n\n if (!tracerManager) {\n throw 'Cannot create Editor. Missing the tracerManager';\n }\n\n ace.require('ace/ext/language_tools');\n var Range = ace.require(\"ace/range\").Range;\n\n this.dataEditor = createEditor('data');\n this.codeEditor = createEditor('code');\n\n // Setting data\n\n this.setData = function (data) {\n _this.dataEditor.setValue(data, -1);\n };\n\n this.setCode = function (code) {\n _this.codeEditor.setValue(code, -1);\n };\n\n this.setContent = function (_ref) {\n var data = _ref.data;\n var code = _ref.code;\n\n _this.setData(data);\n _this.setCode(code);\n };\n\n // Clearing data\n\n this.clearData = function () {\n _this.dataEditor.setValue('');\n };\n\n this.clearCode = function () {\n _this.codeEditor.setValue('');\n };\n\n this.clearContent = function () {\n _this.clearData();\n _this.clearCode();\n };\n\n this.execute = function () {\n var data = _this.dataEditor.getValue();\n var code = _this.codeEditor.getValue();\n return Executor.executeDataAndCode(tracerManager, data, code);\n };\n\n this.highlightLine = function (lineNumber) {\n var session = _this.codeEditor.getSession();\n if (_this.marker) session.removeMarker(_this.marker);\n _this.marker = session.addMarker(new Range(lineNumber, 0, lineNumber, Infinity), \"executing\", \"line\", true);\n };\n\n this.unhighlightLine = function () {\n var session = _this.codeEditor.getSession();\n if (_this.marker) session.removeMarker(_this.marker);\n };\n\n // listeners\n\n this.dataEditor.on('change', function () {\n var data = _this.dataEditor.getValue();\n var lastFileUsed = app.getLastFileUsed();\n if (lastFileUsed) {\n app.updateCachedFile(lastFileUsed, {\n data: data\n });\n }\n Executor.executeData(tracerManager, data);\n TopMenu.resetTopMenuButtons();\n });\n\n this.codeEditor.on('change', function () {\n var code = _this.codeEditor.getValue();\n var lastFileUsed = app.getLastFileUsed();\n if (lastFileUsed) {\n app.updateCachedFile(lastFileUsed, {\n code: code\n });\n }\n tracerManager.reset();\n TopMenu.resetTopMenuButtons();\n });\n}\n\nmodule.exports = Editor;\n\n},{\"../app\":3,\"../dom/top_menu\":25,\"./create\":26,\"./executor\":27}],29:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('./app');\nvar AppConstructor = require('./app/constructor');\nvar DOM = require('./dom');\nvar Server = require('./server');\n\nvar modules = require('./module');\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\n$.ajaxSetup({\n cache: false,\n dataType: 'text'\n});\n\nvar _require = require('./utils');\n\nvar isScratchPaper = _require.isScratchPaper;\n\nvar _require2 = require('./server/helpers');\n\nvar getPath = _require2.getPath;\n\n// set global promise error handler\n\nRSVP.on('error', function (reason) {\n console.assert(false, reason);\n});\n\n$(function () {\n\n // initialize the application and attach in to the instance module\n var appConstructor = new AppConstructor();\n extend(true, app, appConstructor);\n\n // load modules to the global scope so they can be evaled\n extend(true, window, modules);\n\n Server.loadCategories().then(function (data) {\n app.setCategories(data);\n DOM.addCategories();\n\n // determine if the app is loading a pre-existing scratch-pad\n // or the home page\n\n var _getPath = getPath();\n\n var category = _getPath.category;\n var algorithm = _getPath.algorithm;\n var file = _getPath.file;\n\n if (isScratchPaper(category)) {\n if (algorithm) {\n Server.loadScratchPaper(algorithm).then(function (_ref) {\n var category = _ref.category;\n var algorithm = _ref.algorithm;\n var data = _ref.data;\n\n DOM.showAlgorithm(category, algorithm, data);\n });\n } else {\n Server.loadAlgorithm(category).then(function (data) {\n DOM.showAlgorithm(category, null, data);\n });\n }\n } else if (category && algorithm) {\n DOM.showRequestedAlgorithm(category, algorithm, file);\n } else {\n DOM.showFirstAlgorithm();\n }\n });\n\n Server.loadWikiList().then(function (data) {\n app.setWikiList(data.wikis);\n\n DOM.showWiki('Tracer');\n });\n});\n\n},{\"./app\":3,\"./app/constructor\":2,\"./dom\":6,\"./module\":39,\"./server\":56,\"./server/helpers\":55,\"./utils\":70,\"rsvp\":72}],30:[function(require,module,exports){\n'use strict';\n\nvar Array2D = require('./array2d');\n\nvar random = function random(N, min, max) {\n return Array2D.random(1, N, min, max)[0];\n};\n\nvar randomSorted = function randomSorted(N, min, max) {\n return Array2D.randomSorted(1, N, min, max)[0];\n};\n\nmodule.exports = {\n random: random,\n randomSorted: randomSorted\n};\n\n},{\"./array2d\":31}],31:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, M, min, max) {\n if (!N) N = 10;\n if (!M) M = 10;\n if (min === undefined) min = 1;\n if (max === undefined) max = 9;\n var D = [];\n for (var i = 0; i < N; i++) {\n D.push([]);\n for (var j = 0; j < M; j++) {\n D[i].push(Integer.random(min, max));\n }\n }\n return D;\n};\n\nvar randomSorted = function randomSorted(N, M, min, max) {\n return random(N, M, min, max).map(function (arr) {\n return arr.sort(function (a, b) {\n return a - b;\n });\n });\n};\n\nmodule.exports = {\n random: random,\n randomSorted: randomSorted\n};\n\n},{\"./integer\":35}],32:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, min, max) {\n if (!N) N = 7;\n if (!min) min = 1;\n if (!max) max = 10;\n var C = new Array(N);\n for (var i = 0; i < N; i++) {\n C[i] = new Array(2);\n }for (var i = 0; i < N; i++) {\n for (var j = 0; j < C[i].length; j++) {\n C[i][j] = Integer.random(min, max);\n }\n }return C;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{\"./integer\":35}],33:[function(require,module,exports){\n'use strict';\n\nvar random = function random(N, ratio) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n for (var j = 0; j < N; j++) {\n if (i != j) {\n G[i][j] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],34:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\nvar Array1D = require('./array1d');\nvar Array2D = require('./array2d');\nvar CoordinateSystem = require('./coordinate_system');\nvar DirectedGraph = require('./directed_graph');\nvar UndirectedGraph = require('./undirected_graph');\nvar WeightedDirectedGraph = require('./weighted_directed_graph');\nvar WeightedUndirectedGraph = require('./weighted_undirected_graph');\n\nmodule.exports = {\n Integer: Integer,\n Array1D: Array1D,\n Array2D: Array2D,\n CoordinateSystem: CoordinateSystem,\n DirectedGraph: DirectedGraph,\n UndirectedGraph: UndirectedGraph,\n WeightedDirectedGraph: WeightedDirectedGraph,\n WeightedUndirectedGraph: WeightedUndirectedGraph\n};\n\n},{\"./array1d\":30,\"./array2d\":31,\"./coordinate_system\":32,\"./directed_graph\":33,\"./integer\":35,\"./undirected_graph\":36,\"./weighted_directed_graph\":37,\"./weighted_undirected_graph\":38}],35:[function(require,module,exports){\n'use strict';\n\nvar random = function random(min, max) {\n return (Math.random() * (max - min + 1) | 0) + min;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],36:[function(require,module,exports){\n'use strict';\n\nvar random = function random(N, ratio) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n }for (var i = 0; i < N; i++) {\n for (var j = 0; j < N; j++) {\n if (i > j) {\n G[i][j] = G[j][i] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],37:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, ratio, min, max) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n if (!min) min = 1;\n if (!max) max = 5;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n for (var j = 0; j < N; j++) {\n if (i != j && (Math.random() * (1 / ratio) | 0) == 0) {\n G[i][j] = Integer.random(min, max);\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{\"./integer\":35}],38:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, ratio, min, max) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n if (!min) min = 1;\n if (!max) max = 5;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n }for (var i = 0; i < N; i++) {\n for (var j = 0; j < N; j++) {\n if (i > j && (Math.random() * (1 / ratio) | 0) == 0) {\n G[i][j] = G[j][i] = Integer.random(min, max);\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{\"./integer\":35}],39:[function(require,module,exports){\n'use strict';\n\nvar tracers = require('./tracer');\nvar datas = require('./data');\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\nmodule.exports = extend(true, {}, tracers, datas);\n\n},{\"./data\":34,\"./tracer\":45}],40:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Array2DTracer = require('./array2d');\n\nvar Array1DTracer = function (_Array2DTracer) {\n _inherits(Array1DTracer, _Array2DTracer);\n\n _createClass(Array1DTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'Array1DTracer';\n }\n }]);\n\n function Array1DTracer(name) {\n _classCallCheck(this, Array1DTracer);\n\n return _possibleConstructorReturn(this, Object.getPrototypeOf(Array1DTracer).call(this, name));\n }\n\n _createClass(Array1DTracer, [{\n key: '_notify',\n value: function _notify(idx, v) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_notify', this).call(this, 0, idx, v);\n return this;\n }\n }, {\n key: '_denotify',\n value: function _denotify(idx) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_denotify', this).call(this, 0, idx);\n return this;\n }\n }, {\n key: '_select',\n value: function _select(s, e) {\n if (e === undefined) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_select', this).call(this, 0, s);\n } else {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_selectRow', this).call(this, 0, s, e);\n }\n return this;\n }\n }, {\n key: '_deselect',\n value: function _deselect(s, e) {\n if (e === undefined) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_deselect', this).call(this, 0, s);\n } else {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_deselectRow', this).call(this, 0, s, e);\n }\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), 'processStep', this).call(this, step, options);\n if (this.chartTracer) {\n var newStep = $.extend(true, {}, step);\n newStep.capsule = this.chartTracer.capsule;\n newStep.s = newStep.sy;\n newStep.e = newStep.ey;\n if (newStep.s === undefined) newStep.s = newStep.y;\n delete newStep.x;\n delete newStep.y;\n delete newStep.sx;\n delete newStep.sy;\n delete newStep.ex;\n delete newStep.ey;\n this.chartTracer.processStep(newStep, options);\n }\n }\n }, {\n key: 'setData',\n value: function setData(D) {\n return _get(Object.getPrototypeOf(Array1DTracer.prototype), 'setData', this).call(this, [D]);\n }\n }]);\n\n return Array1DTracer;\n}(Array2DTracer);\n\nmodule.exports = Array1DTracer;\n\n},{\"./array2d\":41}],41:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar refineByType = _require.refineByType;\n\nvar Array2DTracer = function (_Tracer) {\n _inherits(Array2DTracer, _Tracer);\n\n _createClass(Array2DTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'Array2DTracer';\n }\n }]);\n\n function Array2DTracer(name) {\n _classCallCheck(this, Array2DTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(Array2DTracer).call(this, name));\n\n _this.colorClass = {\n selected: 'selected',\n notified: 'notified'\n };\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(Array2DTracer, [{\n key: '_notify',\n value: function _notify(x, y, v) {\n this.manager.pushStep(this.capsule, {\n type: 'notify',\n x: x,\n y: y,\n v: v\n });\n return this;\n }\n }, {\n key: '_denotify',\n value: function _denotify(x, y) {\n this.manager.pushStep(this.capsule, {\n type: 'denotify',\n x: x,\n y: y\n });\n return this;\n }\n }, {\n key: '_select',\n value: function _select(sx, sy, ex, ey) {\n this.pushSelectingStep('select', null, arguments);\n return this;\n }\n }, {\n key: '_selectRow',\n value: function _selectRow(x, sy, ey) {\n this.pushSelectingStep('select', 'row', arguments);\n return this;\n }\n }, {\n key: '_selectCol',\n value: function _selectCol(y, sx, ex) {\n this.pushSelectingStep('select', 'col', arguments);\n return this;\n }\n }, {\n key: '_deselect',\n value: function _deselect(sx, sy, ex, ey) {\n this.pushSelectingStep('deselect', null, arguments);\n return this;\n }\n }, {\n key: '_deselectRow',\n value: function _deselectRow(x, sy, ey) {\n this.pushSelectingStep('deselect', 'row', arguments);\n return this;\n }\n }, {\n key: '_deselectCol',\n value: function _deselectCol(y, sx, ex) {\n this.pushSelectingStep('deselect', 'col', arguments);\n return this;\n }\n }, {\n key: '_separate',\n value: function _separate(x, y) {\n this.manager.pushStep(this.capsule, {\n type: 'separate',\n x: x,\n y: y\n });\n return this;\n }\n }, {\n key: '_separateRow',\n value: function _separateRow(x) {\n this._separate(x, -1);\n return this;\n }\n }, {\n key: '_separateCol',\n value: function _separateCol(y) {\n this._separate(-1, y);\n return this;\n }\n }, {\n key: '_deseparate',\n value: function _deseparate(x, y) {\n this.manager.pushStep(this.capsule, {\n type: 'deseparate',\n x: x,\n y: y\n });\n return this;\n }\n }, {\n key: '_deseparateRow',\n value: function _deseparateRow(x) {\n this._deseparate(x, -1);\n return this;\n }\n }, {\n key: '_deseparateCol',\n value: function _deseparateCol(y) {\n this._deseparate(-1, y);\n return this;\n }\n }, {\n key: 'pushSelectingStep',\n value: function pushSelectingStep() {\n var args = Array.prototype.slice.call(arguments);\n var type = args.shift();\n var mode = args.shift();\n args = Array.prototype.slice.call(args.shift());\n var coord;\n switch (mode) {\n case 'row':\n coord = {\n x: args[0],\n sy: args[1],\n ey: args[2]\n };\n break;\n case 'col':\n coord = {\n y: args[0],\n sx: args[1],\n ex: args[2]\n };\n break;\n default:\n if (args[2] === undefined && args[3] === undefined) {\n coord = {\n x: args[0],\n y: args[1]\n };\n } else {\n coord = {\n sx: args[0],\n sy: args[1],\n ex: args[2],\n ey: args[3]\n };\n }\n }\n var step = {\n type: type\n };\n $.extend(step, coord);\n this.manager.pushStep(this.capsule, step);\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'notify':\n if (step.v !== undefined) {\n var $row = this.$table.find('.mtbl-row').eq(step.x);\n var $col = $row.find('.mtbl-col').eq(step.y);\n $col.text(refineByType(step.v));\n }\n case 'denotify':\n case 'select':\n case 'deselect':\n var colorClass = step.type == 'select' || step.type == 'deselect' ? this.colorClass.selected : this.colorClass.notified;\n var addClass = step.type == 'select' || step.type == 'notify';\n var sx = step.sx;\n var sy = step.sy;\n var ex = step.ex;\n var ey = step.ey;\n if (sx === undefined) sx = step.x;\n if (sy === undefined) sy = step.y;\n if (ex === undefined) ex = step.x;\n if (ey === undefined) ey = step.y;\n this.paintColor(sx, sy, ex, ey, colorClass, addClass);\n break;\n case 'separate':\n this.deseparate(step.x, step.y);\n this.separate(step.x, step.y);\n break;\n case 'deseparate':\n this.deseparate(step.x, step.y);\n break;\n default:\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'setData',\n value: function setData(D) {\n this.viewX = this.viewY = 0;\n this.paddingH = 6;\n this.paddingV = 3;\n this.fontSize = 16;\n\n if (_get(Object.getPrototypeOf(Array2DTracer.prototype), 'setData', this).apply(this, arguments)) {\n this.$table.find('.mtbl-row').each(function (i) {\n $(this).find('.mtbl-col').each(function (j) {\n $(this).text(refineByType(D[i][j]));\n });\n });\n return true;\n }\n\n this.$table.empty();\n for (var i = 0; i < D.length; i++) {\n var $row = $('<div class=\"mtbl-row\">');\n this.$table.append($row);\n for (var j = 0; j < D[i].length; j++) {\n var $col = $('<div class=\"mtbl-col\">').css(this.getCellCss()).text(refineByType(D[i][j]));\n $row.append($col);\n }\n }\n this.resize();\n\n return false;\n }\n }, {\n key: 'resize',\n value: function resize() {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'resize', this).call(this);\n\n this.refresh();\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'clear', this).call(this);\n\n this.clearColor();\n this.deseparateAll();\n }\n }, {\n key: 'getCellCss',\n value: function getCellCss() {\n return {\n padding: this.paddingV.toFixed(1) + 'px ' + this.paddingH.toFixed(1) + 'px',\n 'font-size': this.fontSize.toFixed(1) + 'px'\n };\n }\n }, {\n key: 'refresh',\n value: function refresh() {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'refresh', this).call(this);\n\n var $parent = this.$table.parent();\n var top = $parent.height() / 2 - this.$table.height() / 2 + this.viewY;\n var left = $parent.width() / 2 - this.$table.width() / 2 + this.viewX;\n this.$table.css('margin-top', top);\n this.$table.css('margin-left', left);\n }\n }, {\n key: 'mousedown',\n value: function mousedown(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mousedown', this).call(this, e);\n\n this.dragX = e.pageX;\n this.dragY = e.pageY;\n this.dragging = true;\n }\n }, {\n key: 'mousemove',\n value: function mousemove(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mousemove', this).call(this, e);\n\n if (this.dragging) {\n this.viewX += e.pageX - this.dragX;\n this.viewY += e.pageY - this.dragY;\n this.dragX = e.pageX;\n this.dragY = e.pageY;\n this.refresh();\n }\n }\n }, {\n key: 'mouseup',\n value: function mouseup(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mouseup', this).call(this, e);\n\n this.dragging = false;\n }\n }, {\n key: 'mousewheel',\n value: function mousewheel(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mousewheel', this).call(this, e);\n\n e.preventDefault();\n e = e.originalEvent;\n var delta = e.wheelDelta !== undefined && e.wheelDelta || e.detail !== undefined && -e.detail;\n var weight = 1.01;\n var ratio = delta > 0 ? 1 / weight : weight;\n if (this.fontSize < 4 && ratio < 1) return;\n if (this.fontSize > 40 && ratio > 1) return;\n this.paddingV *= ratio;\n this.paddingH *= ratio;\n this.fontSize *= ratio;\n this.$table.find('.mtbl-col').css(this.getCellCss());\n this.refresh();\n }\n }, {\n key: 'paintColor',\n value: function paintColor(sx, sy, ex, ey, colorClass, addClass) {\n for (var i = sx; i <= ex; i++) {\n var $row = this.$table.find('.mtbl-row').eq(i);\n for (var j = sy; j <= ey; j++) {\n var $col = $row.find('.mtbl-col').eq(j);\n if (addClass) $col.addClass(colorClass);else $col.removeClass(colorClass);\n }\n }\n }\n }, {\n key: 'clearColor',\n value: function clearColor() {\n this.$table.find('.mtbl-col').removeClass(Object.keys(this.colorClass).join(' '));\n }\n }, {\n key: 'separate',\n value: function separate(x, y) {\n this.$table.find('.mtbl-row').each(function (i) {\n var $row = $(this);\n if (i == x) {\n $row.after($('<div class=\"mtbl-empty-row\">').attr('data-row', i));\n }\n $row.find('.mtbl-col').each(function (j) {\n var $col = $(this);\n if (j == y) {\n $col.after($('<div class=\"mtbl-empty-col\">').attr('data-col', j));\n }\n });\n });\n }\n }, {\n key: 'deseparate',\n value: function deseparate(x, y) {\n this.$table.find('[data-row=' + x + ']').remove();\n this.$table.find('[data-col=' + y + ']').remove();\n }\n }, {\n key: 'deseparateAll',\n value: function deseparateAll() {\n this.$table.find('.mtbl-empty-row, .mtbl-empty-col').remove();\n }\n }]);\n\n return Array2DTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.$table = tracer.capsule.$table = $('<div class=\"mtbl-table\">');\n tracer.$container.append(tracer.$table);\n};\n\nmodule.exports = Array2DTracer;\n\n},{\"../../tracer_manager/util/index\":67,\"./tracer\":47}],42:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar ChartTracer = function (_Tracer) {\n _inherits(ChartTracer, _Tracer);\n\n _createClass(ChartTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'ChartTracer';\n }\n }]);\n\n function ChartTracer(name) {\n _classCallCheck(this, ChartTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(ChartTracer).call(this, name));\n\n _this.color = {\n selected: 'rgb(0, 0, 255)',\n notified: 'rgb(255, 0, 0)',\n default: 'rgb(136, 136, 136)'\n };\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(ChartTracer, [{\n key: 'setData',\n value: function setData(C) {\n if (_get(Object.getPrototypeOf(ChartTracer.prototype), 'setData', this).apply(this, arguments)) {\n this.chart.config.data.datasets[0].data = C;\n this.chart.update();\n return true;\n }\n\n var color = [];\n for (var i = 0; i < C.length; i++) {\n color.push(this.color.default);\n }this.chart.config.data = {\n labels: C.map(String),\n datasets: [{\n backgroundColor: color,\n data: C\n }]\n };\n this.chart.update();\n }\n }, {\n key: '_notify',\n value: function _notify(s, v) {\n this.manager.pushStep(this.capsule, {\n type: 'notify',\n s: s,\n v: v\n });\n return this;\n }\n }, {\n key: '_denotify',\n value: function _denotify(s) {\n this.manager.pushStep(this.capsule, {\n type: 'denotify',\n s: s\n });\n return this;\n }\n }, {\n key: '_select',\n value: function _select(s, e) {\n this.manager.pushStep(this.capsule, {\n type: 'select',\n s: s,\n e: e\n });\n return this;\n }\n }, {\n key: '_deselect',\n value: function _deselect(s, e) {\n this.manager.pushStep(this.capsule, {\n type: 'deselect',\n s: s,\n e: e\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'notify':\n if (step.v !== undefined) {\n this.chart.config.data.datasets[0].data[step.s] = step.v;\n this.chart.config.data.labels[step.s] = step.v.toString();\n }\n case 'denotify':\n case 'select':\n case 'deselect':\n var color = step.type == 'notify' ? this.color.notified : step.type == 'select' ? this.color.selected : this.color.default;\n if (step.e !== undefined) for (var i = step.s; i <= step.e; i++) {\n this.chart.config.data.datasets[0].backgroundColor[i] = color;\n } else this.chart.config.data.datasets[0].backgroundColor[step.s] = color;\n this.chart.update();\n break;\n default:\n _get(Object.getPrototypeOf(ChartTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'resize',\n value: function resize() {\n _get(Object.getPrototypeOf(ChartTracer.prototype), 'resize', this).call(this);\n\n this.chart.resize();\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(ChartTracer.prototype), 'clear', this).call(this);\n\n var data = this.chart.config.data;\n if (data.datasets.length) {\n var backgroundColor = data.datasets[0].backgroundColor;\n for (var i = 0; i < backgroundColor.length; i++) {\n backgroundColor[i] = this.color.default;\n }\n this.chart.update();\n }\n }\n }]);\n\n return ChartTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.$wrapper = tracer.capsule.$wrapper = $('<canvas class=\"mchrt-chart\">');\n tracer.$container.append(tracer.$wrapper);\n tracer.chart = tracer.capsule.chart = new Chart(tracer.$wrapper, {\n type: 'bar',\n data: {\n labels: [],\n datasets: []\n },\n options: {\n scales: {\n yAxes: [{\n ticks: {\n beginAtZero: true\n }\n }]\n },\n animation: false,\n legend: false,\n responsive: true,\n maintainAspectRatio: false\n }\n });\n};\n\nmodule.exports = ChartTracer;\n\n},{\"./tracer\":47}],43:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar DirectedGraphTracer = require('./directed_graph');\n\nvar CoordinateSystemTracer = function (_DirectedGraphTracer) {\n _inherits(CoordinateSystemTracer, _DirectedGraphTracer);\n\n _createClass(CoordinateSystemTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'CoordinateSystemTracer';\n }\n }]);\n\n function CoordinateSystemTracer(name) {\n _classCallCheck(this, CoordinateSystemTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(CoordinateSystemTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(CoordinateSystemTracer, [{\n key: 'setData',\n value: function setData(C) {\n if (Tracer.prototype.setData.apply(this, arguments)) return true;\n\n this.graph.clear();\n var nodes = [];\n var edges = [];\n for (var i = 0; i < C.length; i++) {\n nodes.push({\n id: this.n(i),\n x: C[i][0],\n y: C[i][1],\n label: '' + i,\n size: 1,\n color: this.color.default\n });\n }this.graph.read({\n nodes: nodes,\n edges: edges\n });\n this.s.camera.goTo({\n x: 0,\n y: 0,\n angle: 0,\n ratio: 1\n });\n this.refresh();\n\n return false;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'visit':\n case 'leave':\n var visit = step.type == 'visit';\n var targetNode = this.graph.nodes(this.n(step.target));\n var color = visit ? this.color.visited : this.color.left;\n targetNode.color = color;\n if (step.source !== undefined) {\n var edgeId = this.e(step.source, step.target);\n if (this.graph.edges(edgeId)) {\n var edge = this.graph.edges(edgeId);\n edge.color = color;\n this.graph.dropEdge(edgeId).addEdge(edge);\n } else {\n this.graph.addEdge({\n id: this.e(step.target, step.source),\n source: this.n(step.source),\n target: this.n(step.target),\n color: color,\n size: 1\n });\n }\n }\n if (this.logTracer) {\n var source = step.source;\n if (source === undefined) source = '';\n this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n }\n break;\n default:\n _get(Object.getPrototypeOf(CoordinateSystemTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'e',\n value: function e(v1, v2) {\n if (v1 > v2) {\n var temp = v1;\n v1 = v2;\n v2 = temp;\n }\n return 'e' + v1 + '_' + v2;\n }\n }, {\n key: 'drawOnHover',\n value: function drawOnHover(node, context, settings, next) {\n var tracer = this;\n\n context.setLineDash([5, 5]);\n var nodeIdx = node.id.substring(1);\n this.graph.edges().forEach(function (edge) {\n var ends = edge.id.substring(1).split(\"_\");\n if (ends[0] == nodeIdx) {\n var color = '#0ff';\n var source = node;\n var target = tracer.graph.nodes('n' + ends[1]);\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n } else if (ends[1] == nodeIdx) {\n var color = '#0ff';\n var source = tracer.graph.nodes('n' + ends[0]);\n var target = node;\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n }\n });\n }\n }, {\n key: 'drawEdge',\n value: function drawEdge(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1;\n\n context.strokeStyle = color;\n context.lineWidth = size;\n context.beginPath();\n context.moveTo(source[prefix + 'x'], source[prefix + 'y']);\n context.lineTo(target[prefix + 'x'], target[prefix + 'y']);\n context.stroke();\n }\n }]);\n\n return CoordinateSystemTracer;\n}(DirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n defaultEdgeType: 'def',\n funcEdgesDef: function funcEdgesDef(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawEdge(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = CoordinateSystemTracer;\n\n},{\"./directed_graph\":44}],44:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar refineByType = _require.refineByType;\n\nvar DirectedGraphTracer = function (_Tracer) {\n _inherits(DirectedGraphTracer, _Tracer);\n\n _createClass(DirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'DirectedGraphTracer';\n }\n }]);\n\n function DirectedGraphTracer(name) {\n _classCallCheck(this, DirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(DirectedGraphTracer).call(this, name));\n\n _this.color = {\n selected: '#0f0',\n visited: '#f00',\n left: '#000',\n default: '#888'\n };\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(DirectedGraphTracer, [{\n key: '_setTreeData',\n value: function _setTreeData(G, root) {\n this.manager.pushStep(this.capsule, {\n type: 'setTreeData',\n arguments: arguments\n });\n return this;\n }\n }, {\n key: '_visit',\n value: function _visit(target, source) {\n this.manager.pushStep(this.capsule, {\n type: 'visit',\n target: target,\n source: source\n });\n return this;\n }\n }, {\n key: '_leave',\n value: function _leave(target, source) {\n this.manager.pushStep(this.capsule, {\n type: 'leave',\n target: target,\n source: source\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'setTreeData':\n this.setTreeData.apply(this, step.arguments);\n break;\n case 'visit':\n case 'leave':\n var visit = step.type == 'visit';\n var targetNode = this.graph.nodes(this.n(step.target));\n var color = visit ? this.color.visited : this.color.left;\n targetNode.color = color;\n if (step.source !== undefined) {\n var edgeId = this.e(step.source, step.target);\n var edge = this.graph.edges(edgeId);\n edge.color = color;\n this.graph.dropEdge(edgeId).addEdge(edge);\n }\n if (this.logTracer) {\n var source = step.source;\n if (source === undefined) source = '';\n this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n }\n break;\n default:\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'setTreeData',\n value: function setTreeData(G, root, undirected) {\n var tracer = this;\n\n root = root || 0;\n var maxDepth = -1;\n\n var chk = new Array(G.length);\n var getDepth = function getDepth(node, depth) {\n if (chk[node]) throw \"the given graph is not a tree because it forms a circuit\";\n chk[node] = true;\n if (maxDepth < depth) maxDepth = depth;\n for (var i = 0; i < G[node].length; i++) {\n if (G[node][i]) getDepth(i, depth + 1);\n }\n };\n getDepth(root, 1);\n\n if (this.setData(G, undirected)) return true;\n\n var place = function place(node, x, y) {\n var temp = tracer.graph.nodes(tracer.n(node));\n temp.x = x;\n temp.y = y;\n };\n\n var wgap = 1 / (maxDepth - 1);\n var dfs = function dfs(node, depth, top, bottom) {\n place(node, top + bottom, depth * wgap);\n var children = 0;\n for (var i = 0; i < G[node].length; i++) {\n if (G[node][i]) children++;\n }\n var vgap = (bottom - top) / children;\n var cnt = 0;\n for (var i = 0; i < G[node].length; i++) {\n if (G[node][i]) dfs(i, depth + 1, top + vgap * cnt, top + vgap * ++cnt);\n }\n };\n dfs(root, 0, 0, 1);\n\n this.refresh();\n }\n }, {\n key: 'setData',\n value: function setData(G, undirected) {\n if (_get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'setData', this).apply(this, arguments)) return true;\n\n this.graph.clear();\n var nodes = [];\n var edges = [];\n var unitAngle = 2 * Math.PI / G.length;\n var currentAngle = 0;\n for (var i = 0; i < G.length; i++) {\n currentAngle += unitAngle;\n nodes.push({\n id: this.n(i),\n label: '' + i,\n x: .5 + Math.sin(currentAngle) / 2,\n y: .5 + Math.cos(currentAngle) / 2,\n size: 1,\n color: this.color.default,\n weight: 0\n });\n\n if (undirected) {\n for (var j = 0; j <= i; j++) {\n var value = G[i][j] || G[j][i];\n if (value) {\n edges.push({\n id: this.e(i, j),\n source: this.n(i),\n target: this.n(j),\n color: this.color.default,\n size: 1,\n weight: refineByType(value)\n });\n }\n }\n } else {\n for (var _j = 0; _j < G[i].length; _j++) {\n if (G[i][_j]) {\n edges.push({\n id: this.e(i, _j),\n source: this.n(i),\n target: this.n(_j),\n color: this.color.default,\n size: 1,\n weight: refineByType(G[i][_j])\n });\n }\n }\n }\n }\n\n this.graph.read({\n nodes: nodes,\n edges: edges\n });\n this.s.camera.goTo({\n x: 0,\n y: 0,\n angle: 0,\n ratio: 1\n });\n this.refresh();\n\n return false;\n }\n }, {\n key: 'resize',\n value: function resize() {\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'resize', this).call(this);\n\n this.s.renderers[0].resize();\n this.refresh();\n }\n }, {\n key: 'refresh',\n value: function refresh() {\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'refresh', this).call(this);\n\n this.s.refresh();\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'clear', this).call(this);\n\n this.clearGraphColor();\n this.refresh();\n }\n }, {\n key: 'clearGraphColor',\n value: function clearGraphColor() {\n var tracer = this;\n\n this.graph.nodes().forEach(function (node) {\n node.color = tracer.color.default;\n });\n this.graph.edges().forEach(function (edge) {\n edge.color = tracer.color.default;\n });\n }\n }, {\n key: 'n',\n value: function n(v) {\n return 'n' + v;\n }\n }, {\n key: 'e',\n value: function e(v1, v2) {\n return 'e' + v1 + '_' + v2;\n }\n }, {\n key: 'getColor',\n value: function getColor(edge, source, target, settings) {\n var color = edge.color,\n edgeColor = settings('edgeColor'),\n defaultNodeColor = settings('defaultNodeColor'),\n defaultEdgeColor = settings('defaultEdgeColor');\n if (!color) switch (edgeColor) {\n case 'source':\n color = source.color || defaultNodeColor;\n break;\n case 'target':\n color = target.color || defaultNodeColor;\n break;\n default:\n color = defaultEdgeColor;\n break;\n }\n\n return color;\n }\n }, {\n key: 'drawLabel',\n value: function drawLabel(node, context, settings) {\n var fontSize,\n prefix = settings('prefix') || '',\n size = node[prefix + 'size'];\n\n if (size < settings('labelThreshold')) return;\n\n if (!node.label || typeof node.label !== 'string') return;\n\n fontSize = settings('labelSize') === 'fixed' ? settings('defaultLabelSize') : settings('labelSizeRatio') * size;\n\n context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') + fontSize + 'px ' + settings('font');\n context.fillStyle = settings('labelColor') === 'node' ? node.color || settings('defaultNodeColor') : settings('defaultLabelColor');\n\n context.textAlign = 'center';\n context.fillText(node.label, Math.round(node[prefix + 'x']), Math.round(node[prefix + 'y'] + fontSize / 3));\n }\n }, {\n key: 'drawArrow',\n value: function drawArrow(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1,\n tSize = target[prefix + 'size'],\n sX = source[prefix + 'x'],\n sY = source[prefix + 'y'],\n tX = target[prefix + 'x'],\n tY = target[prefix + 'y'],\n angle = Math.atan2(tY - sY, tX - sX),\n dist = 3;\n sX += Math.sin(angle) * dist;\n tX += Math.sin(angle) * dist;\n sY += -Math.cos(angle) * dist;\n tY += -Math.cos(angle) * dist;\n var aSize = Math.max(size * 2.5, settings('minArrowSize')),\n d = Math.sqrt(Math.pow(tX - sX, 2) + Math.pow(tY - sY, 2)),\n aX = sX + (tX - sX) * (d - aSize - tSize) / d,\n aY = sY + (tY - sY) * (d - aSize - tSize) / d,\n vX = (tX - sX) * aSize / d,\n vY = (tY - sY) * aSize / d;\n\n context.strokeStyle = color;\n context.lineWidth = size;\n context.beginPath();\n context.moveTo(sX, sY);\n context.lineTo(aX, aY);\n context.stroke();\n\n context.fillStyle = color;\n context.beginPath();\n context.moveTo(aX + vX, aY + vY);\n context.lineTo(aX + vY * 0.6, aY - vX * 0.6);\n context.lineTo(aX - vY * 0.6, aY + vX * 0.6);\n context.lineTo(aX + vX, aY + vY);\n context.closePath();\n context.fill();\n }\n }, {\n key: 'drawOnHover',\n value: function drawOnHover(node, context, settings, next) {\n var tracer = this;\n\n context.setLineDash([5, 5]);\n var nodeIdx = node.id.substring(1);\n this.graph.edges().forEach(function (edge) {\n var ends = edge.id.substring(1).split(\"_\");\n if (ends[0] == nodeIdx) {\n var color = '#0ff';\n var source = node;\n var target = tracer.graph.nodes('n' + ends[1]);\n tracer.drawArrow(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n } else if (ends[1] == nodeIdx) {\n var color = '#ff0';\n var source = tracer.graph.nodes('n' + ends[0]);\n var target = node;\n tracer.drawArrow(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n }\n });\n }\n }]);\n\n return DirectedGraphTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.s = tracer.capsule.s = new sigma({\n renderer: {\n container: tracer.$container[0],\n type: 'canvas'\n },\n settings: {\n minArrowSize: 8,\n defaultEdgeType: 'arrow',\n maxEdgeSize: 2.5,\n labelThreshold: 4,\n font: 'Roboto',\n defaultLabelColor: '#fff',\n zoomMin: 0.6,\n zoomMax: 1.2,\n skipErrors: true,\n minNodeSize: .5,\n maxNodeSize: 12,\n labelSize: 'proportional',\n labelSizeRatio: 1.3,\n funcLabelsDef: function funcLabelsDef(node, context, settings) {\n tracer.drawLabel(node, context, settings);\n },\n funcHoversDef: function funcHoversDef(node, context, settings, next) {\n tracer.drawOnHover(node, context, settings, next);\n },\n funcEdgesArrow: function funcEdgesArrow(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawArrow(edge, source, target, color, context, settings);\n }\n }\n });\n sigma.plugins.dragNodes(tracer.s, tracer.s.renderers[0]);\n tracer.graph = tracer.capsule.graph = tracer.s.graph;\n};\n\nsigma.canvas.labels.def = function (node, context, settings) {\n var func = settings('funcLabelsDef');\n if (func) {\n func(node, context, settings);\n }\n};\nsigma.canvas.hovers.def = function (node, context, settings) {\n var func = settings('funcHoversDef');\n if (func) {\n func(node, context, settings);\n }\n};\nsigma.canvas.edges.def = function (edge, source, target, context, settings) {\n var func = settings('funcEdgesDef');\n if (func) {\n func(edge, source, target, context, settings);\n }\n};\nsigma.canvas.edges.arrow = function (edge, source, target, context, settings) {\n var func = settings('funcEdgesArrow');\n if (func) {\n func(edge, source, target, context, settings);\n }\n};\n\nmodule.exports = DirectedGraphTracer;\n\n},{\"../../tracer_manager/util/index\":67,\"./tracer\":47}],45:[function(require,module,exports){\n'use strict';\n\nvar Tracer = require('./tracer');\nvar LogTracer = require('./log');\nvar Array1DTracer = require('./array1d');\nvar Array2DTracer = require('./array2d');\nvar ChartTracer = require('./chart');\nvar CoordinateSystemTracer = require('./coordinate_system');\nvar DirectedGraphTracer = require('./directed_graph');\nvar UndirectedGraphTracer = require('./undirected_graph');\nvar WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nvar WeightedUndirectedGraphTracer = require('./weighted_undirected_graph');\n\nmodule.exports = {\n Tracer: Tracer,\n LogTracer: LogTracer,\n Array1DTracer: Array1DTracer,\n Array2DTracer: Array2DTracer,\n ChartTracer: ChartTracer,\n CoordinateSystemTracer: CoordinateSystemTracer,\n DirectedGraphTracer: DirectedGraphTracer,\n UndirectedGraphTracer: UndirectedGraphTracer,\n WeightedDirectedGraphTracer: WeightedDirectedGraphTracer,\n WeightedUndirectedGraphTracer: WeightedUndirectedGraphTracer\n};\n\n},{\"./array1d\":40,\"./array2d\":41,\"./chart\":42,\"./coordinate_system\":43,\"./directed_graph\":44,\"./log\":46,\"./tracer\":47,\"./undirected_graph\":48,\"./weighted_directed_graph\":49,\"./weighted_undirected_graph\":50}],46:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar LogTracer = function (_Tracer) {\n _inherits(LogTracer, _Tracer);\n\n _createClass(LogTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'LogTracer';\n }\n }]);\n\n function LogTracer(name) {\n _classCallCheck(this, LogTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(LogTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(LogTracer, [{\n key: '_print',\n value: function _print(msg) {\n this.manager.pushStep(this.capsule, {\n type: 'print',\n msg: msg\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'print':\n this.print(step.msg);\n break;\n }\n }\n }, {\n key: 'refresh',\n value: function refresh() {\n this.scrollToEnd(Math.min(50, this.interval));\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(LogTracer.prototype), 'clear', this).call(this);\n\n this.$wrapper.empty();\n }\n }, {\n key: 'print',\n value: function print(message) {\n this.$wrapper.append($('<span>').append(message + '<br/>'));\n }\n }, {\n key: 'scrollToEnd',\n value: function scrollToEnd(duration) {\n this.$container.animate({\n scrollTop: this.$container[0].scrollHeight\n }, duration);\n }\n }]);\n\n return LogTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.$wrapper = tracer.capsule.$wrapper = $('<div class=\"wrapper\">');\n tracer.$container.append(tracer.$wrapper);\n};\n\nmodule.exports = LogTracer;\n\n},{\"./tracer\":47}],47:[function(require,module,exports){\n'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar app = require('../../app');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar toJSON = _require.toJSON;\nvar fromJSON = _require.fromJSON;\n\nvar Tracer = function () {\n _createClass(Tracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'Tracer';\n }\n }]);\n\n function Tracer(name) {\n _classCallCheck(this, Tracer);\n\n this.module = this.constructor;\n\n this.manager = app.getTracerManager();\n this.capsule = this.manager.allocate(this);\n $.extend(this, this.capsule);\n\n this.setName(name);\n }\n\n _createClass(Tracer, [{\n key: '_setData',\n value: function _setData() {\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n this.manager.pushStep(this.capsule, {\n type: 'setData',\n args: toJSON(args)\n });\n return this;\n }\n }, {\n key: '_clear',\n value: function _clear() {\n this.manager.pushStep(this.capsule, {\n type: 'clear'\n });\n return this;\n }\n }, {\n key: '_wait',\n value: function _wait(line) {\n this.manager.newStep(line);\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n var type = step.type;\n var args = step.args;\n\n\n switch (type) {\n case 'setData':\n this.setData.apply(this, _toConsumableArray(fromJSON(args)));\n break;\n case 'clear':\n this.clear();\n break;\n }\n }\n }, {\n key: 'setName',\n value: function setName(name) {\n var $name = void 0;\n if (this.isNew) {\n $name = $('<span class=\"name\">');\n this.$container.append($name);\n } else {\n $name = this.$container.find('span.name');\n }\n $name.text(name || this.defaultName);\n }\n }, {\n key: 'setData',\n value: function setData() {\n var data = toJSON(arguments);\n if (!this.isNew && this.lastData === data) {\n return true;\n }\n this.lastData = this.capsule.lastData = data;\n return false;\n }\n }, {\n key: 'resize',\n value: function resize() {}\n }, {\n key: 'refresh',\n value: function refresh() {}\n }, {\n key: 'clear',\n value: function clear() {}\n }, {\n key: 'attach',\n value: function attach(tracer) {\n switch (tracer.module) {\n case LogTracer:\n this.logTracer = tracer;\n break;\n case ChartTracer:\n this.chartTracer = tracer;\n break;\n }\n return this;\n }\n }, {\n key: 'mousedown',\n value: function mousedown(e) {}\n }, {\n key: 'mousemove',\n value: function mousemove(e) {}\n }, {\n key: 'mouseup',\n value: function mouseup(e) {}\n }, {\n key: 'mousewheel',\n value: function mousewheel(e) {}\n }]);\n\n return Tracer;\n}();\n\nmodule.exports = Tracer;\n\n},{\"../../app\":3,\"../../tracer_manager/util/index\":67}],48:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar DirectedGraphTracer = require('./directed_graph');\n\nvar UndirectedGraphTracer = function (_DirectedGraphTracer) {\n _inherits(UndirectedGraphTracer, _DirectedGraphTracer);\n\n _createClass(UndirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'UndirectedGraphTracer';\n }\n }]);\n\n function UndirectedGraphTracer(name) {\n _classCallCheck(this, UndirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(UndirectedGraphTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(UndirectedGraphTracer, [{\n key: 'setTreeData',\n value: function setTreeData(G, root) {\n return _get(Object.getPrototypeOf(UndirectedGraphTracer.prototype), 'setTreeData', this).call(this, G, root, true);\n }\n }, {\n key: 'setData',\n value: function setData(G) {\n return _get(Object.getPrototypeOf(UndirectedGraphTracer.prototype), 'setData', this).call(this, G, true);\n }\n }, {\n key: 'e',\n value: function e(v1, v2) {\n if (v1 > v2) {\n var temp = v1;\n v1 = v2;\n v2 = temp;\n }\n return 'e' + v1 + '_' + v2;\n }\n }, {\n key: 'drawOnHover',\n value: function drawOnHover(node, context, settings, next) {\n var tracer = this;\n\n context.setLineDash([5, 5]);\n var nodeIdx = node.id.substring(1);\n this.graph.edges().forEach(function (edge) {\n var ends = edge.id.substring(1).split(\"_\");\n if (ends[0] == nodeIdx) {\n var color = '#0ff';\n var source = node;\n var target = tracer.graph.nodes('n' + ends[1]);\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n } else if (ends[1] == nodeIdx) {\n var color = '#0ff';\n var source = tracer.graph.nodes('n' + ends[0]);\n var target = node;\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n }\n });\n }\n }, {\n key: 'drawEdge',\n value: function drawEdge(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1;\n\n context.strokeStyle = color;\n context.lineWidth = size;\n context.beginPath();\n context.moveTo(source[prefix + 'x'], source[prefix + 'y']);\n context.lineTo(target[prefix + 'x'], target[prefix + 'y']);\n context.stroke();\n }\n }]);\n\n return UndirectedGraphTracer;\n}(DirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n defaultEdgeType: 'def',\n funcEdgesDef: function funcEdgesDef(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawEdge(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = UndirectedGraphTracer;\n\n},{\"./directed_graph\":44}],49:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar DirectedGraphTracer = require('./directed_graph');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar refineByType = _require.refineByType;\n\nvar WeightedDirectedGraphTracer = function (_DirectedGraphTracer) {\n _inherits(WeightedDirectedGraphTracer, _DirectedGraphTracer);\n\n _createClass(WeightedDirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'WeightedDirectedGraphTracer';\n }\n }]);\n\n function WeightedDirectedGraphTracer(name) {\n _classCallCheck(this, WeightedDirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(WeightedDirectedGraphTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(WeightedDirectedGraphTracer, [{\n key: '_weight',\n value: function _weight(target, weight) {\n this.manager.pushStep(this.capsule, {\n type: 'weight',\n target: target,\n weight: weight\n });\n return this;\n }\n }, {\n key: '_visit',\n value: function _visit(target, source, weight) {\n this.manager.pushStep(this.capsule, {\n type: 'visit',\n target: target,\n source: source,\n weight: weight\n });\n return this;\n }\n }, {\n key: '_leave',\n value: function _leave(target, source, weight) {\n this.manager.pushStep(this.capsule, {\n type: 'leave',\n target: target,\n source: source,\n weight: weight\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'weight':\n var targetNode = this.graph.nodes(this.n(step.target));\n if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n break;\n case 'visit':\n case 'leave':\n var visit = step.type == 'visit';\n var targetNode = this.graph.nodes(this.n(step.target));\n var color = visit ? step.weight === undefined ? this.color.selected : this.color.visited : this.color.left;\n targetNode.color = color;\n if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n if (step.source !== undefined) {\n var edgeId = this.e(step.source, step.target);\n var edge = this.graph.edges(edgeId);\n edge.color = color;\n this.graph.dropEdge(edgeId).addEdge(edge);\n }\n if (this.logTracer) {\n var source = step.source;\n if (source === undefined) source = '';\n this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n }\n break;\n default:\n _get(Object.getPrototypeOf(WeightedDirectedGraphTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(WeightedDirectedGraphTracer.prototype), 'clear', this).call(this);\n\n this.clearWeights();\n }\n }, {\n key: 'clearWeights',\n value: function clearWeights() {\n this.graph.nodes().forEach(function (node) {\n node.weight = 0;\n });\n }\n }, {\n key: 'drawEdgeWeight',\n value: function drawEdgeWeight(edge, source, target, color, context, settings) {\n if (source == target) return;\n\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1;\n\n if (size < settings('edgeLabelThreshold')) return;\n\n if (0 === settings('edgeLabelSizePowRatio')) throw '\"edgeLabelSizePowRatio\" must not be 0.';\n\n var fontSize,\n x = (source[prefix + 'x'] + target[prefix + 'x']) / 2,\n y = (source[prefix + 'y'] + target[prefix + 'y']) / 2,\n dX = target[prefix + 'x'] - source[prefix + 'x'],\n dY = target[prefix + 'y'] - source[prefix + 'y'],\n angle = Math.atan2(dY, dX);\n\n fontSize = settings('edgeLabelSize') === 'fixed' ? settings('defaultEdgeLabelSize') : settings('defaultEdgeLabelSize') * size * Math.pow(size, -1 / settings('edgeLabelSizePowRatio'));\n\n context.save();\n\n if (edge.active) {\n context.font = [settings('activeFontStyle'), fontSize + 'px', settings('activeFont') || settings('font')].join(' ');\n\n context.fillStyle = color;\n } else {\n context.font = [settings('fontStyle'), fontSize + 'px', settings('font')].join(' ');\n\n context.fillStyle = color;\n }\n\n context.textAlign = 'center';\n context.textBaseline = 'alphabetic';\n\n context.translate(x, y);\n context.rotate(angle);\n context.fillText(edge.weight, 0, -size / 2 - 3);\n\n context.restore();\n }\n }, {\n key: 'drawNodeWeight',\n value: function drawNodeWeight(node, context, settings) {\n var fontSize,\n prefix = settings('prefix') || '',\n size = node[prefix + 'size'];\n\n if (size < settings('labelThreshold')) return;\n\n fontSize = settings('labelSize') === 'fixed' ? settings('defaultLabelSize') : settings('labelSizeRatio') * size;\n\n context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') + fontSize + 'px ' + settings('font');\n context.fillStyle = settings('labelColor') === 'node' ? node.color || settings('defaultNodeColor') : settings('defaultLabelColor');\n\n context.textAlign = 'left';\n context.fillText(node.weight, Math.round(node[prefix + 'x'] + size * 1.5), Math.round(node[prefix + 'y'] + fontSize / 3));\n }\n }]);\n\n return WeightedDirectedGraphTracer;\n}(DirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n edgeLabelSize: 'proportional',\n defaultEdgeLabelSize: 20,\n edgeLabelSizePowRatio: 0.8,\n funcLabelsDef: function funcLabelsDef(node, context, settings) {\n tracer.drawNodeWeight(node, context, settings);\n tracer.drawLabel(node, context, settings);\n },\n funcHoversDef: function funcHoversDef(node, context, settings) {\n tracer.drawOnHover(node, context, settings, tracer.drawEdgeWeight);\n },\n funcEdgesArrow: function funcEdgesArrow(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawArrow(edge, source, target, color, context, settings);\n tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = WeightedDirectedGraphTracer;\n\n},{\"../../tracer_manager/util/index\":67,\"./directed_graph\":44}],50:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nvar UndirectedGraphTracer = require('./undirected_graph');\n\nvar WeightedUndirectedGraphTracer = function (_WeightedDirectedGrap) {\n _inherits(WeightedUndirectedGraphTracer, _WeightedDirectedGrap);\n\n _createClass(WeightedUndirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'WeightedUndirectedGraphTracer';\n }\n }]);\n\n function WeightedUndirectedGraphTracer(name) {\n _classCallCheck(this, WeightedUndirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(WeightedUndirectedGraphTracer).call(this, name));\n\n _this.e = UndirectedGraphTracer.prototype.e;\n _this.drawOnHover = UndirectedGraphTracer.prototype.drawOnHover;\n _this.drawEdge = UndirectedGraphTracer.prototype.drawEdge;\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(WeightedUndirectedGraphTracer, [{\n key: 'setTreeData',\n value: function setTreeData(G, root) {\n return _get(Object.getPrototypeOf(WeightedUndirectedGraphTracer.prototype), 'setTreeData', this).call(this, G, root, true);\n }\n }, {\n key: 'setData',\n value: function setData(G) {\n return _get(Object.getPrototypeOf(WeightedUndirectedGraphTracer.prototype), 'setData', this).call(this, G, true);\n }\n }, {\n key: 'drawEdgeWeight',\n value: function drawEdgeWeight(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '';\n if (source[prefix + 'x'] > target[prefix + 'x']) {\n var temp = source;\n source = target;\n target = temp;\n }\n WeightedDirectedGraphTracer.prototype.drawEdgeWeight.call(this, edge, source, target, color, context, settings);\n }\n }]);\n\n return WeightedUndirectedGraphTracer;\n}(WeightedDirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n defaultEdgeType: 'def',\n funcEdgesDef: function funcEdgesDef(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawEdge(edge, source, target, color, context, settings);\n tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = WeightedUndirectedGraphTracer;\n\n},{\"./undirected_graph\":48,\"./weighted_directed_graph\":49}],51:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url) {\n return request(url, {\n type: 'GET'\n });\n};\n\n},{\"./request\":54}],52:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url) {\n return request(url, {\n dataType: 'json',\n type: 'GET'\n });\n};\n\n},{\"./request\":54}],53:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url, data) {\n return request(url, {\n dataType: 'json',\n type: 'POST',\n data: JSON.stringify(data)\n });\n};\n\n},{\"./request\":54}],54:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('../../app');\n\nvar _$ = $;\nvar ajax = _$.ajax;\nvar extend = _$.extend;\n\n\nvar defaults = {};\n\nmodule.exports = function (url) {\n var options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1];\n\n app.setIsLoading(true);\n\n return new RSVP.Promise(function (resolve, reject) {\n var callbacks = {\n success: function success(response) {\n app.setIsLoading(false);\n resolve(response);\n },\n error: function error(reason) {\n app.setIsLoading(false);\n reject(reason);\n }\n };\n\n var opts = extend({}, defaults, options, callbacks, {\n url: url\n });\n\n ajax(opts);\n });\n};\n\n},{\"../../app\":3,\"rsvp\":72}],55:[function(require,module,exports){\n'use strict';\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar app = require('../app');\nvar Toast = require('../dom/toast');\n\nvar checkLoading = function checkLoading() {\n if (app.getIsLoading()) {\n Toast.showErrorToast('Wait until it completes loading of previous file.');\n return true;\n }\n return false;\n};\n\nvar getParameterByName = function getParameterByName(name) {\n var url = window.location.href;\n var regex = new RegExp('[?&]' + name + '(=([^&#]*)|&|#|$)');\n\n var results = regex.exec(url);\n\n if (!results || results.length !== 3) {\n return null;\n }\n\n var _results = _slicedToArray(results, 3);\n\n var id = _results[2];\n\n\n return id;\n};\n\nvar getHashValue = function getHashValue(key) {\n if (!key) return null;\n var hash = window.location.hash.substr(1);\n var params = hash ? hash.split('&') : [];\n for (var i = 0; i < params.length; i++) {\n var pair = params[i].split('=');\n if (pair[0] === key) {\n return pair[1];\n }\n }\n return null;\n};\n\nvar setHashValue = function setHashValue(key, value) {\n if (!key || !value) return;\n var hash = window.location.hash.substr(1);\n var params = hash ? hash.split('&') : [];\n\n var found = false;\n for (var i = 0; i < params.length && !found; i++) {\n var pair = params[i].split('=');\n if (pair[0] === key) {\n pair[1] = value;\n params[i] = pair.join('=');\n found = true;\n }\n }\n if (!found) {\n params.push([key, value].join('='));\n }\n\n var newHash = params.join('&');\n window.location.hash = '#' + newHash;\n};\n\nvar removeHashValue = function removeHashValue(key) {\n if (!key) return;\n var hash = window.location.hash.substr(1);\n var params = hash ? hash.split('&') : [];\n\n for (var i = 0; i < params.length; i++) {\n var pair = params[i].split('=');\n if (pair[0] === key) {\n params.splice(i, 1);\n break;\n }\n }\n\n var newHash = params.join('&');\n window.location.hash = '#' + newHash;\n};\n\nvar setPath = function setPath(category, algorithm, file) {\n var path = category ? category + (algorithm ? '/' + algorithm + (file ? '/' + file : '') : '') : '';\n setHashValue('path', path);\n};\n\nvar getPath = function getPath() {\n var hash = getHashValue('path');\n if (hash) {\n var _hash$split = hash.split('/');\n\n var _hash$split2 = _slicedToArray(_hash$split, 3);\n\n var category = _hash$split2[0];\n var algorithm = _hash$split2[1];\n var file = _hash$split2[2];\n\n return { category: category, algorithm: algorithm, file: file };\n } else {\n return false;\n }\n};\n\nmodule.exports = {\n checkLoading: checkLoading,\n getParameterByName: getParameterByName,\n getHashValue: getHashValue,\n setHashValue: setHashValue,\n removeHashValue: removeHashValue,\n setPath: setPath,\n getPath: getPath\n};\n\n},{\"../app\":3,\"../dom/toast\":24}],56:[function(require,module,exports){\n'use strict';\n\nvar loadAlgorithm = require('./load_algorithm');\nvar loadCategories = require('./load_categories');\nvar loadFile = require('./load_file');\nvar loadScratchPaper = require('./load_scratch_paper');\nvar shareScratchPaper = require('./share_scratch_paper');\nvar loadWikiList = require('./load_wiki_list');\nvar loadWiki = require('./load_wiki');\n\nmodule.exports = {\n loadAlgorithm: loadAlgorithm,\n loadCategories: loadCategories,\n loadFile: loadFile,\n loadScratchPaper: loadScratchPaper,\n shareScratchPaper: shareScratchPaper,\n loadWikiList: loadWikiList,\n loadWiki: loadWiki\n};\n\n},{\"./load_algorithm\":57,\"./load_categories\":58,\"./load_file\":59,\"./load_scratch_paper\":60,\"./load_wiki\":61,\"./load_wiki_list\":62,\"./share_scratch_paper\":63}],57:[function(require,module,exports){\n'use strict';\n\nvar getJSON = require('./ajax/get_json');\n\nvar _require = require('../utils');\n\nvar getAlgorithmDir = _require.getAlgorithmDir;\n\n\nmodule.exports = function (category, algorithm) {\n var dir = getAlgorithmDir(category, algorithm);\n return getJSON(dir + 'desc.json');\n};\n\n},{\"../utils\":70,\"./ajax/get_json\":52}],58:[function(require,module,exports){\n'use strict';\n\nvar getJSON = require('./ajax/get_json');\n\nmodule.exports = function () {\n return getJSON('./algorithm/category.json');\n};\n\n},{\"./ajax/get_json\":52}],59:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\n\nvar app = require('../app');\n\nvar _require = require('../utils');\n\nvar getFileDir = _require.getFileDir;\nvar isScratchPaper = _require.isScratchPaper;\n\nvar _require2 = require('./helpers');\n\nvar checkLoading = _require2.checkLoading;\nvar setPath = _require2.setPath;\n\n\nvar get = require('./ajax/get');\n\nvar loadDataAndCode = function loadDataAndCode(dir) {\n return RSVP.hash({\n data: get(dir + 'data.js'),\n code: get(dir + 'code.js')\n });\n};\n\nvar loadFileAndUpdateContent = function loadFileAndUpdateContent(dir) {\n app.getEditor().clearContent();\n\n return loadDataAndCode(dir).then(function (content) {\n app.updateCachedFile(dir, content);\n app.getEditor().setContent(content);\n });\n};\n\nvar cachedContentExists = function cachedContentExists(cachedFile) {\n return cachedFile && cachedFile.data !== undefined && cachedFile.code !== undefined;\n};\n\nmodule.exports = function (category, algorithm, file, explanation) {\n return new RSVP.Promise(function (resolve, reject) {\n if (checkLoading()) {\n reject();\n } else {\n if (isScratchPaper(category)) {\n setPath(category, app.getLoadedScratch());\n } else {\n setPath(category, algorithm, file);\n }\n $('#explanation').html(explanation);\n\n var dir = getFileDir(category, algorithm, file);\n app.setLastFileUsed(dir);\n var cachedFile = app.getCachedFile(dir);\n\n if (cachedContentExists(cachedFile)) {\n app.getEditor().setContent(cachedFile);\n resolve();\n } else {\n loadFileAndUpdateContent(dir).then(resolve, reject);\n }\n }\n });\n};\n\n},{\"../app\":3,\"../utils\":70,\"./ajax/get\":51,\"./helpers\":55,\"rsvp\":72}],60:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('../app');\n\nvar _require = require('../utils');\n\nvar getFileDir = _require.getFileDir;\n\n\nvar getJSON = require('./ajax/get_json');\nvar loadAlgorithm = require('./load_algorithm');\n\nvar extractGistCode = function extractGistCode(files, name) {\n return files[name + '.js'].content;\n};\n\nmodule.exports = function (gistID) {\n return new RSVP.Promise(function (resolve, reject) {\n app.setLoadedScratch(gistID);\n\n getJSON('https://api.github.com/gists/' + gistID).then(function (_ref) {\n var files = _ref.files;\n\n\n var category = 'scratch';\n var algorithm = gistID;\n\n loadAlgorithm(category, algorithm).then(function (data) {\n\n var algoData = extractGistCode(files, 'data');\n var algoCode = extractGistCode(files, 'code');\n\n // update scratch paper algo code with the loaded gist code\n var dir = getFileDir(category, algorithm, 'scratch_paper');\n app.updateCachedFile(dir, {\n data: algoData,\n code: algoCode,\n 'CREDIT.md': 'Shared by an anonymous user from http://parkjs814.github.io/AlgorithmVisualizer'\n });\n\n resolve({\n category: category,\n algorithm: algorithm,\n data: data\n });\n });\n });\n });\n};\n\n},{\"../app\":3,\"../utils\":70,\"./ajax/get_json\":52,\"./load_algorithm\":57,\"rsvp\":72}],61:[function(require,module,exports){\n'use strict';\n\nvar get = require('./ajax/get');\n\nmodule.exports = function (wiki) {\n return get('./AlgorithmVisualizer.wiki/' + wiki + '.md');\n};\n\n},{\"./ajax/get\":51}],62:[function(require,module,exports){\n'use strict';\n\nvar getJSON = require('./ajax/get_json');\n\nmodule.exports = function () {\n return getJSON('./wiki.json');\n};\n\n},{\"./ajax/get_json\":52}],63:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('../app');\n\nvar postJSON = require('./ajax/post_json');\n\nvar _require = require('./helpers');\n\nvar setPath = _require.setPath;\n\n\nmodule.exports = function () {\n return new RSVP.Promise(function (resolve, reject) {\n var _app$getEditor = app.getEditor();\n\n var dataEditor = _app$getEditor.dataEditor;\n var codeEditor = _app$getEditor.codeEditor;\n\n\n var gist = {\n 'description': 'temp',\n 'public': true,\n 'files': {\n 'data.js': {\n 'content': dataEditor.getValue()\n },\n 'code.js': {\n 'content': codeEditor.getValue()\n }\n }\n };\n\n postJSON('https://api.github.com/gists', gist).then(function (_ref) {\n var id = _ref.id;\n\n app.setLoadedScratch(id);\n setPath('scratch', id);\n var _location = location;\n var href = _location.href;\n\n $('#algorithm').html('Shared');\n resolve(href);\n });\n });\n};\n\n},{\"../app\":3,\"./ajax/post_json\":53,\"./helpers\":55,\"rsvp\":72}],64:[function(require,module,exports){\n'use strict';\n\nvar TracerManager = require('./manager');\nvar Tracer = require('../module/tracer/tracer');\n\nmodule.exports = {\n init: function init() {\n var tm = new TracerManager();\n Tracer.prototype.manager = tm;\n return tm;\n }\n};\n\n},{\"../module/tracer/tracer\":47,\"./manager\":65}],65:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar ModuleContainer = require('../dom/module_container');\nvar TopMenu = require('../dom/top_menu');\n\nvar _$ = $;\nvar each = _$.each;\nvar extend = _$.extend;\nvar grep = _$.grep;\n\n\nvar stepLimit = 1e6;\n\nvar TracerManager = function TracerManager() {\n this.timer = null;\n this.pause = false;\n this.capsules = [];\n this.interval = 500;\n};\n\nTracerManager.prototype = {\n add: function add(tracer) {\n\n var $container = ModuleContainer.create();\n\n var capsule = {\n module: tracer.module,\n tracer: tracer,\n allocated: true,\n defaultName: null,\n $container: $container,\n isNew: true\n };\n\n this.capsules.push(capsule);\n return capsule;\n },\n allocate: function allocate(newTracer) {\n var selectedCapsule = null;\n var count = 0;\n\n each(this.capsules, function (i, capsule) {\n if (capsule.module === newTracer.module) {\n count++;\n if (!capsule.allocated) {\n capsule.tracer = newTracer;\n capsule.allocated = true;\n capsule.isNew = false;\n selectedCapsule = capsule;\n return false;\n }\n }\n });\n\n if (selectedCapsule === null) {\n count++;\n selectedCapsule = this.add(newTracer);\n }\n\n var className = newTracer.module.getClassName();\n selectedCapsule.defaultName = className + ' ' + count;\n selectedCapsule.order = this.order++;\n return selectedCapsule;\n },\n deallocateAll: function deallocateAll() {\n this.order = 0;\n this.reset();\n each(this.capsules, function (i, capsule) {\n capsule.allocated = false;\n });\n },\n removeUnallocated: function removeUnallocated() {\n var changed = false;\n\n this.capsules = grep(this.capsules, function (capsule) {\n var removed = !capsule.allocated;\n\n if (capsule.isNew || removed) {\n changed = true;\n }\n if (removed) {\n capsule.$container.remove();\n }\n\n return !removed;\n });\n\n if (changed) {\n this.place();\n }\n },\n place: function place() {\n var capsules = this.capsules;\n\n\n each(capsules, function (i, capsule) {\n var width = 100;\n var height = 100 / capsules.length;\n var top = height * capsule.order;\n\n capsule.$container.css({\n top: top + '%',\n width: width + '%',\n height: height + '%'\n });\n\n capsule.tracer.resize();\n });\n },\n resize: function resize() {\n this.command('resize');\n },\n isPause: function isPause() {\n return this.pause;\n },\n setInterval: function setInterval(interval) {\n TopMenu.setInterval(interval);\n },\n reset: function reset() {\n this.traces = [];\n this.traceIndex = -1;\n this.stepCnt = 0;\n if (this.timer) {\n clearTimeout(this.timer);\n }\n this.command('clear');\n },\n pushStep: function pushStep(capsule, step) {\n if (this.stepCnt++ > stepLimit) throw \"Tracer's stack overflow\";\n var len = this.traces.length;\n if (len == 0) len += this.newStep();\n var last = this.traces[len - 1];\n last.push(extend(step, {\n capsule: capsule\n }));\n },\n newStep: function newStep() {\n var line = arguments.length <= 0 || arguments[0] === undefined ? -1 : arguments[0];\n\n var len = this.traces.length;\n if (len > 0 && ~line) {\n this.traces[len - 1].push(line);\n }\n return this.traces.push([]);\n },\n pauseStep: function pauseStep() {\n if (this.traceIndex < 0) return;\n this.pause = true;\n if (this.timer) {\n clearTimeout(this.timer);\n }\n TopMenu.activateBtnPause();\n },\n resumeStep: function resumeStep() {\n this.pause = false;\n this.step(this.traceIndex + 1);\n TopMenu.deactivateBtnPause();\n },\n step: function step(i) {\n var options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1];\n\n var tracer = this;\n\n if (isNaN(i) || i >= this.traces.length || i < 0) return;\n\n this.traceIndex = i;\n var trace = this.traces[i];\n trace.forEach(function (step) {\n if (typeof step === 'number') {\n app.getEditor().highlightLine(step);\n return;\n }\n step.capsule.tracer.processStep(step, options);\n });\n\n if (!options.virtual) {\n this.command('refresh');\n }\n\n if (this.pause) return;\n\n this.timer = setTimeout(function () {\n if (!tracer.nextStep(options)) {\n TopMenu.resetTopMenuButtons();\n }\n }, this.interval);\n },\n prevStep: function prevStep() {\n var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n this.command('clear');\n\n var finalIndex = this.traceIndex - 1;\n if (finalIndex < 0) {\n this.traceIndex = -1;\n this.command('refresh');\n return false;\n }\n\n for (var i = 0; i < finalIndex; i++) {\n this.step(i, extend(options, {\n virtual: true\n }));\n }\n\n this.step(finalIndex);\n return true;\n },\n nextStep: function nextStep() {\n var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n var finalIndex = this.traceIndex + 1;\n if (finalIndex >= this.traces.length) {\n this.traceIndex = this.traces.length - 1;\n return false;\n }\n\n this.step(finalIndex, options);\n return true;\n },\n visualize: function visualize() {\n this.traceIndex = -1;\n this.resumeStep();\n },\n command: function command() {\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var functionName = args.shift();\n each(this.capsules, function (i, capsule) {\n if (capsule.allocated) {\n capsule.tracer.module.prototype[functionName].apply(capsule.tracer, args);\n }\n });\n },\n findOwner: function findOwner(container) {\n var selectedCapsule = null;\n each(this.capsules, function (i, capsule) {\n if (capsule.$container[0] === container) {\n selectedCapsule = capsule;\n return false;\n }\n });\n return selectedCapsule.tracer;\n }\n};\n\nmodule.exports = TracerManager;\n\n},{\"../app\":3,\"../dom/module_container\":8,\"../dom/top_menu\":25}],66:[function(require,module,exports){\n'use strict';\n\nvar parse = JSON.parse;\n\n\nvar fromJSON = function fromJSON(obj) {\n return parse(obj, function (key, value) {\n return value === 'Infinity' ? Infinity : value;\n });\n};\n\nmodule.exports = fromJSON;\n\n},{}],67:[function(require,module,exports){\n'use strict';\n\nvar toJSON = require('./to_json');\nvar fromJSON = require('./from_json');\nvar refineByType = require('./refine_by_type');\n\nmodule.exports = {\n toJSON: toJSON,\n fromJSON: fromJSON,\n refineByType: refineByType\n};\n\n},{\"./from_json\":66,\"./refine_by_type\":68,\"./to_json\":69}],68:[function(require,module,exports){\n'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol ? \"symbol\" : typeof obj; };\n\nvar refineByType = function refineByType(item) {\n switch (typeof item === 'undefined' ? 'undefined' : _typeof(item)) {\n case 'number':\n return refineNumber(item);\n case 'boolean':\n return refineBoolean(item);\n default:\n return refineString(item);\n }\n};\n\nvar refineString = function refineString(str) {\n return str === '' ? ' ' : str;\n};\n\nvar refineNumber = function refineNumber(num) {\n return num === Infinity ? '∞' : num;\n};\n\nvar refineBoolean = function refineBoolean(bool) {\n return bool ? 'T' : 'F';\n};\n\nmodule.exports = refineByType;\n\n},{}],69:[function(require,module,exports){\n'use strict';\n\nvar stringify = JSON.stringify;\n\n\nvar toJSON = function toJSON(obj) {\n return stringify(obj, function (key, value) {\n return value === Infinity ? 'Infinity' : value;\n });\n};\n\nmodule.exports = toJSON;\n\n},{}],70:[function(require,module,exports){\n'use strict';\n\nvar isScratchPaper = function isScratchPaper(category, algorithm) {\n return category == 'scratch';\n};\n\nvar getAlgorithmDir = function getAlgorithmDir(category, algorithm) {\n if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n return './algorithm/' + category + '/' + algorithm + '/';\n};\n\nvar getFileDir = function getFileDir(category, algorithm, file) {\n if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n return './algorithm/' + category + '/' + algorithm + '/' + file + '/';\n};\n\nmodule.exports = {\n isScratchPaper: isScratchPaper,\n getAlgorithmDir: getAlgorithmDir,\n getFileDir: getFileDir\n};\n\n},{}],71:[function(require,module,exports){\n// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = setTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n clearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n setTimeout(drainQueue, 0);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\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\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n\n},{}],72:[function(require,module,exports){\n(function (process,global){\n/*!\n * @overview RSVP - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors\n * @license Licensed under MIT license\n * See https://raw.githubusercontent.com/tildeio/rsvp.js/master/LICENSE\n * @version 3.2.1\n */\n\n(function() {\n \"use strict\";\n function lib$rsvp$utils$$objectOrFunction(x) {\n return typeof x === 'function' || (typeof x === 'object' && x !== null);\n }\n\n function lib$rsvp$utils$$isFunction(x) {\n return typeof x === 'function';\n }\n\n function lib$rsvp$utils$$isMaybeThenable(x) {\n return typeof x === 'object' && x !== null;\n }\n\n var lib$rsvp$utils$$_isArray;\n if (!Array.isArray) {\n lib$rsvp$utils$$_isArray = function (x) {\n return Object.prototype.toString.call(x) === '[object Array]';\n };\n } else {\n lib$rsvp$utils$$_isArray = Array.isArray;\n }\n\n var lib$rsvp$utils$$isArray = lib$rsvp$utils$$_isArray;\n\n var lib$rsvp$utils$$now = Date.now || function() { return new Date().getTime(); };\n\n function lib$rsvp$utils$$F() { }\n\n var lib$rsvp$utils$$o_create = (Object.create || function (o) {\n if (arguments.length > 1) {\n throw new Error('Second argument not supported');\n }\n if (typeof o !== 'object') {\n throw new TypeError('Argument must be an object');\n }\n lib$rsvp$utils$$F.prototype = o;\n return new lib$rsvp$utils$$F();\n });\n function lib$rsvp$events$$indexOf(callbacks, callback) {\n for (var i=0, l=callbacks.length; i<l; i++) {\n if (callbacks[i] === callback) { return i; }\n }\n\n return -1;\n }\n\n function lib$rsvp$events$$callbacksFor(object) {\n var callbacks = object._promiseCallbacks;\n\n if (!callbacks) {\n callbacks = object._promiseCallbacks = {};\n }\n\n return callbacks;\n }\n\n var lib$rsvp$events$$default = {\n\n /**\n `RSVP.EventTarget.mixin` extends an object with EventTarget methods. For\n Example:\n\n ```javascript\n var object = {};\n\n RSVP.EventTarget.mixin(object);\n\n object.on('finished', function(event) {\n // handle event\n });\n\n object.trigger('finished', { detail: value });\n ```\n\n `EventTarget.mixin` also works with prototypes:\n\n ```javascript\n var Person = function() {};\n RSVP.EventTarget.mixin(Person.prototype);\n\n var yehuda = new Person();\n var tom = new Person();\n\n yehuda.on('poke', function(event) {\n console.log('Yehuda says OW');\n });\n\n tom.on('poke', function(event) {\n console.log('Tom says OW');\n });\n\n yehuda.trigger('poke');\n tom.trigger('poke');\n ```\n\n @method mixin\n @for RSVP.EventTarget\n @private\n @param {Object} object object to extend with EventTarget methods\n */\n 'mixin': function(object) {\n object['on'] = this['on'];\n object['off'] = this['off'];\n object['trigger'] = this['trigger'];\n object._promiseCallbacks = undefined;\n return object;\n },\n\n /**\n Registers a callback to be executed when `eventName` is triggered\n\n ```javascript\n object.on('event', function(eventInfo){\n // handle the event\n });\n\n object.trigger('event');\n ```\n\n @method on\n @for RSVP.EventTarget\n @private\n @param {String} eventName name of the event to listen for\n @param {Function} callback function to be called when the event is triggered.\n */\n 'on': function(eventName, callback) {\n if (typeof callback !== 'function') {\n throw new TypeError('Callback must be a function');\n }\n\n var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks;\n\n callbacks = allCallbacks[eventName];\n\n if (!callbacks) {\n callbacks = allCallbacks[eventName] = [];\n }\n\n if (lib$rsvp$events$$indexOf(callbacks, callback) === -1) {\n callbacks.push(callback);\n }\n },\n\n /**\n You can use `off` to stop firing a particular callback for an event:\n\n ```javascript\n function doStuff() { // do stuff! }\n object.on('stuff', doStuff);\n\n object.trigger('stuff'); // doStuff will be called\n\n // Unregister ONLY the doStuff callback\n object.off('stuff', doStuff);\n object.trigger('stuff'); // doStuff will NOT be called\n ```\n\n If you don't pass a `callback` argument to `off`, ALL callbacks for the\n event will not be executed when the event fires. For example:\n\n ```javascript\n var callback1 = function(){};\n var callback2 = function(){};\n\n object.on('stuff', callback1);\n object.on('stuff', callback2);\n\n object.trigger('stuff'); // callback1 and callback2 will be executed.\n\n object.off('stuff');\n object.trigger('stuff'); // callback1 and callback2 will not be executed!\n ```\n\n @method off\n @for RSVP.EventTarget\n @private\n @param {String} eventName event to stop listening to\n @param {Function} callback optional argument. If given, only the function\n given will be removed from the event's callback queue. If no `callback`\n argument is given, all callbacks will be removed from the event's callback\n queue.\n */\n 'off': function(eventName, callback) {\n var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, index;\n\n if (!callback) {\n allCallbacks[eventName] = [];\n return;\n }\n\n callbacks = allCallbacks[eventName];\n\n index = lib$rsvp$events$$indexOf(callbacks, callback);\n\n if (index !== -1) { callbacks.splice(index, 1); }\n },\n\n /**\n Use `trigger` to fire custom events. For example:\n\n ```javascript\n object.on('foo', function(){\n console.log('foo event happened!');\n });\n object.trigger('foo');\n // 'foo event happened!' logged to the console\n ```\n\n You can also pass a value as a second argument to `trigger` that will be\n passed as an argument to all event listeners for the event:\n\n ```javascript\n object.on('foo', function(value){\n console.log(value.name);\n });\n\n object.trigger('foo', { name: 'bar' });\n // 'bar' logged to the console\n ```\n\n @method trigger\n @for RSVP.EventTarget\n @private\n @param {String} eventName name of the event to be triggered\n @param {*} options optional value to be passed to any event handlers for\n the given `eventName`\n */\n 'trigger': function(eventName, options, label) {\n var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, callback;\n\n if (callbacks = allCallbacks[eventName]) {\n // Don't cache the callbacks.length since it may grow\n for (var i=0; i<callbacks.length; i++) {\n callback = callbacks[i];\n\n callback(options, label);\n }\n }\n }\n };\n\n var lib$rsvp$config$$config = {\n instrument: false\n };\n\n lib$rsvp$events$$default['mixin'](lib$rsvp$config$$config);\n\n function lib$rsvp$config$$configure(name, value) {\n if (name === 'onerror') {\n // handle for legacy users that expect the actual\n // error to be passed to their function added via\n // `RSVP.configure('onerror', someFunctionHere);`\n lib$rsvp$config$$config['on']('error', value);\n return;\n }\n\n if (arguments.length === 2) {\n lib$rsvp$config$$config[name] = value;\n } else {\n return lib$rsvp$config$$config[name];\n }\n }\n\n var lib$rsvp$instrument$$queue = [];\n\n function lib$rsvp$instrument$$scheduleFlush() {\n setTimeout(function() {\n var entry;\n for (var i = 0; i < lib$rsvp$instrument$$queue.length; i++) {\n entry = lib$rsvp$instrument$$queue[i];\n\n var payload = entry.payload;\n\n payload.guid = payload.key + payload.id;\n payload.childGuid = payload.key + payload.childId;\n if (payload.error) {\n payload.stack = payload.error.stack;\n }\n\n lib$rsvp$config$$config['trigger'](entry.name, entry.payload);\n }\n lib$rsvp$instrument$$queue.length = 0;\n }, 50);\n }\n\n function lib$rsvp$instrument$$instrument(eventName, promise, child) {\n if (1 === lib$rsvp$instrument$$queue.push({\n name: eventName,\n payload: {\n key: promise._guidKey,\n id: promise._id,\n eventName: eventName,\n detail: promise._result,\n childId: child && child._id,\n label: promise._label,\n timeStamp: lib$rsvp$utils$$now(),\n error: lib$rsvp$config$$config[\"instrument-with-stack\"] ? new Error(promise._label) : null\n }})) {\n lib$rsvp$instrument$$scheduleFlush();\n }\n }\n var lib$rsvp$instrument$$default = lib$rsvp$instrument$$instrument;\n function lib$rsvp$then$$then(onFulfillment, onRejection, label) {\n var parent = this;\n var state = parent._state;\n\n if (state === lib$rsvp$$internal$$FULFILLED && !onFulfillment || state === lib$rsvp$$internal$$REJECTED && !onRejection) {\n lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, parent);\n return parent;\n }\n\n parent._onError = null;\n\n var child = new parent.constructor(lib$rsvp$$internal$$noop, label);\n var result = parent._result;\n\n lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, child);\n\n if (state) {\n var callback = arguments[state - 1];\n lib$rsvp$config$$config.async(function(){\n lib$rsvp$$internal$$invokeCallback(state, child, callback, result);\n });\n } else {\n lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection);\n }\n\n return child;\n }\n var lib$rsvp$then$$default = lib$rsvp$then$$then;\n function lib$rsvp$promise$resolve$$resolve(object, label) {\n /*jshint validthis:true */\n var Constructor = this;\n\n if (object && typeof object === 'object' && object.constructor === Constructor) {\n return object;\n }\n\n var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n lib$rsvp$$internal$$resolve(promise, object);\n return promise;\n }\n var lib$rsvp$promise$resolve$$default = lib$rsvp$promise$resolve$$resolve;\n function lib$rsvp$enumerator$$makeSettledResult(state, position, value) {\n if (state === lib$rsvp$$internal$$FULFILLED) {\n return {\n state: 'fulfilled',\n value: value\n };\n } else {\n return {\n state: 'rejected',\n reason: value\n };\n }\n }\n\n function lib$rsvp$enumerator$$Enumerator(Constructor, input, abortOnReject, label) {\n this._instanceConstructor = Constructor;\n this.promise = new Constructor(lib$rsvp$$internal$$noop, label);\n this._abortOnReject = abortOnReject;\n\n if (this._validateInput(input)) {\n this._input = input;\n this.length = input.length;\n this._remaining = input.length;\n\n this._init();\n\n if (this.length === 0) {\n lib$rsvp$$internal$$fulfill(this.promise, this._result);\n } else {\n this.length = this.length || 0;\n this._enumerate();\n if (this._remaining === 0) {\n lib$rsvp$$internal$$fulfill(this.promise, this._result);\n }\n }\n } else {\n lib$rsvp$$internal$$reject(this.promise, this._validationError());\n }\n }\n\n var lib$rsvp$enumerator$$default = lib$rsvp$enumerator$$Enumerator;\n\n lib$rsvp$enumerator$$Enumerator.prototype._validateInput = function(input) {\n return lib$rsvp$utils$$isArray(input);\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._validationError = function() {\n return new Error('Array Methods must be provided an Array');\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._init = function() {\n this._result = new Array(this.length);\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._enumerate = function() {\n var length = this.length;\n var promise = this.promise;\n var input = this._input;\n\n for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n this._eachEntry(input[i], i);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._settleMaybeThenable = function(entry, i) {\n var c = this._instanceConstructor;\n var resolve = c.resolve;\n\n if (resolve === lib$rsvp$promise$resolve$$default) {\n var then = lib$rsvp$$internal$$getThen(entry);\n\n if (then === lib$rsvp$then$$default &&\n entry._state !== lib$rsvp$$internal$$PENDING) {\n entry._onError = null;\n this._settledAt(entry._state, i, entry._result);\n } else if (typeof then !== 'function') {\n this._remaining--;\n this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n } else if (c === lib$rsvp$promise$$default) {\n var promise = new c(lib$rsvp$$internal$$noop);\n lib$rsvp$$internal$$handleMaybeThenable(promise, entry, then);\n this._willSettleAt(promise, i);\n } else {\n this._willSettleAt(new c(function(resolve) { resolve(entry); }), i);\n }\n } else {\n this._willSettleAt(resolve(entry), i);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._eachEntry = function(entry, i) {\n if (lib$rsvp$utils$$isMaybeThenable(entry)) {\n this._settleMaybeThenable(entry, i);\n } else {\n this._remaining--;\n this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._settledAt = function(state, i, value) {\n var promise = this.promise;\n\n if (promise._state === lib$rsvp$$internal$$PENDING) {\n this._remaining--;\n\n if (this._abortOnReject && state === lib$rsvp$$internal$$REJECTED) {\n lib$rsvp$$internal$$reject(promise, value);\n } else {\n this._result[i] = this._makeResult(state, i, value);\n }\n }\n\n if (this._remaining === 0) {\n lib$rsvp$$internal$$fulfill(promise, this._result);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._makeResult = function(state, i, value) {\n return value;\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._willSettleAt = function(promise, i) {\n var enumerator = this;\n\n lib$rsvp$$internal$$subscribe(promise, undefined, function(value) {\n enumerator._settledAt(lib$rsvp$$internal$$FULFILLED, i, value);\n }, function(reason) {\n enumerator._settledAt(lib$rsvp$$internal$$REJECTED, i, reason);\n });\n };\n function lib$rsvp$promise$all$$all(entries, label) {\n return new lib$rsvp$enumerator$$default(this, entries, true /* abort on reject */, label).promise;\n }\n var lib$rsvp$promise$all$$default = lib$rsvp$promise$all$$all;\n function lib$rsvp$promise$race$$race(entries, label) {\n /*jshint validthis:true */\n var Constructor = this;\n\n var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n\n if (!lib$rsvp$utils$$isArray(entries)) {\n lib$rsvp$$internal$$reject(promise, new TypeError('You must pass an array to race.'));\n return promise;\n }\n\n var length = entries.length;\n\n function onFulfillment(value) {\n lib$rsvp$$internal$$resolve(promise, value);\n }\n\n function onRejection(reason) {\n lib$rsvp$$internal$$reject(promise, reason);\n }\n\n for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n lib$rsvp$$internal$$subscribe(Constructor.resolve(entries[i]), undefined, onFulfillment, onRejection);\n }\n\n return promise;\n }\n var lib$rsvp$promise$race$$default = lib$rsvp$promise$race$$race;\n function lib$rsvp$promise$reject$$reject(reason, label) {\n /*jshint validthis:true */\n var Constructor = this;\n var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n lib$rsvp$$internal$$reject(promise, reason);\n return promise;\n }\n var lib$rsvp$promise$reject$$default = lib$rsvp$promise$reject$$reject;\n\n var lib$rsvp$promise$$guidKey = 'rsvp_' + lib$rsvp$utils$$now() + '-';\n var lib$rsvp$promise$$counter = 0;\n\n function lib$rsvp$promise$$needsResolver() {\n throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n }\n\n function lib$rsvp$promise$$needsNew() {\n throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n }\n\n function lib$rsvp$promise$$Promise(resolver, label) {\n this._id = lib$rsvp$promise$$counter++;\n this._label = label;\n this._state = undefined;\n this._result = undefined;\n this._subscribers = [];\n\n lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('created', this);\n\n if (lib$rsvp$$internal$$noop !== resolver) {\n typeof resolver !== 'function' && lib$rsvp$promise$$needsResolver();\n this instanceof lib$rsvp$promise$$Promise ? lib$rsvp$$internal$$initializePromise(this, resolver) : lib$rsvp$promise$$needsNew();\n }\n }\n\n var lib$rsvp$promise$$default = lib$rsvp$promise$$Promise;\n\n // deprecated\n lib$rsvp$promise$$Promise.cast = lib$rsvp$promise$resolve$$default;\n lib$rsvp$promise$$Promise.all = lib$rsvp$promise$all$$default;\n lib$rsvp$promise$$Promise.race = lib$rsvp$promise$race$$default;\n lib$rsvp$promise$$Promise.resolve = lib$rsvp$promise$resolve$$default;\n lib$rsvp$promise$$Promise.reject = lib$rsvp$promise$reject$$default;\n\n lib$rsvp$promise$$Promise.prototype = {\n constructor: lib$rsvp$promise$$Promise,\n\n _guidKey: lib$rsvp$promise$$guidKey,\n\n _onError: function (reason) {\n var promise = this;\n lib$rsvp$config$$config.after(function() {\n if (promise._onError) {\n lib$rsvp$config$$config['trigger']('error', reason, promise._label);\n }\n });\n },\n\n /**\n The primary way of interacting with a promise is through its `then` method,\n which registers callbacks to receive either a promise's eventual value or the\n reason why the promise cannot be fulfilled.\n\n ```js\n findUser().then(function(user){\n // user is available\n }, function(reason){\n // user is unavailable, and you are given the reason why\n });\n ```\n\n Chaining\n --------\n\n The return value of `then` is itself a promise. This second, 'downstream'\n promise is resolved with the return value of the first promise's fulfillment\n or rejection handler, or rejected if the handler throws an exception.\n\n ```js\n findUser().then(function (user) {\n return user.name;\n }, function (reason) {\n return 'default name';\n }).then(function (userName) {\n // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n // will be `'default name'`\n });\n\n findUser().then(function (user) {\n throw new Error('Found user, but still unhappy');\n }, function (reason) {\n throw new Error('`findUser` rejected and we're unhappy');\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n });\n ```\n If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n\n ```js\n findUser().then(function (user) {\n throw new PedagogicalException('Upstream error');\n }).then(function (value) {\n // never reached\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // The `PedgagocialException` is propagated all the way down to here\n });\n ```\n\n Assimilation\n ------------\n\n Sometimes the value you want to propagate to a downstream promise can only be\n retrieved asynchronously. This can be achieved by returning a promise in the\n fulfillment or rejection handler. The downstream promise will then be pending\n until the returned promise is settled. This is called *assimilation*.\n\n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // The user's comments are now available\n });\n ```\n\n If the assimliated promise rejects, then the downstream promise will also reject.\n\n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // If `findCommentsByAuthor` fulfills, we'll have the value here\n }, function (reason) {\n // If `findCommentsByAuthor` rejects, we'll have the reason here\n });\n ```\n\n Simple Example\n --------------\n\n Synchronous Example\n\n ```javascript\n var result;\n\n try {\n result = findResult();\n // success\n } catch(reason) {\n // failure\n }\n ```\n\n Errback Example\n\n ```js\n findResult(function(result, err){\n if (err) {\n // failure\n } else {\n // success\n }\n });\n ```\n\n Promise Example;\n\n ```javascript\n findResult().then(function(result){\n // success\n }, function(reason){\n // failure\n });\n ```\n\n Advanced Example\n --------------\n\n Synchronous Example\n\n ```javascript\n var author, books;\n\n try {\n author = findAuthor();\n books = findBooksByAuthor(author);\n // success\n } catch(reason) {\n // failure\n }\n ```\n\n Errback Example\n\n ```js\n\n function foundBooks(books) {\n\n }\n\n function failure(reason) {\n\n }\n\n findAuthor(function(author, err){\n if (err) {\n failure(err);\n // failure\n } else {\n try {\n findBoooksByAuthor(author, function(books, err) {\n if (err) {\n failure(err);\n } else {\n try {\n foundBooks(books);\n } catch(reason) {\n failure(reason);\n }\n }\n });\n } catch(error) {\n failure(err);\n }\n // success\n }\n });\n ```\n\n Promise Example;\n\n ```javascript\n findAuthor().\n then(findBooksByAuthor).\n then(function(books){\n // found books\n }).catch(function(reason){\n // something went wrong\n });\n ```\n\n @method then\n @param {Function} onFulfillment\n @param {Function} onRejection\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise}\n */\n then: lib$rsvp$then$$default,\n\n /**\n `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n as the catch block of a try/catch statement.\n\n ```js\n function findAuthor(){\n throw new Error('couldn't find that author');\n }\n\n // synchronous\n try {\n findAuthor();\n } catch(reason) {\n // something went wrong\n }\n\n // async with promises\n findAuthor().catch(function(reason){\n // something went wrong\n });\n ```\n\n @method catch\n @param {Function} onRejection\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise}\n */\n 'catch': function(onRejection, label) {\n return this.then(undefined, onRejection, label);\n },\n\n /**\n `finally` will be invoked regardless of the promise's fate just as native\n try/catch/finally behaves\n\n Synchronous example:\n\n ```js\n findAuthor() {\n if (Math.random() > 0.5) {\n throw new Error();\n }\n return new Author();\n }\n\n try {\n return findAuthor(); // succeed or fail\n } catch(error) {\n return findOtherAuther();\n } finally {\n // always runs\n // doesn't affect the return value\n }\n ```\n\n Asynchronous example:\n\n ```js\n findAuthor().catch(function(reason){\n return findOtherAuther();\n }).finally(function(){\n // author was either found, or not\n });\n ```\n\n @method finally\n @param {Function} callback\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise}\n */\n 'finally': function(callback, label) {\n var promise = this;\n var constructor = promise.constructor;\n\n return promise.then(function(value) {\n return constructor.resolve(callback()).then(function() {\n return value;\n });\n }, function(reason) {\n return constructor.resolve(callback()).then(function() {\n return constructor.reject(reason);\n });\n }, label);\n }\n };\n function lib$rsvp$$internal$$withOwnPromise() {\n return new TypeError('A promises callback cannot return that same promise.');\n }\n\n function lib$rsvp$$internal$$noop() {}\n\n var lib$rsvp$$internal$$PENDING = void 0;\n var lib$rsvp$$internal$$FULFILLED = 1;\n var lib$rsvp$$internal$$REJECTED = 2;\n\n var lib$rsvp$$internal$$GET_THEN_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n function lib$rsvp$$internal$$getThen(promise) {\n try {\n return promise.then;\n } catch(error) {\n lib$rsvp$$internal$$GET_THEN_ERROR.error = error;\n return lib$rsvp$$internal$$GET_THEN_ERROR;\n }\n }\n\n function lib$rsvp$$internal$$tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n try {\n then.call(value, fulfillmentHandler, rejectionHandler);\n } catch(e) {\n return e;\n }\n }\n\n function lib$rsvp$$internal$$handleForeignThenable(promise, thenable, then) {\n lib$rsvp$config$$config.async(function(promise) {\n var sealed = false;\n var error = lib$rsvp$$internal$$tryThen(then, thenable, function(value) {\n if (sealed) { return; }\n sealed = true;\n if (thenable !== value) {\n lib$rsvp$$internal$$resolve(promise, value, undefined);\n } else {\n lib$rsvp$$internal$$fulfill(promise, value);\n }\n }, function(reason) {\n if (sealed) { return; }\n sealed = true;\n\n lib$rsvp$$internal$$reject(promise, reason);\n }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n if (!sealed && error) {\n sealed = true;\n lib$rsvp$$internal$$reject(promise, error);\n }\n }, promise);\n }\n\n function lib$rsvp$$internal$$handleOwnThenable(promise, thenable) {\n if (thenable._state === lib$rsvp$$internal$$FULFILLED) {\n lib$rsvp$$internal$$fulfill(promise, thenable._result);\n } else if (thenable._state === lib$rsvp$$internal$$REJECTED) {\n thenable._onError = null;\n lib$rsvp$$internal$$reject(promise, thenable._result);\n } else {\n lib$rsvp$$internal$$subscribe(thenable, undefined, function(value) {\n if (thenable !== value) {\n lib$rsvp$$internal$$resolve(promise, value, undefined);\n } else {\n lib$rsvp$$internal$$fulfill(promise, value);\n }\n }, function(reason) {\n lib$rsvp$$internal$$reject(promise, reason);\n });\n }\n }\n\n function lib$rsvp$$internal$$handleMaybeThenable(promise, maybeThenable, then) {\n if (maybeThenable.constructor === promise.constructor &&\n then === lib$rsvp$then$$default &&\n constructor.resolve === lib$rsvp$promise$resolve$$default) {\n lib$rsvp$$internal$$handleOwnThenable(promise, maybeThenable);\n } else {\n if (then === lib$rsvp$$internal$$GET_THEN_ERROR) {\n lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$GET_THEN_ERROR.error);\n } else if (then === undefined) {\n lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n } else if (lib$rsvp$utils$$isFunction(then)) {\n lib$rsvp$$internal$$handleForeignThenable(promise, maybeThenable, then);\n } else {\n lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n }\n }\n }\n\n function lib$rsvp$$internal$$resolve(promise, value) {\n if (promise === value) {\n lib$rsvp$$internal$$fulfill(promise, value);\n } else if (lib$rsvp$utils$$objectOrFunction(value)) {\n lib$rsvp$$internal$$handleMaybeThenable(promise, value, lib$rsvp$$internal$$getThen(value));\n } else {\n lib$rsvp$$internal$$fulfill(promise, value);\n }\n }\n\n function lib$rsvp$$internal$$publishRejection(promise) {\n if (promise._onError) {\n promise._onError(promise._result);\n }\n\n lib$rsvp$$internal$$publish(promise);\n }\n\n function lib$rsvp$$internal$$fulfill(promise, value) {\n if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n\n promise._result = value;\n promise._state = lib$rsvp$$internal$$FULFILLED;\n\n if (promise._subscribers.length === 0) {\n if (lib$rsvp$config$$config.instrument) {\n lib$rsvp$instrument$$default('fulfilled', promise);\n }\n } else {\n lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, promise);\n }\n }\n\n function lib$rsvp$$internal$$reject(promise, reason) {\n if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n promise._state = lib$rsvp$$internal$$REJECTED;\n promise._result = reason;\n lib$rsvp$config$$config.async(lib$rsvp$$internal$$publishRejection, promise);\n }\n\n function lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection) {\n var subscribers = parent._subscribers;\n var length = subscribers.length;\n\n parent._onError = null;\n\n subscribers[length] = child;\n subscribers[length + lib$rsvp$$internal$$FULFILLED] = onFulfillment;\n subscribers[length + lib$rsvp$$internal$$REJECTED] = onRejection;\n\n if (length === 0 && parent._state) {\n lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, parent);\n }\n }\n\n function lib$rsvp$$internal$$publish(promise) {\n var subscribers = promise._subscribers;\n var settled = promise._state;\n\n if (lib$rsvp$config$$config.instrument) {\n lib$rsvp$instrument$$default(settled === lib$rsvp$$internal$$FULFILLED ? 'fulfilled' : 'rejected', promise);\n }\n\n if (subscribers.length === 0) { return; }\n\n var child, callback, detail = promise._result;\n\n for (var i = 0; i < subscribers.length; i += 3) {\n child = subscribers[i];\n callback = subscribers[i + settled];\n\n if (child) {\n lib$rsvp$$internal$$invokeCallback(settled, child, callback, detail);\n } else {\n callback(detail);\n }\n }\n\n promise._subscribers.length = 0;\n }\n\n function lib$rsvp$$internal$$ErrorObject() {\n this.error = null;\n }\n\n var lib$rsvp$$internal$$TRY_CATCH_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n function lib$rsvp$$internal$$tryCatch(callback, detail) {\n try {\n return callback(detail);\n } catch(e) {\n lib$rsvp$$internal$$TRY_CATCH_ERROR.error = e;\n return lib$rsvp$$internal$$TRY_CATCH_ERROR;\n }\n }\n\n function lib$rsvp$$internal$$invokeCallback(settled, promise, callback, detail) {\n var hasCallback = lib$rsvp$utils$$isFunction(callback),\n value, error, succeeded, failed;\n\n if (hasCallback) {\n value = lib$rsvp$$internal$$tryCatch(callback, detail);\n\n if (value === lib$rsvp$$internal$$TRY_CATCH_ERROR) {\n failed = true;\n error = value.error;\n value = null;\n } else {\n succeeded = true;\n }\n\n if (promise === value) {\n lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$withOwnPromise());\n return;\n }\n\n } else {\n value = detail;\n succeeded = true;\n }\n\n if (promise._state !== lib$rsvp$$internal$$PENDING) {\n // noop\n } else if (hasCallback && succeeded) {\n lib$rsvp$$internal$$resolve(promise, value);\n } else if (failed) {\n lib$rsvp$$internal$$reject(promise, error);\n } else if (settled === lib$rsvp$$internal$$FULFILLED) {\n lib$rsvp$$internal$$fulfill(promise, value);\n } else if (settled === lib$rsvp$$internal$$REJECTED) {\n lib$rsvp$$internal$$reject(promise, value);\n }\n }\n\n function lib$rsvp$$internal$$initializePromise(promise, resolver) {\n var resolved = false;\n try {\n resolver(function resolvePromise(value){\n if (resolved) { return; }\n resolved = true;\n lib$rsvp$$internal$$resolve(promise, value);\n }, function rejectPromise(reason) {\n if (resolved) { return; }\n resolved = true;\n lib$rsvp$$internal$$reject(promise, reason);\n });\n } catch(e) {\n lib$rsvp$$internal$$reject(promise, e);\n }\n }\n\n function lib$rsvp$all$settled$$AllSettled(Constructor, entries, label) {\n this._superConstructor(Constructor, entries, false /* don't abort on reject */, label);\n }\n\n lib$rsvp$all$settled$$AllSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n lib$rsvp$all$settled$$AllSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n lib$rsvp$all$settled$$AllSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n lib$rsvp$all$settled$$AllSettled.prototype._validationError = function() {\n return new Error('allSettled must be called with an array');\n };\n\n function lib$rsvp$all$settled$$allSettled(entries, label) {\n return new lib$rsvp$all$settled$$AllSettled(lib$rsvp$promise$$default, entries, label).promise;\n }\n var lib$rsvp$all$settled$$default = lib$rsvp$all$settled$$allSettled;\n function lib$rsvp$all$$all(array, label) {\n return lib$rsvp$promise$$default.all(array, label);\n }\n var lib$rsvp$all$$default = lib$rsvp$all$$all;\n var lib$rsvp$asap$$len = 0;\n var lib$rsvp$asap$$toString = {}.toString;\n var lib$rsvp$asap$$vertxNext;\n function lib$rsvp$asap$$asap(callback, arg) {\n lib$rsvp$asap$$queue[lib$rsvp$asap$$len] = callback;\n lib$rsvp$asap$$queue[lib$rsvp$asap$$len + 1] = arg;\n lib$rsvp$asap$$len += 2;\n if (lib$rsvp$asap$$len === 2) {\n // If len is 1, that means that we need to schedule an async flush.\n // If additional callbacks are queued before the queue is flushed, they\n // will be processed by this flush that we are scheduling.\n lib$rsvp$asap$$scheduleFlush();\n }\n }\n\n var lib$rsvp$asap$$default = lib$rsvp$asap$$asap;\n\n var lib$rsvp$asap$$browserWindow = (typeof window !== 'undefined') ? window : undefined;\n var lib$rsvp$asap$$browserGlobal = lib$rsvp$asap$$browserWindow || {};\n var lib$rsvp$asap$$BrowserMutationObserver = lib$rsvp$asap$$browserGlobal.MutationObserver || lib$rsvp$asap$$browserGlobal.WebKitMutationObserver;\n var lib$rsvp$asap$$isNode = typeof self === 'undefined' &&\n typeof process !== 'undefined' && {}.toString.call(process) === '[object process]';\n\n // test for web worker but not in IE10\n var lib$rsvp$asap$$isWorker = typeof Uint8ClampedArray !== 'undefined' &&\n typeof importScripts !== 'undefined' &&\n typeof MessageChannel !== 'undefined';\n\n // node\n function lib$rsvp$asap$$useNextTick() {\n var nextTick = process.nextTick;\n // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n // setImmediate should be used instead instead\n var version = process.versions.node.match(/^(?:(\\d+)\\.)?(?:(\\d+)\\.)?(\\*|\\d+)$/);\n if (Array.isArray(version) && version[1] === '0' && version[2] === '10') {\n nextTick = setImmediate;\n }\n return function() {\n nextTick(lib$rsvp$asap$$flush);\n };\n }\n\n // vertx\n function lib$rsvp$asap$$useVertxTimer() {\n return function() {\n lib$rsvp$asap$$vertxNext(lib$rsvp$asap$$flush);\n };\n }\n\n function lib$rsvp$asap$$useMutationObserver() {\n var iterations = 0;\n var observer = new lib$rsvp$asap$$BrowserMutationObserver(lib$rsvp$asap$$flush);\n var node = document.createTextNode('');\n observer.observe(node, { characterData: true });\n\n return function() {\n node.data = (iterations = ++iterations % 2);\n };\n }\n\n // web worker\n function lib$rsvp$asap$$useMessageChannel() {\n var channel = new MessageChannel();\n channel.port1.onmessage = lib$rsvp$asap$$flush;\n return function () {\n channel.port2.postMessage(0);\n };\n }\n\n function lib$rsvp$asap$$useSetTimeout() {\n return function() {\n setTimeout(lib$rsvp$asap$$flush, 1);\n };\n }\n\n var lib$rsvp$asap$$queue = new Array(1000);\n function lib$rsvp$asap$$flush() {\n for (var i = 0; i < lib$rsvp$asap$$len; i+=2) {\n var callback = lib$rsvp$asap$$queue[i];\n var arg = lib$rsvp$asap$$queue[i+1];\n\n callback(arg);\n\n lib$rsvp$asap$$queue[i] = undefined;\n lib$rsvp$asap$$queue[i+1] = undefined;\n }\n\n lib$rsvp$asap$$len = 0;\n }\n\n function lib$rsvp$asap$$attemptVertex() {\n try {\n var r = require;\n var vertx = r('vertx');\n lib$rsvp$asap$$vertxNext = vertx.runOnLoop || vertx.runOnContext;\n return lib$rsvp$asap$$useVertxTimer();\n } catch(e) {\n return lib$rsvp$asap$$useSetTimeout();\n }\n }\n\n var lib$rsvp$asap$$scheduleFlush;\n // Decide what async method to use to triggering processing of queued callbacks:\n if (lib$rsvp$asap$$isNode) {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useNextTick();\n } else if (lib$rsvp$asap$$BrowserMutationObserver) {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMutationObserver();\n } else if (lib$rsvp$asap$$isWorker) {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMessageChannel();\n } else if (lib$rsvp$asap$$browserWindow === undefined && typeof require === 'function') {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$attemptVertex();\n } else {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useSetTimeout();\n }\n function lib$rsvp$defer$$defer(label) {\n var deferred = {};\n\n deferred['promise'] = new lib$rsvp$promise$$default(function(resolve, reject) {\n deferred['resolve'] = resolve;\n deferred['reject'] = reject;\n }, label);\n\n return deferred;\n }\n var lib$rsvp$defer$$default = lib$rsvp$defer$$defer;\n function lib$rsvp$filter$$filter(promises, filterFn, label) {\n return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n if (!lib$rsvp$utils$$isFunction(filterFn)) {\n throw new TypeError(\"You must pass a function as filter's second argument.\");\n }\n\n var length = values.length;\n var filtered = new Array(length);\n\n for (var i = 0; i < length; i++) {\n filtered[i] = filterFn(values[i]);\n }\n\n return lib$rsvp$promise$$default.all(filtered, label).then(function(filtered) {\n var results = new Array(length);\n var newLength = 0;\n\n for (var i = 0; i < length; i++) {\n if (filtered[i]) {\n results[newLength] = values[i];\n newLength++;\n }\n }\n\n results.length = newLength;\n\n return results;\n });\n });\n }\n var lib$rsvp$filter$$default = lib$rsvp$filter$$filter;\n\n function lib$rsvp$promise$hash$$PromiseHash(Constructor, object, label) {\n this._superConstructor(Constructor, object, true, label);\n }\n\n var lib$rsvp$promise$hash$$default = lib$rsvp$promise$hash$$PromiseHash;\n\n lib$rsvp$promise$hash$$PromiseHash.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n lib$rsvp$promise$hash$$PromiseHash.prototype._superConstructor = lib$rsvp$enumerator$$default;\n lib$rsvp$promise$hash$$PromiseHash.prototype._init = function() {\n this._result = {};\n };\n\n lib$rsvp$promise$hash$$PromiseHash.prototype._validateInput = function(input) {\n return input && typeof input === 'object';\n };\n\n lib$rsvp$promise$hash$$PromiseHash.prototype._validationError = function() {\n return new Error('Promise.hash must be called with an object');\n };\n\n lib$rsvp$promise$hash$$PromiseHash.prototype._enumerate = function() {\n var enumerator = this;\n var promise = enumerator.promise;\n var input = enumerator._input;\n var results = [];\n\n for (var key in input) {\n if (promise._state === lib$rsvp$$internal$$PENDING && Object.prototype.hasOwnProperty.call(input, key)) {\n results.push({\n position: key,\n entry: input[key]\n });\n }\n }\n\n var length = results.length;\n enumerator._remaining = length;\n var result;\n\n for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n result = results[i];\n enumerator._eachEntry(result.entry, result.position);\n }\n };\n\n function lib$rsvp$hash$settled$$HashSettled(Constructor, object, label) {\n this._superConstructor(Constructor, object, false, label);\n }\n\n lib$rsvp$hash$settled$$HashSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$promise$hash$$default.prototype);\n lib$rsvp$hash$settled$$HashSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n lib$rsvp$hash$settled$$HashSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n\n lib$rsvp$hash$settled$$HashSettled.prototype._validationError = function() {\n return new Error('hashSettled must be called with an object');\n };\n\n function lib$rsvp$hash$settled$$hashSettled(object, label) {\n return new lib$rsvp$hash$settled$$HashSettled(lib$rsvp$promise$$default, object, label).promise;\n }\n var lib$rsvp$hash$settled$$default = lib$rsvp$hash$settled$$hashSettled;\n function lib$rsvp$hash$$hash(object, label) {\n return new lib$rsvp$promise$hash$$default(lib$rsvp$promise$$default, object, label).promise;\n }\n var lib$rsvp$hash$$default = lib$rsvp$hash$$hash;\n function lib$rsvp$map$$map(promises, mapFn, label) {\n return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n if (!lib$rsvp$utils$$isFunction(mapFn)) {\n throw new TypeError(\"You must pass a function as map's second argument.\");\n }\n\n var length = values.length;\n var results = new Array(length);\n\n for (var i = 0; i < length; i++) {\n results[i] = mapFn(values[i]);\n }\n\n return lib$rsvp$promise$$default.all(results, label);\n });\n }\n var lib$rsvp$map$$default = lib$rsvp$map$$map;\n\n function lib$rsvp$node$$Result() {\n this.value = undefined;\n }\n\n var lib$rsvp$node$$ERROR = new lib$rsvp$node$$Result();\n var lib$rsvp$node$$GET_THEN_ERROR = new lib$rsvp$node$$Result();\n\n function lib$rsvp$node$$getThen(obj) {\n try {\n return obj.then;\n } catch(error) {\n lib$rsvp$node$$ERROR.value= error;\n return lib$rsvp$node$$ERROR;\n }\n }\n\n\n function lib$rsvp$node$$tryApply(f, s, a) {\n try {\n f.apply(s, a);\n } catch(error) {\n lib$rsvp$node$$ERROR.value = error;\n return lib$rsvp$node$$ERROR;\n }\n }\n\n function lib$rsvp$node$$makeObject(_, argumentNames) {\n var obj = {};\n var name;\n var i;\n var length = _.length;\n var args = new Array(length);\n\n for (var x = 0; x < length; x++) {\n args[x] = _[x];\n }\n\n for (i = 0; i < argumentNames.length; i++) {\n name = argumentNames[i];\n obj[name] = args[i + 1];\n }\n\n return obj;\n }\n\n function lib$rsvp$node$$arrayResult(_) {\n var length = _.length;\n var args = new Array(length - 1);\n\n for (var i = 1; i < length; i++) {\n args[i - 1] = _[i];\n }\n\n return args;\n }\n\n function lib$rsvp$node$$wrapThenable(then, promise) {\n return {\n then: function(onFulFillment, onRejection) {\n return then.call(promise, onFulFillment, onRejection);\n }\n };\n }\n\n function lib$rsvp$node$$denodeify(nodeFunc, options) {\n var fn = function() {\n var self = this;\n var l = arguments.length;\n var args = new Array(l + 1);\n var arg;\n var promiseInput = false;\n\n for (var i = 0; i < l; ++i) {\n arg = arguments[i];\n\n if (!promiseInput) {\n // TODO: clean this up\n promiseInput = lib$rsvp$node$$needsPromiseInput(arg);\n if (promiseInput === lib$rsvp$node$$GET_THEN_ERROR) {\n var p = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n lib$rsvp$$internal$$reject(p, lib$rsvp$node$$GET_THEN_ERROR.value);\n return p;\n } else if (promiseInput && promiseInput !== true) {\n arg = lib$rsvp$node$$wrapThenable(promiseInput, arg);\n }\n }\n args[i] = arg;\n }\n\n var promise = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n\n args[l] = function(err, val) {\n if (err)\n lib$rsvp$$internal$$reject(promise, err);\n else if (options === undefined)\n lib$rsvp$$internal$$resolve(promise, val);\n else if (options === true)\n lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$arrayResult(arguments));\n else if (lib$rsvp$utils$$isArray(options))\n lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$makeObject(arguments, options));\n else\n lib$rsvp$$internal$$resolve(promise, val);\n };\n\n if (promiseInput) {\n return lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self);\n } else {\n return lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self);\n }\n };\n\n fn.__proto__ = nodeFunc;\n\n return fn;\n }\n\n var lib$rsvp$node$$default = lib$rsvp$node$$denodeify;\n\n function lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self) {\n var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n if (result === lib$rsvp$node$$ERROR) {\n lib$rsvp$$internal$$reject(promise, result.value);\n }\n return promise;\n }\n\n function lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self){\n return lib$rsvp$promise$$default.all(args).then(function(args){\n var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n if (result === lib$rsvp$node$$ERROR) {\n lib$rsvp$$internal$$reject(promise, result.value);\n }\n return promise;\n });\n }\n\n function lib$rsvp$node$$needsPromiseInput(arg) {\n if (arg && typeof arg === 'object') {\n if (arg.constructor === lib$rsvp$promise$$default) {\n return true;\n } else {\n return lib$rsvp$node$$getThen(arg);\n }\n } else {\n return false;\n }\n }\n var lib$rsvp$platform$$platform;\n\n /* global self */\n if (typeof self === 'object') {\n lib$rsvp$platform$$platform = self;\n\n /* global global */\n } else if (typeof global === 'object') {\n lib$rsvp$platform$$platform = global;\n } else {\n throw new Error('no global: `self` or `global` found');\n }\n\n var lib$rsvp$platform$$default = lib$rsvp$platform$$platform;\n function lib$rsvp$race$$race(array, label) {\n return lib$rsvp$promise$$default.race(array, label);\n }\n var lib$rsvp$race$$default = lib$rsvp$race$$race;\n function lib$rsvp$reject$$reject(reason, label) {\n return lib$rsvp$promise$$default.reject(reason, label);\n }\n var lib$rsvp$reject$$default = lib$rsvp$reject$$reject;\n function lib$rsvp$resolve$$resolve(value, label) {\n return lib$rsvp$promise$$default.resolve(value, label);\n }\n var lib$rsvp$resolve$$default = lib$rsvp$resolve$$resolve;\n function lib$rsvp$rethrow$$rethrow(reason) {\n setTimeout(function() {\n throw reason;\n });\n throw reason;\n }\n var lib$rsvp$rethrow$$default = lib$rsvp$rethrow$$rethrow;\n\n // defaults\n lib$rsvp$config$$config.async = lib$rsvp$asap$$default;\n lib$rsvp$config$$config.after = function(cb) {\n setTimeout(cb, 0);\n };\n var lib$rsvp$$cast = lib$rsvp$resolve$$default;\n function lib$rsvp$$async(callback, arg) {\n lib$rsvp$config$$config.async(callback, arg);\n }\n\n function lib$rsvp$$on() {\n lib$rsvp$config$$config['on'].apply(lib$rsvp$config$$config, arguments);\n }\n\n function lib$rsvp$$off() {\n lib$rsvp$config$$config['off'].apply(lib$rsvp$config$$config, arguments);\n }\n\n // Set up instrumentation through `window.__PROMISE_INTRUMENTATION__`\n if (typeof window !== 'undefined' && typeof window['__PROMISE_INSTRUMENTATION__'] === 'object') {\n var lib$rsvp$$callbacks = window['__PROMISE_INSTRUMENTATION__'];\n lib$rsvp$config$$configure('instrument', true);\n for (var lib$rsvp$$eventName in lib$rsvp$$callbacks) {\n if (lib$rsvp$$callbacks.hasOwnProperty(lib$rsvp$$eventName)) {\n lib$rsvp$$on(lib$rsvp$$eventName, lib$rsvp$$callbacks[lib$rsvp$$eventName]);\n }\n }\n }\n\n var lib$rsvp$umd$$RSVP = {\n 'race': lib$rsvp$race$$default,\n 'Promise': lib$rsvp$promise$$default,\n 'allSettled': lib$rsvp$all$settled$$default,\n 'hash': lib$rsvp$hash$$default,\n 'hashSettled': lib$rsvp$hash$settled$$default,\n 'denodeify': lib$rsvp$node$$default,\n 'on': lib$rsvp$$on,\n 'off': lib$rsvp$$off,\n 'map': lib$rsvp$map$$default,\n 'filter': lib$rsvp$filter$$default,\n 'resolve': lib$rsvp$resolve$$default,\n 'reject': lib$rsvp$reject$$default,\n 'all': lib$rsvp$all$$default,\n 'rethrow': lib$rsvp$rethrow$$default,\n 'defer': lib$rsvp$defer$$default,\n 'EventTarget': lib$rsvp$events$$default,\n 'configure': lib$rsvp$config$$configure,\n 'async': lib$rsvp$$async\n };\n\n /* global define:true module:true window: true */\n if (typeof define === 'function' && define['amd']) {\n define(function() { return lib$rsvp$umd$$RSVP; });\n } else if (typeof module !== 'undefined' && module['exports']) {\n module['exports'] = lib$rsvp$umd$$RSVP;\n } else if (typeof lib$rsvp$platform$$default !== 'undefined') {\n lib$rsvp$platform$$default['RSVP'] = lib$rsvp$umd$$RSVP;\n }\n}).call(this);\n\n\n}).call(this,require('_process'),typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n\n},{\"_process\":71}]},{},[29])\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","js/app/cache.js","js/app/constructor.js","js/app/index.js","js/dom/add_categories.js","js/dom/add_files.js","js/dom/index.js","js/dom/loading_slider.js","js/dom/module_container.js","js/dom/setup/index.js","js/dom/setup/setup_dividers.js","js/dom/setup/setup_document.js","js/dom/setup/setup_files_bar.js","js/dom/setup/setup_interval.js","js/dom/setup/setup_module_container.js","js/dom/setup/setup_side_menu.js","js/dom/setup/setup_tab_container.js","js/dom/setup/setup_top_menu.js","js/dom/setup/setup_window.js","js/dom/show_algorithm.js","js/dom/show_description.js","js/dom/show_first_algorithm.js","js/dom/show_requested_algorithm.js","js/dom/show_wiki.js","js/dom/toast.js","js/dom/top_menu.js","js/editor/create.js","js/editor/executor.js","js/editor/index.js","js/index.js","js/module/data/array1d.js","js/module/data/array2d.js","js/module/data/coordinate_system.js","js/module/data/directed_graph.js","js/module/data/index.js","js/module/data/integer.js","js/module/data/undirected_graph.js","js/module/data/weighted_directed_graph.js","js/module/data/weighted_undirected_graph.js","js/module/index.js","js/module/tracer/array1d.js","js/module/tracer/array2d.js","js/module/tracer/chart.js","js/module/tracer/coordinate_system.js","js/module/tracer/directed_graph.js","js/module/tracer/index.js","js/module/tracer/log.js","js/module/tracer/tracer.js","js/module/tracer/undirected_graph.js","js/module/tracer/weighted_directed_graph.js","js/module/tracer/weighted_undirected_graph.js","js/server/ajax/get.js","js/server/ajax/get_json.js","js/server/ajax/post_json.js","js/server/ajax/request.js","js/server/helpers.js","js/server/index.js","js/server/load_algorithm.js","js/server/load_categories.js","js/server/load_file.js","js/server/load_scratch_paper.js","js/server/load_wiki.js","js/server/load_wiki_list.js","js/server/share_scratch_paper.js","js/tracer_manager/index.js","js/tracer_manager/manager.js","js/tracer_manager/util/from_json.js","js/tracer_manager/util/index.js","js/tracer_manager/util/refine_by_type.js","js/tracer_manager/util/to_json.js","js/utils/index.js","node_modules/process/browser.js","node_modules/rsvp/dist/rsvp.js"],"names":[],"mappings":"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lB,eAAkB,CAAC,QAAD,EAAW,SAAX,EAAyB;AAC/C,MAAI,eAAe,QAAf,CAAJ,EAA8B,OAAO,4BAAP;AAC9B,0BAAsB,QAAtB,SAAkC,SAAlC;AACD,CAHD;;AAKA,IAAM,aAAa,SAAb,UAAa,CAAC,QAAD,EAAW,SAAX,EAAsB,IAAtB,EAA+B;AAChD,MAAI,eAAe,QAAf,CAAJ,EAA8B,OAAO,4BAAP;AAC9B,0BAAsB,QAAtB,SAAkC,SAAlC,SAA+C,IAA/C;AACD,CAHD;;AAKA,OAAO,OAAP,GAAiB;AACf,gCADe;AAEf,kCAFe;AAGf;AAHe,CAAjB;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC9FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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})","'use strict';\n\nconst {\n  extend\n} = $;\n\nconst cache = {\n  lastFileUsed: '',\n  files: {}\n};\n\nconst assertFileName = (name) => {\n  if (!name) {\n    throw 'Missing file name';\n  }\n};\n\n\n/**\n * Global application cache\n */\nmodule.exports = {\n\n  getCachedFile(name) {\n    assertFileName(name);\n    return cache.files[name];\n  },\n\n  updateCachedFile(name, updates) {\n    assertFileName(name);\n    if (!cache.files[name]) {\n      cache.files[name] = {};\n    }\n    extend(cache.files[name], updates);\n  },\n\n  getLastFileUsed() {\n    return cache.lastFileUsed;\n  },\n\n  setLastFileUsed(file) {\n    cache.lastFileUsed = file;\n  }\n};","'use strict';\n\nconst Editor = require('../editor');\nconst TracerManager = require('../tracer_manager');\nconst DOM = require('../dom/setup');\n\nconst {\n  showLoadingSlider,\n  hideLoadingSlider\n} = require('../dom/loading_slider');\n\nconst Cache = require('./cache');\n\nconst state = {\n  isLoading: null,\n  editor: null,\n  tracerManager: null,\n  categories: null,\n  loadedScratch: null,\n  wikiList: null\n};\n\nconst initState = (tracerManager) => {\n  state.isLoading = false;\n  state.editor = new Editor(tracerManager);\n  state.tracerManager = tracerManager;\n  state.categories = {};\n  state.loadedScratch = null;\n  state.wikiList = [];\n};\n\n/**\n * Global application singleton.\n */\nconst App = function () {\n\n  this.getIsLoading = () => {\n    return state.isLoading;\n  };\n\n  this.setIsLoading = (loading) => {\n    state.isLoading = loading;\n    if (loading) {\n      showLoadingSlider();\n    } else {\n      hideLoadingSlider();\n    }\n  };\n\n  this.getEditor = () => {\n    return state.editor;\n  };\n\n  this.getCategories = () => {\n    return state.categories;\n  };\n\n  this.getCategory = (name) => {\n    return state.categories[name];\n  };\n\n  this.setCategories = (categories) => {\n    state.categories = categories;\n  };\n\n  this.updateCategory = (name, updates) => {\n    $.extend(state.categories[name], updates);\n  };\n\n  this.getTracerManager = () => {\n    return state.tracerManager;\n  };\n\n  this.getLoadedScratch = () => {\n    return state.loadedScratch;\n  };\n\n  this.setLoadedScratch = (loadedScratch) => {\n    state.loadedScratch = loadedScratch;\n  };\n\n  this.getWikiList = () => {\n    return state.wikiList;\n  };\n\n  this.setWikiList = (wikiList) => {\n    state.wikiList = wikiList;\n  };\n\n  this.hasWiki = (wiki) => {\n    return ~state.wikiList.indexOf(wiki);\n  };\n\n  const tracerManager = TracerManager.init();\n\n  initState(tracerManager);\n  DOM.setup(tracerManager);\n\n};\n\nApp.prototype = Cache;\n\nmodule.exports = App;\n","'use strict';\n\n/**\n * This is the main application instance.\n * Gets populated on page load. \n */\nmodule.exports = {};","'use strict';\n\nconst app = require('../app');\nconst Server = require('../server');\nconst showAlgorithm = require('./show_algorithm');\n\nconst {\n  each\n} = $;\n\nconst getAlgorithmDOM = (category, subList, algorithm) => {\n  return $('<button class=\"indent\">')\n    .append(subList[algorithm])\n    .attr('data-algorithm', algorithm)\n    .attr('data-category', category)\n    .click(function () {\n      Server.loadAlgorithm(category, algorithm).then((data) => {\n        showAlgorithm(category, algorithm, data);\n      });\n    });\n\n  $('#list').append($algorithm);\n};\n\nconst addCategoryToDOM = (category) => {\n\n  const {\n    name: categoryName,\n    list: categorySubList\n  } = app.getCategory(category);\n\n  const $category = $('<button class=\"category\">')\n    .append('<i class=\"fa fa-fw fa-caret-right\">')\n    .append(categoryName)\n    .attr('data-category', category);\n\n  $category.click(function () {\n    const $self = $(this);\n    $self.toggleClass('open');\n    $self.next().toggleClass('collapse');\n    $self.find('i.fa').toggleClass('fa-caret-right fa-caret-down');\n  });\n\n  const $algorithms = $('<div class=\"algorithms collapse\">');\n  $('#list').append($category).append($algorithms);\n\n  each(categorySubList, (algorithm) => {\n    const $algorithm = getAlgorithmDOM(category, categorySubList, algorithm);\n    $algorithms.append($algorithm);\n  });\n};\n\nmodule.exports = () => {\n  each(app.getCategories(), addCategoryToDOM);\n};\n","'use strict';\n\nconst Server = require('../server');\n\nconst {\n  each\n} = $;\n\nconst addFileToDOM = (category, algorithm, file, explanation) => {\n  var $file = $('<button>')\n    .append(file)\n    .attr('data-file', file)\n    .click(function () {\n      Server.loadFile(category, algorithm, file, explanation);\n      $('.files_bar > .wrapper > button').removeClass('active');\n      $(this).addClass('active');\n    });\n  $('.files_bar > .wrapper').append($file);\n  return $file;\n};\n\nmodule.exports = (category, algorithm, files, requestedFile) => {\n  $('.files_bar > .wrapper').empty();\n\n  each(files, (file, explanation) => {\n    var $file = addFileToDOM(category, algorithm, file, explanation);\n    if (requestedFile && requestedFile == file) $file.click();\n  });\n\n  if (!requestedFile) $('.files_bar > .wrapper > button').first().click();\n  $('.files_bar > .wrapper').scroll();\n};","'use strict';\n\nconst showAlgorithm = require('./show_algorithm');\nconst addCategories = require('./add_categories');\nconst showDescription = require('./show_description');\nconst addFiles = require('./add_files');\nconst showFirstAlgorithm = require('./show_first_algorithm');\nconst showRequestedAlgorithm = require('./show_requested_algorithm');\nconst showWiki = require('./show_wiki');\n\nmodule.exports = {\n  showAlgorithm,\n  addCategories,\n  showDescription,\n  addFiles,\n  showFirstAlgorithm,\n  showRequestedAlgorithm,\n  showWiki\n};","'use strict';\n\nconst showLoadingSlider = () => {\n  $('#loading-slider').removeClass('loaded');\n};\n\nconst hideLoadingSlider = () => {\n  $('#loading-slider').addClass('loaded');\n};\n\nmodule.exports = {\n  showLoadingSlider,\n  hideLoadingSlider\n};\n","'use strict';\n\nconst create = () => {\n  const $container = $('<section class=\"module_wrapper\">');\n  $('.module_container').append($container);\n  return $container;\n};\n\nmodule.exports = {\n  create\n};\n","'use strict';\n\nconst setupDividers = require('./setup_dividers');\nconst setupDocument = require('./setup_document');\nconst setupFilesBar = require('./setup_files_bar');\nconst setupInterval = require('./setup_interval');\nconst setupModuleContainer = require('./setup_module_container');\nconst setupTabContainer = require('./setup_tab_container');\nconst setupSideMenu = require('./setup_side_menu');\nconst setupTopMenu = require('./setup_top_menu');\nconst setupWindow = require('./setup_window');\n\n/**\n * Initializes elements once the app loads in the DOM.\n */\nconst setup = () => {\n\n  $('.btn input').click((e) => {\n    e.stopPropagation();\n  });\n\n  // dividers\n  setupDividers();\n\n  // document\n  setupDocument();\n\n  // files bar\n  setupFilesBar();\n\n  // interval\n  setupInterval();\n\n  // module container\n  setupModuleContainer();\n\n  // tab container\n  setupTabContainer();\n\n  // side menu\n  setupSideMenu();\n\n  // top menu\n  setupTopMenu();\n\n  // window\n  setupWindow();\n\n};\n\nmodule.exports = {\n  setup\n};\n","'use strict';\n\nconst app = require('../../app');\n\nconst addDividerToDom = (divider) => {\n  const [vertical, $first, $second] = divider;\n  const $parent = $first.parent();\n  const thickness = 5;\n\n  const $divider = $('<div class=\"divider\">');\n\n  let dragging = false;\n  if (vertical) {\n    $divider.addClass('vertical');\n\n    let _left = -thickness / 2;\n    $divider.css({\n      top: 0,\n      bottom: 0,\n      left: _left,\n      width: thickness\n    });\n\n    let x;\n    $divider.mousedown(({\n      pageX\n    }) => {\n      x = pageX;\n      dragging = true;\n    });\n\n    $(document).mousemove(({\n      pageX\n    }) => {\n      if (dragging) {\n        const new_left = $second.position().left + pageX - x;\n        let percent = new_left / $parent.width() * 100;\n        percent = Math.min(90, Math.max(10, percent));\n        $first.css('right', (100 - percent) + '%');\n        $second.css('left', percent + '%');\n        x = pageX;\n        app.getTracerManager().resize();\n        $('.files_bar > .wrapper').scroll();\n      }\n    });\n\n    $(document).mouseup(function(e) {\n      dragging = false;\n    });\n\n  } else {\n\n    $divider.addClass('horizontal');\n    const _top = -thickness / 2;\n    $divider.css({\n      top: _top,\n      height: thickness,\n      left: 0,\n      right: 0\n    });\n\n    let y;\n    $divider.mousedown(function({\n      pageY\n    }) {\n      y = pageY;\n      dragging = true;\n    });\n\n    $(document).mousemove(function({\n      pageY\n    }) {\n      if (dragging) {\n        const new_top = $second.position().top + pageY - y;\n        let percent = new_top / $parent.height() * 100;\n        percent = Math.min(90, Math.max(10, percent));\n        $first.css('bottom', (100 - percent) + '%');\n        $second.css('top', percent + '%');\n        y = pageY;\n        app.getTracerManager().resize();\n      }\n    });\n\n    $(document).mouseup(function(e) {\n      dragging = false;\n    });\n  }\n\n  $second.append($divider);\n};\n\nmodule.exports = () => {\n  const dividers = [\n    ['v', $('.sidemenu'), $('.workspace')],\n    ['v', $('.viewer_container'), $('.editor_container')],\n    ['h', $('.data_container'), $('.code_container')]\n  ];\n  for (let i = 0; i < dividers.length; i++) {\n    addDividerToDom(dividers[i]);\n  }\n};","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = () => {\n  $(document).on('click', 'a', function (e) {\n    const href = $(this).attr('href');\n    if (/^(https?:\\/\\/).+/.test(href)) {\n      e.preventDefault();\n      if (!window.open(href, '_blank')) {\n        alert('Please allow popups for this site');\n      }\n    }\n  });\n\n  $(document).mouseup(function (e) {\n    app.getTracerManager().command('mouseup', e);\n  });\n};\n","'use strict';\n\nconst definitelyBigger = (x, y) => x > (y + 2);\n\nmodule.exports = () => {\n\n  $('.files_bar > .btn-left').click(() => {\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const scrollLeft = $wrapper.scrollLeft();\n\n    $($wrapper.children('button').get().reverse()).each(function() {\n      const left = $(this).position().left;\n      const right = left + $(this).outerWidth();\n      if (0 > left) {\n        $wrapper.scrollLeft(scrollLeft + right - clipWidth);\n        return false;\n      }\n    });\n  });\n\n  $('.files_bar > .btn-right').click(() => {\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const scrollLeft = $wrapper.scrollLeft();\n\n    $wrapper.children('button').each(function() {\n      const left = $(this).position().left;\n      const right = left + $(this).outerWidth();\n      if (clipWidth < right) {\n        $wrapper.scrollLeft(scrollLeft + left);\n        return false;\n      }\n    });\n  });\n\n  $('.files_bar > .wrapper').scroll(function() {\n\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const $left = $wrapper.children('button:first-child');\n    const $right = $wrapper.children('button:last-child');\n    const left = $left.position().left;\n    const right = $right.position().left + $right.outerWidth();\n\n    if (definitelyBigger(0, left) && definitelyBigger(clipWidth, right)) {\n      const scrollLeft = $wrapper.scrollLeft();\n      $wrapper.scrollLeft(scrollLeft + clipWidth - right);\n      return;\n    }\n\n    const lefter = definitelyBigger(0, left);\n    const righter = definitelyBigger(right, clipWidth);\n    $wrapper.toggleClass('shadow-left', lefter);\n    $wrapper.toggleClass('shadow-right', righter);\n    $('.files_bar > .btn-left').attr('disabled', !lefter);\n    $('.files_bar > .btn-right').attr('disabled', !righter);\n  });\n}\n","'use strict';\n\nconst app = require('../../app');\nconst Toast = require('../toast');\n\nconst {\n  parseFloat\n} = Number;\n\nconst minInterval = 0.1;\nconst maxInterval = 10;\nconst startInterval = 0.5;\nconst stepInterval = 0.1;\n\nconst normalize = (sec) => {\n\n\n  let interval;\n  let message;\n  if (sec < minInterval) {\n    interval = minInterval;\n    message = `Interval of ${sec} seconds is too low. Setting to min allowed interval of ${minInterval} second(s).`;\n  } else if (sec > maxInterval) {\n    interval = maxInterval;\n    message = `Interval of ${sec} seconds is too high. Setting to max allowed interval of ${maxInterval} second(s).`;\n  } else {\n    interval = sec;\n    message = `Interval has been set to ${sec} second(s).`\n  }\n\n  return [interval, message];\n};\n\nmodule.exports = () => {\n\n  const $interval = $('#interval');\n  $interval.val(startInterval);\n  $interval.attr({\n    max: maxInterval,\n    min: minInterval,\n    step: stepInterval\n  });\n\n  $('#interval').on('change', function() {\n    const tracerManager = app.getTracerManager();\n    const [seconds, message] = normalize(parseFloat($(this).val()));\n\n    $(this).val(seconds);\n    tracerManager.interval = seconds * 1000;\n    Toast.showInfoToast(message);\n  });\n};\n","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = () => {\n\n  const $module_container = $('.module_container');\n\n  $module_container.on('mousedown', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousedown(e);\n  });\n\n  $module_container.on('mousemove', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousemove(e);\n  });\n\n  $module_container.on('DOMMouseScroll mousewheel', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousewheel(e);\n  });\n}\n","'use strict';\n\nconst app = require('../../app');\nconst Server = require('../../server');\nconst showAlgorithm = require('../show_algorithm');\n\nlet sidemenu_percent;\n\nmodule.exports = () => {\n  $('#navigation').click(() => {\n    const $sidemenu = $('.sidemenu');\n    const $workspace = $('.workspace');\n\n    $sidemenu.toggleClass('active');\n    $('.nav-dropdown').toggleClass('fa-caret-down fa-caret-up');\n\n    if ($sidemenu.hasClass('active')) {\n      $sidemenu.css('right', (100 - sidemenu_percent) + '%');\n      $workspace.css('left', sidemenu_percent + '%');\n\n    } else {\n      sidemenu_percent = $workspace.position().left / $('body').width() * 100;\n      $sidemenu.css('right', 0);\n      $workspace.css('left', 0);\n    }\n\n    app.getTracerManager().resize();\n  });\n\n  $('#documentation').click(function () {\n    $('#btn_doc').click();\n  });\n\n  $('#powered-by').click(() => {\n    $('#powered-by-list button').toggleClass('collapse');\n  });\n\n  $('#scratch-paper').click(() => {\n    const category = 'scratch';\n    const algorithm = app.getLoadedScratch();\n    Server.loadAlgorithm(category, algorithm).then((data) => {\n      showAlgorithm(category, algorithm, data);\n    });\n  });\n};","'use strict';\n\nmodule.exports = () => {\n  $('.tab_bar > button').click(function () {\n    $('.tab_bar > button').removeClass('active');\n    $('.tab_container > .tab').removeClass('active');\n    $(this).addClass('active');\n    $($(this).attr('data-target')).addClass('active');\n  });\n};","'use strict';\n\nconst app = require('../../app');\nconst Server = require('../../server');\nconst Toast = require('../toast');\nconst TopMenu = require('../top_menu');\n\nmodule.exports = () => {\n\n  // shared\n  $('#shared').mouseup(function () {\n    $(this).select();\n  });\n\n  $('#btn_share').click(function () {\n\n    const $icon = $(this).find('.fa-share');\n    $icon.addClass('fa-spin fa-spin-faster');\n\n    Server.shareScratchPaper().then((url) => {\n      $icon.removeClass('fa-spin fa-spin-faster');\n      $('#shared').removeClass('collapse');\n      $('#shared').val(url);\n      Toast.showInfoToast('Shareable link is created.');\n    });\n  });\n\n  // control\n\n  const $btnRun = $('#btn_run');\n  const $btnTrace = $('#btn_trace');\n  const $btnPause = $('#btn_pause');\n  const $btnPrev = $('#btn_prev');\n  const $btnNext = $('#btn_next');\n\n  // initially, control buttons are disabled\n  TopMenu.disableFlowControl();\n\n  $btnRun.click(() => {\n    $btnTrace.click();\n    $btnPause.removeClass('active');\n    $btnRun.addClass('active');\n    TopMenu.enableFlowControl();\n    var err = app.getEditor().execute();\n    if (err) {\n      console.error(err);\n      Toast.showErrorToast(err);\n      TopMenu.resetTopMenuButtons();\n    }\n  });\n\n  $btnPause.click(() => {\n    $btnRun.toggleClass('active');\n    $btnPause.toggleClass('active');\n    if (app.getTracerManager().isPause()) {\n      app.getTracerManager().resumeStep();\n    } else {\n      app.getTracerManager().pauseStep();\n    }\n  });\n\n  $btnPrev.click(() => {\n    $btnRun.removeClass('active');\n    $btnPause.addClass('active');\n    app.getTracerManager().pauseStep();\n    app.getTracerManager().prevStep();\n  });\n\n  $btnNext.click(() => {\n    $btnRun.removeClass('active');\n    $btnPause.addClass('active');\n    app.getTracerManager().pauseStep();\n    app.getTracerManager().nextStep();\n  });\n\n};\n","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = function() {\n  $(window).resize(function() {\n    app.getTracerManager().resize();\n  });\n};\n","'use strict';\n\nconst app = require('../app');\n\nconst {\n  isScratchPaper\n} = require('../utils');\n\nconst showDescription = require('./show_description');\nconst addFiles = require('./add_files');\n\nmodule.exports = (category, algorithm, data, requestedFile) => {\n  let $menu;\n  let category_name;\n  let algorithm_name;\n\n  if (isScratchPaper(category)) {\n    $menu = $('#scratch-paper');\n    category_name = 'Scratch Paper';\n    algorithm_name = algorithm ? 'Shared' : 'Temporary';\n  } else {\n    $menu = $(`[data-category=\"${category}\"][data-algorithm=\"${algorithm}\"]`);\n    const categoryObj = app.getCategory(category);\n    category_name = categoryObj.name;\n    algorithm_name = categoryObj.list[algorithm];\n  }\n\n  $('.sidemenu button').removeClass('active');\n  $menu.addClass('active');\n\n  $('#category').html(category_name);\n  $('#algorithm').html(algorithm_name);\n  $('#tab_desc > .wrapper').empty();\n  $('.files_bar > .wrapper').empty();\n  $('#explanation').html('');\n\n  app.setLastFileUsed(null);\n  app.getEditor().clearContent();\n\n  const {\n    files\n  } = data;\n\n  delete data.files;\n\n  showDescription(data);\n  addFiles(category, algorithm, files, requestedFile);\n};","'use strict';\n\nconst {\n  isArray\n} = Array;\n\nconst {\n  each\n} = $;\n\nmodule.exports = (data) => {\n  const $container = $('#tab_desc > .wrapper');\n  $container.empty();\n\n  each(data, (key, value) => {\n\n    if (key) {\n      $container.append($('<h3>').html(key));\n    }\n\n    if (typeof value === 'string') {\n      $container.append($('<p>').html(value));\n\n    } else if (isArray(value)) {\n\n      const $ul = $('<ul class=\"applications\">');\n      $container.append($ul);\n\n      value.forEach((li) => {\n        $ul.append($('<li>').html(li));\n      });\n\n    } else if (typeof value === 'object') {\n\n      const $ul = $('<ul class=\"complexities\">');\n      $container.append($ul);\n\n      each(value, (prop) => {\n        const $wrapper = $('<div class=\"complexity\">');\n        const $type = $('<span class=\"complexity-type\">').html(`${prop}: `);\n        const $value = $('<span class=\"complexity-value\">').html(`${value[prop]}`);\n\n        $wrapper.append($type).append($value);\n\n        $ul.append($('<li>').append($wrapper));\n      });\n    }\n  });\n};\n","'use strict';\n\n// click the first algorithm in the first category\nmodule.exports = () => {\n  $('#list .category').first().click();\n  $('#list .category + .algorithms > .indent').first().click();\n};\n","'use strict';\n\nconst Server = require('../server');\nconst showAlgorithm = require('./show_algorithm');\n\nmodule.exports = (category, algorithm, file) => {\n  $(`.category[data-category=\"${category}\"]`).click();\n  Server.loadAlgorithm(category, algorithm).then((data) => {\n    showAlgorithm(category, algorithm, data, file);\n  });\n};\n","'use strict';\n\nconst app = require('../app');\nconst Server = require('../server');\nconst converter = new showdown.Converter({tables: true});\n\nmodule.exports = (wiki) => {\n  Server.loadWiki(wiki).then((data) => {\n    $('#tab_doc > .wrapper').html(converter.makeHtml(`#${wiki}\\n${data}`));\n    $('#tab_doc').scrollTop(0);\n    $('#tab_doc > .wrapper a').click(function (e) {\n      const href = $(this).attr('href');\n      if (app.hasWiki(href)) {\n        e.preventDefault();\n        module.exports(href);\n      }\n    });\n  });\n};","'use strict';\n\nconst showToast = (data, type) => {\n  const $toast = $(`<div class=\"toast ${type}\">`).append(data);\n\n  $('.toast_container').append($toast);\n  setTimeout(() => {\n    $toast.fadeOut(() => {\n      $toast.remove();\n    });\n  }, 3000);\n};\n\nconst showErrorToast = (err) => {\n  showToast(err, 'error');\n};\n\nconst showInfoToast = (err) => {\n  showToast(err, 'info');\n};\n\nmodule.exports = {\n  showErrorToast,\n  showInfoToast\n};","'use strict';\n\nconst app = require('../app');\n\nconst flowControlBtns = [ $('#btn_pause'), $('#btn_prev'), $('#btn_next') ];\nconst setFlowControlState = (isDisabled) => {\n  flowControlBtns.forEach($btn => $btn.attr('disabled', isDisabled));\n};\n\nconst enableFlowControl = () => {\n  setFlowControlState(false);\n};\n\nconst disableFlowControl = () => {\n  setFlowControlState(true);\n};\n\nconst resetTopMenuButtons = () => {\n  $('.top-menu-buttons button').removeClass('active');\n  disableFlowControl();\n  app.getEditor().unhighlightLine();\n};\n\nconst setInterval = (val) => {\n  $('#interval').val(interval);\n};\n\nconst activateBtnPause = () => {\n  $('#btn_pause').addClass('active');\n};\n\nconst deactivateBtnPause = () => {\n  $('#btn_pause').removeClass('active');\n};\n\nmodule.exports = {\n  enableFlowControl,\n  disableFlowControl,\n  resetTopMenuButtons,\n  setInterval,\n  activateBtnPause,\n  deactivateBtnPause\n};\n","'use strict';\n\nmodule.exports = function(id) {\n  const editor = ace.edit(id);\n\n  editor.setOptions({\n    enableBasicAutocompletion: true,\n    enableSnippets: true,\n    enableLiveAutocompletion: true\n  });\n\n  editor.setTheme('ace/theme/tomorrow_night_eighties');\n  editor.session.setMode('ace/mode/javascript');\n  editor.$blockScrolling = Infinity;\n\n  return editor;\n};","'use strict';\n\nconst execute = (tracerManager, code, dataLines) => {\n  // all modules available to eval are obtained from window\n  try {\n    tracerManager.deallocateAll();\n    const lines = code.split('\\n');\n    const newLines = [];\n    lines.forEach((line, i) => {\n      newLines.push(line.replace(/(.+\\. *_wait *)(\\( *\\))/g, `$1(${i - dataLines})`));\n    });\n    eval(newLines.join('\\n'));\n    tracerManager.visualize();\n  } catch (err) {\n    return err;\n  } finally {\n    tracerManager.removeUnallocated();\n  }\n};\n\nconst executeData = (tracerManager, algoData) => {\n  return execute(tracerManager, algoData);\n};\n\nconst executeDataAndCode = (tracerManager, algoData, algoCode) => {\n  const dataLines = algoData.split('\\n').length;\n  return execute(tracerManager, `${algoData}\\n${algoCode}`, dataLines);\n};\n\nmodule.exports = {\n  executeData,\n  executeDataAndCode\n};","'use strict';\n\nconst app = require('../app');\nconst createEditor = require('./create');\nconst Executor = require('./executor');\nconst TopMenu = require('../dom/top_menu');\n\nfunction Editor(tracerManager) {\n  if (!tracerManager) {\n    throw 'Cannot create Editor. Missing the tracerManager';\n  }\n\n  ace.require('ace/ext/language_tools');\n  const Range = ace.require(\"ace/range\").Range;\n\n  this.dataEditor = createEditor('data');\n  this.codeEditor = createEditor('code');\n\n  // Setting data\n\n  this.setData = (data) => {\n    this.dataEditor.setValue(data, -1);\n  };\n\n  this.setCode = (code) => {\n    this.codeEditor.setValue(code, -1);\n  };\n\n  this.setContent = (({\n    data,\n    code\n  }) => {\n    this.setData(data);\n    this.setCode(code);\n  });\n\n  // Clearing data\n\n  this.clearData = () => {\n    this.dataEditor.setValue('');\n  };\n\n  this.clearCode = () => {\n    this.codeEditor.setValue('');\n  };\n\n  this.clearContent = () => {\n    this.clearData();\n    this.clearCode();\n  };\n\n  this.execute = () => {\n    const data = this.dataEditor.getValue();\n    const code = this.codeEditor.getValue();\n    return Executor.executeDataAndCode(tracerManager, data, code);\n  };\n\n  this.highlightLine = (lineNumber) => {\n    const session = this.codeEditor.getSession();\n    if (this.marker) session.removeMarker(this.marker);\n    this.marker = session.addMarker(new Range(lineNumber, 0, lineNumber, Infinity), \"executing\", \"line\", true);\n  };\n\n  this.unhighlightLine = () => {\n    const session = this.codeEditor.getSession();\n    if (this.marker) session.removeMarker(this.marker);\n  };\n\n  // listeners\n\n  this.dataEditor.on('change', () => {\n    const data = this.dataEditor.getValue();\n    const lastFileUsed = app.getLastFileUsed();\n    if (lastFileUsed) {\n      app.updateCachedFile(lastFileUsed, {\n        data\n      });\n    }\n    Executor.executeData(tracerManager, data);\n    TopMenu.resetTopMenuButtons();\n  });\n\n  this.codeEditor.on('change', () => {\n    const code = this.codeEditor.getValue();\n    const lastFileUsed = app.getLastFileUsed();\n    if (lastFileUsed) {\n      app.updateCachedFile(lastFileUsed, {\n        code\n      });\n    }\n    tracerManager.reset();\n    TopMenu.resetTopMenuButtons();\n  });\n}\n\nmodule.exports = Editor;","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('./app');\nconst AppConstructor = require('./app/constructor');\nconst DOM = require('./dom');\nconst Server = require('./server');\n\nconst modules = require('./module');\n\nconst {\n  extend\n} = $;\n\n$.ajaxSetup({\n  cache: false,\n  dataType: 'text'\n});\n\nconst {\n  isScratchPaper\n} = require('./utils');\n\nconst {\n  getPath\n} = require('./server/helpers');\n\n// set global promise error handler\nRSVP.on('error', function (reason) {\n  console.assert(false, reason);\n});\n\n$(() => {\n\n  // initialize the application and attach in to the instance module\n  const appConstructor = new AppConstructor();\n  extend(true, app, appConstructor);\n\n  // load modules to the global scope so they can be evaled\n  extend(true, window, modules);\n\n  Server.loadCategories().then((data) => {\n    app.setCategories(data);\n    DOM.addCategories();\n\n    // determine if the app is loading a pre-existing scratch-pad\n    // or the home page\n    const {\n      category,\n      algorithm,\n      file\n    } = getPath();\n    if (isScratchPaper(category)) {\n      if (algorithm) {\n        Server.loadScratchPaper(algorithm).then(({category, algorithm, data}) => {\n          DOM.showAlgorithm(category, algorithm, data);\n        });\n      } else {\n        Server.loadAlgorithm(category).then((data) => {\n          DOM.showAlgorithm(category, null, data);\n        });\n      }\n    } else if (category && algorithm) {\n      DOM.showRequestedAlgorithm(category, algorithm, file);\n    } else {\n      DOM.showFirstAlgorithm();\n    }\n  });\n\n  Server.loadWikiList().then((data) => {\n    app.setWikiList(data.wikis);\n\n    DOM.showWiki('Tracer');\n  })\n});","'use strict';\n\nconst Array2D = require('./array2d');\n\nconst random = (N, min, max) => {\n  return Array2D.random(1, N, min, max)[0];\n};\n\nconst randomSorted = (N, min, max)=> {\n  return Array2D.randomSorted(1, N, min, max)[0];\n};\n\nmodule.exports = {\n  random,\n  randomSorted\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, M, min, max) => {\n  if (!N) N = 10;\n  if (!M) M = 10;\n  if (min === undefined) min = 1;\n  if (max === undefined) max = 9;\n  var D = [];\n  for (var i = 0; i < N; i++) {\n    D.push([]);\n    for (var j = 0; j < M; j++) {\n      D[i].push(Integer.random(min, max));\n    }\n  }\n  return D;\n};\n\nconst randomSorted = (N, M, min, max) => {\n  return random(N, M, min, max).map(function (arr) {\n    return arr.sort(function (a, b) {\n      return a - b;\n    });\n  });\n};\n\nmodule.exports = {\n  random,\n  randomSorted\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, min, max) => {\n  if (!N) N = 7;\n  if (!min) min = 1;\n  if (!max) max = 10;\n  var C = new Array(N);\n  for (var i = 0; i < N; i++) C[i] = new Array(2);\n  for (var i = 0; i < N; i++)\n    for (var j = 0; j < C[i].length; j++)\n      C[i][j] = Integer.random(min, max);\n  return C;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst random = (N, ratio) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) {\n    G[i] = new Array(N);\n    for (var j = 0; j < N; j++) {\n      if (i != j) {\n        G[i][j] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\nconst Array1D = require('./array1d');\nconst Array2D = require('./array2d');\nconst CoordinateSystem = require('./coordinate_system');\nconst DirectedGraph = require('./directed_graph');\nconst UndirectedGraph = require('./undirected_graph');\nconst WeightedDirectedGraph = require('./weighted_directed_graph');\nconst WeightedUndirectedGraph = require('./weighted_undirected_graph');\n\nmodule.exports = {\n  Integer,\n  Array1D,\n  Array2D,\n  CoordinateSystem,\n  DirectedGraph,\n  UndirectedGraph,\n  WeightedDirectedGraph,\n  WeightedUndirectedGraph\n};","'use strict';\n\nconst random = (min, max) => {\n  return (Math.random() * (max - min + 1) | 0) + min;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst random = (N, ratio) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) G[i] = new Array(N);\n  for (var i = 0; i < N; i++) {\n    for (var j = 0; j < N; j++) {\n      if (i > j) {\n        G[i][j] = G[j][i] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, ratio, min, max) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  if (!min) min = 1;\n  if (!max) max = 5;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) {\n    G[i] = new Array(N);\n    for (var j = 0; j < N; j++) {\n      if (i != j && (Math.random() * (1 / ratio) | 0) == 0) {\n        G[i][j] = Integer.random(min, max);\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, ratio, min, max) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  if (!min) min = 1;\n  if (!max) max = 5;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) G[i] = new Array(N);\n  for (var i = 0; i < N; i++) {\n    for (var j = 0; j < N; j++) {\n      if (i > j && (Math.random() * (1 / ratio) | 0) == 0) {\n        G[i][j] = G[j][i] = Integer.random(min, max);\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nvar tracers = require('./tracer');\nvar datas = require('./data');\n\nconst {\n  extend\n} = $;\n\nmodule.exports = extend(true, {}, tracers, datas);","'use strict';\n\nconst Array2DTracer = require('./array2d');\n\nclass Array1DTracer extends Array2DTracer {\n  static getClassName() {\n    return 'Array1DTracer';\n  }\n\n  constructor(name) {\n    super(name);\n  }\n\n  _notify(idx, v) {\n    super._notify(0, idx, v);\n    return this;\n  }\n\n  _denotify(idx) {\n    super._denotify(0, idx);\n    return this;\n  }\n\n  _select(s, e) {\n    if (e === undefined) {\n      super._select(0, s);\n    } else {\n      super._selectRow(0, s, e);\n    }\n    return this;\n  }\n\n  _deselect(s, e) {\n    if (e === undefined) {\n      super._deselect(0, s);\n    } else {\n      super._deselectRow(0, s, e);\n    }\n    return this;\n  }\n\n  processStep(step, options) {\n    super.processStep(step, options);\n    if (this.chartTracer) {\n      const newStep = $.extend(true, {}, step);\n      newStep.capsule = this.chartTracer.capsule;\n      newStep.s = newStep.sy;\n      newStep.e = newStep.ey;\n      if (newStep.s === undefined) newStep.s = newStep.y;\n      delete newStep.x;\n      delete newStep.y;\n      delete newStep.sx;\n      delete newStep.sy;\n      delete newStep.ex;\n      delete newStep.ey;\n      this.chartTracer.processStep(newStep, options);\n    }\n  }\n\n  setData(D) {\n    return super.setData([D]);\n  }\n}\n\nmodule.exports = Array1DTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass Array2DTracer extends Tracer {\n  static getClassName() {\n    return 'Array2DTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.colorClass = {\n      selected: 'selected',\n      notified: 'notified'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  _notify(x, y, v) {\n    this.manager.pushStep(this.capsule, {\n      type: 'notify',\n      x: x,\n      y: y,\n      v: v\n    });\n    return this;\n  }\n\n  _denotify(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'denotify',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _select(sx, sy, ex, ey) {\n    this.pushSelectingStep('select', null, arguments);\n    return this;\n  }\n\n  _selectRow(x, sy, ey) {\n    this.pushSelectingStep('select', 'row', arguments);\n    return this;\n  }\n\n  _selectCol(y, sx, ex) {\n    this.pushSelectingStep('select', 'col', arguments);\n    return this;\n  }\n\n  _deselect(sx, sy, ex, ey) {\n    this.pushSelectingStep('deselect', null, arguments);\n    return this;\n  }\n\n  _deselectRow(x, sy, ey) {\n    this.pushSelectingStep('deselect', 'row', arguments);\n    return this;\n  }\n\n  _deselectCol(y, sx, ex) {\n    this.pushSelectingStep('deselect', 'col', arguments);\n    return this;\n  }\n\n  _separate(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'separate',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _separateRow(x) {\n    this._separate(x, -1);\n    return this;\n  }\n\n  _separateCol(y) {\n    this._separate(-1, y);\n    return this;\n  }\n\n  _deseparate(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'deseparate',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _deseparateRow(x) {\n    this._deseparate(x, -1);\n    return this;\n  }\n\n  _deseparateCol(y) {\n    this._deseparate(-1, y);\n    return this;\n  }\n\n  pushSelectingStep() {\n    var args = Array.prototype.slice.call(arguments);\n    var type = args.shift();\n    var mode = args.shift();\n    args = Array.prototype.slice.call(args.shift());\n    var coord;\n    switch (mode) {\n      case 'row':\n        coord = {\n          x: args[0],\n          sy: args[1],\n          ey: args[2]\n        };\n        break;\n      case 'col':\n        coord = {\n          y: args[0],\n          sx: args[1],\n          ex: args[2]\n        };\n        break;\n      default:\n        if (args[2] === undefined && args[3] === undefined) {\n          coord = {\n            x: args[0],\n            y: args[1]\n          };\n        } else {\n          coord = {\n            sx: args[0],\n            sy: args[1],\n            ex: args[2],\n            ey: args[3]\n          };\n        }\n    }\n    var step = {\n      type: type\n    };\n    $.extend(step, coord);\n    this.manager.pushStep(this.capsule, step);\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'notify':\n        if (step.v !== undefined) {\n          var $row = this.$table.find('.mtbl-row').eq(step.x);\n          var $col = $row.find('.mtbl-col').eq(step.y);\n          $col.text(refineByType(step.v));\n        }\n      case 'denotify':\n      case 'select':\n      case 'deselect':\n        var colorClass = step.type == 'select' || step.type == 'deselect' ? this.colorClass.selected : this.colorClass.notified;\n        var addClass = step.type == 'select' || step.type == 'notify';\n        var sx = step.sx;\n        var sy = step.sy;\n        var ex = step.ex;\n        var ey = step.ey;\n        if (sx === undefined) sx = step.x;\n        if (sy === undefined) sy = step.y;\n        if (ex === undefined) ex = step.x;\n        if (ey === undefined) ey = step.y;\n        this.paintColor(sx, sy, ex, ey, colorClass, addClass);\n        break;\n      case 'separate':\n        this.deseparate(step.x, step.y);\n        this.separate(step.x, step.y);\n        break;\n      case 'deseparate':\n        this.deseparate(step.x, step.y);\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  setData(D) {\n    this.viewX = this.viewY = 0;\n    this.paddingH = 6;\n    this.paddingV = 3;\n    this.fontSize = 16;\n\n    if (super.setData.apply(this, arguments)) {\n      this.$table.find('.mtbl-row').each(function (i) {\n        $(this).find('.mtbl-col').each(function (j) {\n          $(this).text(refineByType(D[i][j]));\n        });\n      });\n      return true;\n    }\n\n    this.$table.empty();\n    for (var i = 0; i < D.length; i++) {\n      var $row = $('<div class=\"mtbl-row\">');\n      this.$table.append($row);\n      for (var j = 0; j < D[i].length; j++) {\n        var $col = $('<div class=\"mtbl-col\">')\n          .css(this.getCellCss())\n          .text(refineByType(D[i][j]));\n        $row.append($col);\n      }\n    }\n    this.resize();\n\n    return false;\n  }\n\n  resize() {\n    super.resize();\n\n    this.refresh();\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearColor();\n    this.deseparateAll();\n  }\n\n  getCellCss() {\n    return {\n      padding: this.paddingV.toFixed(1) + 'px ' + this.paddingH.toFixed(1) + 'px',\n      'font-size': this.fontSize.toFixed(1) + 'px'\n    };\n  }\n\n  refresh() {\n    super.refresh();\n\n    var $parent = this.$table.parent();\n    var top = $parent.height() / 2 - this.$table.height() / 2 + this.viewY;\n    var left = $parent.width() / 2 - this.$table.width() / 2 + this.viewX;\n    this.$table.css('margin-top', top);\n    this.$table.css('margin-left', left);\n  }\n\n  mousedown(e) {\n    super.mousedown(e);\n\n    this.dragX = e.pageX;\n    this.dragY = e.pageY;\n    this.dragging = true;\n  }\n\n  mousemove(e) {\n    super.mousemove(e);\n\n    if (this.dragging) {\n      this.viewX += e.pageX - this.dragX;\n      this.viewY += e.pageY - this.dragY;\n      this.dragX = e.pageX;\n      this.dragY = e.pageY;\n      this.refresh();\n    }\n  }\n\n  mouseup(e) {\n    super.mouseup(e);\n\n    this.dragging = false;\n  }\n\n  mousewheel(e) {\n    super.mousewheel(e);\n\n    e.preventDefault();\n    e = e.originalEvent;\n    var delta = (e.wheelDelta !== undefined && e.wheelDelta) ||\n      (e.detail !== undefined && -e.detail);\n    var weight = 1.01;\n    var ratio = delta > 0 ? 1 / weight : weight;\n    if (this.fontSize < 4 && ratio < 1) return;\n    if (this.fontSize > 40 && ratio > 1) return;\n    this.paddingV *= ratio;\n    this.paddingH *= ratio;\n    this.fontSize *= ratio;\n    this.$table.find('.mtbl-col').css(this.getCellCss());\n    this.refresh();\n  }\n\n  paintColor(sx, sy, ex, ey, colorClass, addClass) {\n    for (var i = sx; i <= ex; i++) {\n      var $row = this.$table.find('.mtbl-row').eq(i);\n      for (var j = sy; j <= ey; j++) {\n        var $col = $row.find('.mtbl-col').eq(j);\n        if (addClass) $col.addClass(colorClass);\n        else $col.removeClass(colorClass);\n      }\n    }\n  }\n\n  clearColor() {\n    this.$table.find('.mtbl-col').removeClass(Object.keys(this.colorClass).join(' '));\n  }\n\n  separate(x, y) {\n    this.$table.find('.mtbl-row').each(function (i) {\n      var $row = $(this);\n      if (i == x) {\n        $row.after($('<div class=\"mtbl-empty-row\">').attr('data-row', i))\n      }\n      $row.find('.mtbl-col').each(function (j) {\n        var $col = $(this);\n        if (j == y) {\n          $col.after($('<div class=\"mtbl-empty-col\">').attr('data-col', j));\n        }\n      });\n    });\n  }\n\n  deseparate(x, y) {\n    this.$table.find('[data-row=' + x + ']').remove();\n    this.$table.find('[data-col=' + y + ']').remove();\n  }\n\n  deseparateAll() {\n    this.$table.find('.mtbl-empty-row, .mtbl-empty-col').remove();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$table = tracer.capsule.$table = $('<div class=\"mtbl-table\">');\n  tracer.$container.append(tracer.$table);\n};\n\nmodule.exports = Array2DTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nclass ChartTracer extends Tracer {\n  static getClassName() {\n    return 'ChartTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.color = {\n      selected: 'rgb(0, 0, 255)',\n      notified: 'rgb(255, 0, 0)',\n      default: 'rgb(136, 136, 136)'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (super.setData.apply(this, arguments)) {\n      this.chart.config.data.datasets[0].data = C;\n      this.chart.update();\n      return true;\n    }\n\n    var color = [];\n    for (var i = 0; i < C.length; i++) color.push(this.color.default);\n    this.chart.config.data = {\n      labels: C.map(String),\n      datasets: [{\n        backgroundColor: color,\n        data: C\n      }]\n    };\n    this.chart.update();\n  }\n\n  _notify(s, v) {\n    this.manager.pushStep(this.capsule, {\n      type: 'notify',\n      s: s,\n      v: v\n    });\n    return this;\n  }\n\n  _denotify(s) {\n    this.manager.pushStep(this.capsule, {\n      type: 'denotify',\n      s: s\n    });\n    return this;\n  }\n\n  _select(s, e) {\n    this.manager.pushStep(this.capsule, {\n      type: 'select',\n      s: s,\n      e: e\n    });\n    return this;\n  }\n\n  _deselect(s, e) {\n    this.manager.pushStep(this.capsule, {\n      type: 'deselect',\n      s: s,\n      e: e\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'notify':\n        if (step.v !== undefined) {\n          this.chart.config.data.datasets[0].data[step.s] = step.v;\n          this.chart.config.data.labels[step.s] = step.v.toString();\n        }\n      case 'denotify':\n      case 'select':\n      case 'deselect':\n        let color = step.type == 'notify' ? this.color.notified : step.type == 'select' ? this.color.selected : this.color.default;\n        if (step.e !== undefined)\n          for (var i = step.s; i <= step.e; i++)\n            this.chart.config.data.datasets[0].backgroundColor[i] = color;\n        else\n          this.chart.config.data.datasets[0].backgroundColor[step.s] = color;\n        this.chart.update();\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  resize() {\n    super.resize();\n\n    this.chart.resize();\n  }\n\n  clear() {\n    super.clear();\n\n    const data = this.chart.config.data;\n    if (data.datasets.length) {\n      const backgroundColor = data.datasets[0].backgroundColor;\n      for (let i = 0; i < backgroundColor.length; i++) {\n        backgroundColor[i] = this.color.default;\n      }\n      this.chart.update();\n    }\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$wrapper = tracer.capsule.$wrapper = $('<canvas class=\"mchrt-chart\">');\n  tracer.$container.append(tracer.$wrapper);\n  tracer.chart = tracer.capsule.chart = new Chart(tracer.$wrapper, {\n    type: 'bar',\n    data: {\n      labels: [],\n      datasets: []\n    },\n    options: {\n      scales: {\n        yAxes: [{\n          ticks: {\n            beginAtZero: true\n          }\n        }]\n      },\n      animation: false,\n      legend: false,\n      responsive: true,\n      maintainAspectRatio: false\n    }\n  });\n};\n\nmodule.exports = ChartTracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nclass CoordinateSystemTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'CoordinateSystemTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (Tracer.prototype.setData.apply(this, arguments)) return true;\n\n    this.graph.clear();\n    var nodes = [];\n    var edges = [];\n    for (var i = 0; i < C.length; i++)\n      nodes.push({\n        id: this.n(i),\n        x: C[i][0],\n        y: C[i][1],\n        label: '' + i,\n        size: 1,\n        color: this.color.default\n      });\n    this.graph.read({\n      nodes: nodes,\n      edges: edges\n    });\n    this.s.camera.goTo({\n      x: 0,\n      y: 0,\n      angle: 0,\n      ratio: 1\n    });\n    this.refresh();\n\n    return false;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          if (this.graph.edges(edgeId)) {\n            var edge = this.graph.edges(edgeId);\n            edge.color = color;\n            this.graph.dropEdge(edgeId).addEdge(edge);\n          } else {\n            this.graph.addEdge({\n              id: this.e(step.target, step.source),\n              source: this.n(step.source),\n              target: this.n(step.target),\n              color: color,\n              size: 1\n            });\n          }\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  e(v1, v2) {\n    if (v1 > v2) {\n      var temp = v1;\n      v1 = v2;\n      v2 = temp;\n    }\n    return 'e' + v1 + '_' + v2;\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#0ff';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n\n  drawEdge(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(\n      source[prefix + 'x'],\n      source[prefix + 'y']\n    );\n    context.lineTo(\n      target[prefix + 'x'],\n      target[prefix + 'y']\n    );\n    context.stroke();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = CoordinateSystemTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass DirectedGraphTracer extends Tracer {\n  static getClassName() {\n    return 'DirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.color = {\n      selected: '#0f0',\n      visited: '#f00',\n      left: '#000',\n      default: '#888'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  _setTreeData(G, root) {\n    this.manager.pushStep(this.capsule, {\n      type: 'setTreeData',\n      arguments: arguments\n    });\n    return this;\n  }\n\n  _visit(target, source) {\n    this.manager.pushStep(this.capsule, {\n      type: 'visit',\n      target: target,\n      source: source\n    });\n    return this;\n  }\n\n  _leave(target, source) {\n    this.manager.pushStep(this.capsule, {\n      type: 'leave',\n      target: target,\n      source: source\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'setTreeData':\n        this.setTreeData.apply(this, step.arguments);\n        break;\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          var edge = this.graph.edges(edgeId);\n          edge.color = color;\n          this.graph.dropEdge(edgeId).addEdge(edge);\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  setTreeData(G, root, undirected) {\n    var tracer = this;\n\n    root = root || 0;\n    var maxDepth = -1;\n\n    var chk = new Array(G.length);\n    var getDepth = function (node, depth) {\n      if (chk[node]) throw \"the given graph is not a tree because it forms a circuit\";\n      chk[node] = true;\n      if (maxDepth < depth) maxDepth = depth;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) getDepth(i, depth + 1);\n      }\n    };\n    getDepth(root, 1);\n\n    if (this.setData(G, undirected)) return true;\n\n    var place = function (node, x, y) {\n      var temp = tracer.graph.nodes(tracer.n(node));\n      temp.x = x;\n      temp.y = y;\n    };\n\n    var wgap = 1 / (maxDepth - 1);\n    var dfs = function (node, depth, top, bottom) {\n      place(node, top + bottom, depth * wgap);\n      var children = 0;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) children++;\n      }\n      var vgap = (bottom - top) / children;\n      var cnt = 0;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) dfs(i, depth + 1, top + vgap * cnt, top + vgap * ++cnt);\n      }\n    };\n    dfs(root, 0, 0, 1);\n\n    this.refresh();\n  }\n\n  setData(G, undirected) {\n    if (super.setData.apply(this, arguments)) return true;\n\n    this.graph.clear();\n    const nodes = [];\n    const edges = [];\n    const unitAngle = 2 * Math.PI / G.length;\n    let currentAngle = 0;\n    for (let i = 0; i < G.length; i++) {\n      currentAngle += unitAngle;\n      nodes.push({\n        id: this.n(i),\n        label: '' + i,\n        x: .5 + Math.sin(currentAngle) / 2,\n        y: .5 + Math.cos(currentAngle) / 2,\n        size: 1,\n        color: this.color.default,\n        weight: 0\n      });\n\n      if (undirected) {\n        for (let j = 0; j <= i; j++) {\n          const value = G[i][j] || G[j][i];\n          if (value) {\n            edges.push({\n              id: this.e(i, j),\n              source: this.n(i),\n              target: this.n(j),\n              color: this.color.default,\n              size: 1,\n              weight: refineByType(value)\n            });\n          }\n        }\n      } else {\n        for (let j = 0; j < G[i].length; j++) {\n          if (G[i][j]) {\n            edges.push({\n              id: this.e(i, j),\n              source: this.n(i),\n              target: this.n(j),\n              color: this.color.default,\n              size: 1,\n              weight: refineByType(G[i][j])\n            });\n          }\n        }\n      }\n    }\n\n    this.graph.read({\n      nodes: nodes,\n      edges: edges\n    });\n    this.s.camera.goTo({\n      x: 0,\n      y: 0,\n      angle: 0,\n      ratio: 1\n    });\n    this.refresh();\n\n    return false;\n  }\n\n  resize() {\n    super.resize();\n\n    this.s.renderers[0].resize();\n    this.refresh();\n  }\n\n  refresh() {\n    super.refresh();\n\n    this.s.refresh();\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearGraphColor();\n    this.refresh();\n  }\n\n  clearGraphColor() {\n    var tracer = this;\n\n    this.graph.nodes().forEach(function (node) {\n      node.color = tracer.color.default;\n    });\n    this.graph.edges().forEach(function (edge) {\n      edge.color = tracer.color.default;\n    });\n  }\n\n  n(v) {\n    return 'n' + v;\n  }\n\n  e(v1, v2) {\n    return 'e' + v1 + '_' + v2;\n  }\n\n  getColor(edge, source, target, settings) {\n    var color = edge.color,\n      edgeColor = settings('edgeColor'),\n      defaultNodeColor = settings('defaultNodeColor'),\n      defaultEdgeColor = settings('defaultEdgeColor');\n    if (!color)\n      switch (edgeColor) {\n        case 'source':\n          color = source.color || defaultNodeColor;\n          break;\n        case 'target':\n          color = target.color || defaultNodeColor;\n          break;\n        default:\n          color = defaultEdgeColor;\n          break;\n      }\n\n    return color;\n  }\n\n  drawLabel(node, context, settings) {\n    var fontSize,\n      prefix = settings('prefix') || '',\n      size = node[prefix + 'size'];\n\n    if (size < settings('labelThreshold'))\n      return;\n\n    if (!node.label || typeof node.label !== 'string')\n      return;\n\n    fontSize = (settings('labelSize') === 'fixed') ?\n      settings('defaultLabelSize') :\n    settings('labelSizeRatio') * size;\n\n    context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') +\n      fontSize + 'px ' + settings('font');\n    context.fillStyle = (settings('labelColor') === 'node') ?\n      (node.color || settings('defaultNodeColor')) :\n      settings('defaultLabelColor');\n\n    context.textAlign = 'center';\n    context.fillText(\n      node.label,\n      Math.round(node[prefix + 'x']),\n      Math.round(node[prefix + 'y'] + fontSize / 3)\n    );\n  }\n\n  drawArrow(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1,\n      tSize = target[prefix + 'size'],\n      sX = source[prefix + 'x'],\n      sY = source[prefix + 'y'],\n      tX = target[prefix + 'x'],\n      tY = target[prefix + 'y'],\n      angle = Math.atan2(tY - sY, tX - sX),\n      dist = 3;\n    sX += Math.sin(angle) * dist;\n    tX += Math.sin(angle) * dist;\n    sY += -Math.cos(angle) * dist;\n    tY += -Math.cos(angle) * dist;\n    var aSize = Math.max(size * 2.5, settings('minArrowSize')),\n      d = Math.sqrt(Math.pow(tX - sX, 2) + Math.pow(tY - sY, 2)),\n      aX = sX + (tX - sX) * (d - aSize - tSize) / d,\n      aY = sY + (tY - sY) * (d - aSize - tSize) / d,\n      vX = (tX - sX) * aSize / d,\n      vY = (tY - sY) * aSize / d;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(sX, sY);\n    context.lineTo(\n      aX,\n      aY\n    );\n    context.stroke();\n\n    context.fillStyle = color;\n    context.beginPath();\n    context.moveTo(aX + vX, aY + vY);\n    context.lineTo(aX + vY * 0.6, aY - vX * 0.6);\n    context.lineTo(aX - vY * 0.6, aY + vX * 0.6);\n    context.lineTo(aX + vX, aY + vY);\n    context.closePath();\n    context.fill();\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawArrow(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#ff0';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawArrow(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s = tracer.capsule.s = new sigma({\n    renderer: {\n      container: tracer.$container[0],\n      type: 'canvas'\n    },\n    settings: {\n      minArrowSize: 8,\n      defaultEdgeType: 'arrow',\n      maxEdgeSize: 2.5,\n      labelThreshold: 4,\n      font: 'Roboto',\n      defaultLabelColor: '#fff',\n      zoomMin: 0.6,\n      zoomMax: 1.2,\n      skipErrors: true,\n      minNodeSize: .5,\n      maxNodeSize: 12,\n      labelSize: 'proportional',\n      labelSizeRatio: 1.3,\n      funcLabelsDef(node, context, settings) {\n        tracer.drawLabel(node, context, settings);\n      },\n      funcHoversDef(node, context, settings, next) {\n        tracer.drawOnHover(node, context, settings, next);\n      },\n      funcEdgesArrow(edge, source, target, context, settings) {\n        var color = tracer.getColor(edge, source, target, settings);\n        tracer.drawArrow(edge, source, target, color, context, settings);\n      }\n    }\n  });\n  sigma.plugins.dragNodes(tracer.s, tracer.s.renderers[0]);\n  tracer.graph = tracer.capsule.graph = tracer.s.graph;\n};\n\nsigma.canvas.labels.def = function (node, context, settings) {\n  var func = settings('funcLabelsDef');\n  if (func) {\n    func(node, context, settings);\n  }\n};\nsigma.canvas.hovers.def = function (node, context, settings) {\n  var func = settings('funcHoversDef');\n  if (func) {\n    func(node, context, settings);\n  }\n};\nsigma.canvas.edges.def = function (edge, source, target, context, settings) {\n  var func = settings('funcEdgesDef');\n  if (func) {\n    func(edge, source, target, context, settings);\n  }\n};\nsigma.canvas.edges.arrow = function (edge, source, target, context, settings) {\n  var func = settings('funcEdgesArrow');\n  if (func) {\n    func(edge, source, target, context, settings);\n  }\n};\n\nmodule.exports = DirectedGraphTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\nconst LogTracer = require('./log');\nconst Array1DTracer = require('./array1d');\nconst Array2DTracer = require('./array2d');\nconst ChartTracer = require('./chart');\nconst CoordinateSystemTracer = require('./coordinate_system');\nconst DirectedGraphTracer = require('./directed_graph');\nconst UndirectedGraphTracer = require('./undirected_graph');\nconst WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nconst WeightedUndirectedGraphTracer = require('./weighted_undirected_graph');\n\nmodule.exports = {\n  Tracer,\n  LogTracer,\n  Array1DTracer,\n  Array2DTracer,\n  ChartTracer,\n  CoordinateSystemTracer,\n  DirectedGraphTracer,\n  UndirectedGraphTracer,\n  WeightedDirectedGraphTracer,\n  WeightedUndirectedGraphTracer\n};","'use strict';\n\nconst Tracer = require('./tracer');\n\nclass LogTracer extends Tracer {\n  static getClassName() {\n    return 'LogTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  _print(msg) {\n    this.manager.pushStep(this.capsule, {\n      type: 'print',\n      msg: msg\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'print':\n        this.print(step.msg);\n        break;\n    }\n  }\n\n  refresh() {\n    this.scrollToEnd(Math.min(50, this.interval));\n  }\n\n  clear() {\n    super.clear();\n\n    this.$wrapper.empty();\n  }\n\n  print(message) {\n    this.$wrapper.append($('<span>').append(message + '<br/>'));\n  }\n\n  scrollToEnd(duration) {\n    this.$container.animate({\n      scrollTop: this.$container[0].scrollHeight\n    }, duration);\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$wrapper = tracer.capsule.$wrapper = $('<div class=\"wrapper\">');\n  tracer.$container.append(tracer.$wrapper);\n};\n\nmodule.exports = LogTracer;\n","'use strict';\n\nconst app = require('../../app');\n\nconst {\n  toJSON,\n  fromJSON\n} = require('../../tracer_manager/util/index');\n\nclass Tracer {\n  static getClassName() {\n    return 'Tracer';\n  }\n\n  constructor(name) {\n    this.module = this.constructor;\n\n    this.manager = app.getTracerManager();\n    this.capsule = this.manager.allocate(this);\n    $.extend(this, this.capsule);\n\n    this.setName(name);\n  }\n\n  _setData(...args) {\n    this.manager.pushStep(this.capsule, {\n      type: 'setData',\n      args: toJSON(args)\n    });\n    return this;\n  }\n\n  _clear() {\n    this.manager.pushStep(this.capsule, {\n      type: 'clear'\n    });\n    return this;\n  }\n\n  _wait(line) {\n    this.manager.newStep(line);\n    return this;\n  }\n\n  processStep(step, options) {\n    const {\n      type,\n      args\n    } = step;\n\n    switch (type) {\n      case 'setData':\n        this.setData(...fromJSON(args));\n        break;\n      case 'clear':\n        this.clear();\n        break;\n    }\n  }\n\n  setName(name) {\n    let $name;\n    if (this.isNew) {\n      $name = $('<span class=\"name\">');\n      this.$container.append($name);\n    } else {\n      $name = this.$container.find('span.name');\n    }\n    $name.text(name || this.defaultName);\n  }\n\n  setData() {\n    const data = toJSON(arguments);\n    if (!this.isNew && this.lastData === data) {\n      return true;\n    }\n    this.lastData = this.capsule.lastData = data;\n    return false;\n  }\n\n  resize() {\n  }\n\n  refresh() {\n  }\n\n  clear() {\n  }\n\n  attach(tracer) {\n    switch (tracer.module) {\n      case LogTracer:\n        this.logTracer = tracer;\n        break;\n      case ChartTracer:\n        this.chartTracer = tracer;\n        break;\n    }\n    return this;\n  }\n\n  mousedown(e) {\n  }\n\n  mousemove(e) {\n  }\n\n  mouseup(e) {\n  }\n\n  mousewheel(e) {\n  }\n}\n\nmodule.exports = Tracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nclass UndirectedGraphTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'UndirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  setTreeData(G, root) {\n    return super.setTreeData(G, root, true);\n  }\n\n  setData(G) {\n    return super.setData(G, true);\n  }\n\n  e(v1, v2) {\n    if (v1 > v2) {\n      var temp = v1;\n      v1 = v2;\n      v2 = temp;\n    }\n    return 'e' + v1 + '_' + v2;\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#0ff';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n\n  drawEdge(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(\n      source[prefix + 'x'],\n      source[prefix + 'y']\n    );\n    context.lineTo(\n      target[prefix + 'x'],\n      target[prefix + 'y']\n    );\n    context.stroke();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = UndirectedGraphTracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass WeightedDirectedGraphTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'WeightedDirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  _weight(target, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'weight',\n      target: target,\n      weight: weight\n    });\n    return this;\n  }\n\n  _visit(target, source, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'visit',\n      target: target,\n      source: source,\n      weight: weight\n    });\n    return this;\n  }\n\n  _leave(target, source, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'leave',\n      target: target,\n      source: source,\n      weight: weight\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'weight':\n        var targetNode = this.graph.nodes(this.n(step.target));\n        if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n        break;\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? step.weight === undefined ? this.color.selected : this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          var edge = this.graph.edges(edgeId);\n          edge.color = color;\n          this.graph.dropEdge(edgeId).addEdge(edge);\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearWeights();\n  }\n\n  clearWeights() {\n    this.graph.nodes().forEach(function (node) {\n      node.weight = 0;\n    });\n  }\n\n  drawEdgeWeight(edge, source, target, color, context, settings) {\n    if (source == target)\n      return;\n\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    if (size < settings('edgeLabelThreshold'))\n      return;\n\n    if (0 === settings('edgeLabelSizePowRatio'))\n      throw '\"edgeLabelSizePowRatio\" must not be 0.';\n\n    var fontSize,\n      x = (source[prefix + 'x'] + target[prefix + 'x']) / 2,\n      y = (source[prefix + 'y'] + target[prefix + 'y']) / 2,\n      dX = target[prefix + 'x'] - source[prefix + 'x'],\n      dY = target[prefix + 'y'] - source[prefix + 'y'],\n      angle = Math.atan2(dY, dX);\n\n    fontSize = (settings('edgeLabelSize') === 'fixed') ?\n      settings('defaultEdgeLabelSize') :\n    settings('defaultEdgeLabelSize') *\n    size *\n    Math.pow(size, -1 / settings('edgeLabelSizePowRatio'));\n\n    context.save();\n\n    if (edge.active) {\n      context.font = [\n        settings('activeFontStyle'),\n        fontSize + 'px',\n        settings('activeFont') || settings('font')\n      ].join(' ');\n\n      context.fillStyle = color;\n    } else {\n      context.font = [\n        settings('fontStyle'),\n        fontSize + 'px',\n        settings('font')\n      ].join(' ');\n\n      context.fillStyle = color;\n    }\n\n    context.textAlign = 'center';\n    context.textBaseline = 'alphabetic';\n\n    context.translate(x, y);\n    context.rotate(angle);\n    context.fillText(\n      edge.weight,\n      0,\n      (-size / 2) - 3\n    );\n\n    context.restore();\n  }\n\n  drawNodeWeight(node, context, settings) {\n    var fontSize,\n      prefix = settings('prefix') || '',\n      size = node[prefix + 'size'];\n\n    if (size < settings('labelThreshold'))\n      return;\n\n    fontSize = (settings('labelSize') === 'fixed') ?\n      settings('defaultLabelSize') :\n    settings('labelSizeRatio') * size;\n\n    context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') +\n      fontSize + 'px ' + settings('font');\n    context.fillStyle = (settings('labelColor') === 'node') ?\n      (node.color || settings('defaultNodeColor')) :\n      settings('defaultLabelColor');\n\n    context.textAlign = 'left';\n    context.fillText(\n      node.weight,\n      Math.round(node[prefix + 'x'] + size * 1.5),\n      Math.round(node[prefix + 'y'] + fontSize / 3)\n    );\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    edgeLabelSize: 'proportional',\n    defaultEdgeLabelSize: 20,\n    edgeLabelSizePowRatio: 0.8,\n    funcLabelsDef(node, context, settings) {\n      tracer.drawNodeWeight(node, context, settings);\n      tracer.drawLabel(node, context, settings);\n    },\n    funcHoversDef(node, context, settings) {\n      tracer.drawOnHover(node, context, settings, tracer.drawEdgeWeight);\n    },\n    funcEdgesArrow(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawArrow(edge, source, target, color, context, settings);\n      tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = WeightedDirectedGraphTracer;\n","'use strict';\n\nconst WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nconst UndirectedGraphTracer = require('./undirected_graph');\n\nclass WeightedUndirectedGraphTracer extends WeightedDirectedGraphTracer {\n  static getClassName() {\n    return 'WeightedUndirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.e = UndirectedGraphTracer.prototype.e;\n    this.drawOnHover = UndirectedGraphTracer.prototype.drawOnHover;\n    this.drawEdge = UndirectedGraphTracer.prototype.drawEdge;\n\n    if (this.isNew) initView(this);\n  }\n\n  setTreeData(G, root) {\n    return super.setTreeData(G, root, true);\n  }\n\n  setData(G) {\n    return super.setData(G, true);\n  }\n\n  drawEdgeWeight(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '';\n    if (source[prefix + 'x'] > target[prefix + 'x']) {\n      var temp = source;\n      source = target;\n      target = temp;\n    }\n    WeightedDirectedGraphTracer.prototype.drawEdgeWeight.call(this, edge, source, target, color, context, settings);\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n      tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = WeightedUndirectedGraphTracer;\n","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = (url) => {\n  return request(url, {\n    type: 'GET'\n  });\n};","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = function(url) {\n  return request(url, {\n    dataType: 'json',\n    type: 'GET'\n  });\n};","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = function(url, data) {\n  return request(url, {\n    dataType: 'json',\n    type: 'POST',\n    data: JSON.stringify(data),\n  });\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../../app');\n\nconst {\n  ajax,\n  extend\n} = $;\n\nconst defaults = {\n\n};\n\nmodule.exports = function(url, options = {}) {\n  app.setIsLoading(true);\n\n  return new RSVP.Promise((resolve, reject) => {\n    const callbacks = {\n      success(response) {\n        app.setIsLoading(false);\n        resolve(response);\n      },\n      error(reason) {\n        app.setIsLoading(false);\n        reject(reason);\n      }\n    };\n\n    const opts = extend({}, defaults, options, callbacks, {\n      url\n    });\n\n    ajax(opts);\n  });\n};","'use strict';\n\nconst app = require('../app');\nconst Toast = require('../dom/toast');\n\nconst checkLoading = () => {\n  if (app.getIsLoading()) {\n    Toast.showErrorToast('Wait until it completes loading of previous file.');\n    return true;\n  }\n  return false;\n};\n\nconst getParameterByName = (name) => {\n  const url = window.location.href;\n  const regex = new RegExp(`[?&]${name}(=([^&#]*)|&|#|$)`);\n\n  const results = regex.exec(url);\n\n  if (!results || results.length !== 3) {\n    return null;\n  }\n\n  const [, , id] = results;\n\n  return id;\n};\n\nconst getHashValue = (key)=> {\n  if (!key) return null;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n  for (let i = 0; i < params.length; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      return pair[1];\n    }\n  }\n  return null;\n};\n\nconst setHashValue = (key, value)=> {\n  if (!key || !value) return;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n\n  let found = false;\n  for (let i = 0; i < params.length && !found; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      pair[1] = value;\n      params[i] = pair.join('=');\n      found = true;\n    }\n  }\n  if (!found) {\n    params.push([key, value].join('='));\n  }\n\n  const newHash = params.join('&');\n  window.location.hash = `#${newHash}`;\n};\n\nconst removeHashValue = (key) => {\n  if (!key) return;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n\n  for (let i = 0; i < params.length; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      params.splice(i, 1);\n      break;\n    }\n  }\n\n  const newHash = params.join('&');\n  window.location.hash = `#${newHash}`;\n};\n\nconst setPath = (category, algorithm, file) => {\n  const path = category ? category + (algorithm ? `/${algorithm}` + (file ? `/${file}` : '') : '') : '';\n  setHashValue('path', path);\n};\n\nconst getPath = () => {\n  const hash = getHashValue('path');\n  if (hash) {\n    const [ category, algorithm, file ] = hash.split('/');\n    return { category, algorithm, file };\n  } else {\n    return false;\n  }\n};\n\nmodule.exports = {\n  checkLoading,\n  getParameterByName,\n  getHashValue,\n  setHashValue,\n  removeHashValue,\n  setPath,\n  getPath\n};\n","'use strict';\n\nconst loadAlgorithm = require('./load_algorithm');\nconst loadCategories = require('./load_categories');\nconst loadFile = require('./load_file');\nconst loadScratchPaper = require('./load_scratch_paper');\nconst shareScratchPaper = require('./share_scratch_paper');\nconst loadWikiList = require('./load_wiki_list');\nconst loadWiki = require('./load_wiki');\n\nmodule.exports = {\n  loadAlgorithm,\n  loadCategories,\n  loadFile,\n  loadScratchPaper,\n  shareScratchPaper,\n  loadWikiList,\n  loadWiki\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nconst {\n  getAlgorithmDir\n} = require('../utils');\n\nmodule.exports = (category, algorithm) => {\n  const dir = getAlgorithmDir(category, algorithm);\n  return getJSON(`${dir}desc.json`);\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nmodule.exports = () => {\n  return getJSON('./algorithm/category.json');\n};","'use strict';\n\nconst RSVP = require('rsvp');\n\nconst app = require('../app');\n\nconst {\n  getFileDir,\n  isScratchPaper\n} = require('../utils');\n\nconst {\n  checkLoading,\n  setPath\n} = require('./helpers');\n\nconst get = require('./ajax/get');\n\nconst loadDataAndCode = (dir) => {\n  return RSVP.hash({\n    data: get(`${dir}data.js`),\n    code: get(`${dir}code.js`)\n  });\n};\n\nconst loadFileAndUpdateContent = (dir) => {\n  app.getEditor().clearContent();\n\n  return loadDataAndCode(dir).then((content) => {\n    app.updateCachedFile(dir, content);\n    app.getEditor().setContent(content);\n  });\n};\n\nconst cachedContentExists = (cachedFile) => {\n  return cachedFile &&\n    cachedFile.data !== undefined &&\n    cachedFile.code !== undefined;\n};\n\nmodule.exports = (category, algorithm, file, explanation) => {\n  return new RSVP.Promise((resolve, reject) => {\n    if (checkLoading()) {\n      reject();\n    } else {\n      if (isScratchPaper(category)) {\n        setPath(category, app.getLoadedScratch());\n      } else {\n        setPath(category, algorithm, file);\n      }\n      $('#explanation').html(explanation);\n\n      let dir = getFileDir(category, algorithm, file);\n      app.setLastFileUsed(dir);\n      const cachedFile = app.getCachedFile(dir);\n\n      if (cachedContentExists(cachedFile)) {\n        app.getEditor().setContent(cachedFile);\n        resolve();\n      } else {\n        loadFileAndUpdateContent(dir).then(resolve, reject);\n      }\n    }\n  });\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../app');\n\nconst {\n  getFileDir\n} = require('../utils');\n\nconst getJSON = require('./ajax/get_json');\nconst loadAlgorithm = require('./load_algorithm');\n\nconst extractGistCode = (files, name) => files[`${name}.js`].content;\n\nmodule.exports = (gistID) => {\n  return new RSVP.Promise((resolve, reject) => {\n    app.setLoadedScratch(gistID);\n\n    getJSON(`https://api.github.com/gists/${gistID}`).then(({\n      files\n    }) => {\n\n      const category = 'scratch';\n      const algorithm = gistID;\n\n      loadAlgorithm(category, algorithm).then((data) => {\n\n        const algoData = extractGistCode(files, 'data');\n        const algoCode = extractGistCode(files, 'code');\n\n        // update scratch paper algo code with the loaded gist code\n        const dir = getFileDir(category, algorithm, 'scratch_paper');\n        app.updateCachedFile(dir, {\n          data: algoData,\n          code: algoCode,\n          'CREDIT.md': 'Shared by an anonymous user from http://parkjs814.github.io/AlgorithmVisualizer'\n        });\n\n        resolve({\n          category,\n          algorithm,\n          data\n        });\n      });\n    });\n  });\n\n};","'use strict';\n\nconst get = require('./ajax/get');\n\nmodule.exports = (wiki) => {\n  return get(`./AlgorithmVisualizer.wiki/${wiki}.md`);\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nmodule.exports = () => {\n  return getJSON('./wiki.json');\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../app');\n\nconst postJSON = require('./ajax/post_json');\n\nconst {\n  setPath\n} = require('./helpers');\n\nmodule.exports = () => {\n  return new RSVP.Promise((resolve, reject) => {\n\n    const {\n      dataEditor,\n      codeEditor\n    } = app.getEditor();\n\n    const gist = {\n      'description': 'temp',\n      'public': true,\n      'files': {\n        'data.js': {\n          'content': dataEditor.getValue()\n        },\n        'code.js': {\n          'content': codeEditor.getValue()\n        }\n      }\n    };\n\n    postJSON('https://api.github.com/gists', gist).then(({\n      id\n    }) => {\n      app.setLoadedScratch(id);\n      setPath('scratch', id);\n      const {\n        href\n      } = location;\n      $('#algorithm').html('Shared');\n      resolve(href);\n    });\n  });\n};","'use strict';\n\nconst TracerManager = require('./manager');\nconst Tracer = require('../module/tracer/tracer');\n\nmodule.exports = {\n\n  init() {\n    const tm = new TracerManager();\n    Tracer.prototype.manager = tm;\n    return tm;\n  }\n\n};","'use strict';\n\nconst app = require('../app');\nconst ModuleContainer = require('../dom/module_container');\nconst TopMenu = require('../dom/top_menu');\n\nconst {\n  each,\n  extend,\n  grep\n} = $;\n\nconst stepLimit = 1e6;\n\nconst TracerManager = function () {\n  this.timer = null;\n  this.pause = false;\n  this.capsules = [];\n  this.interval = 500;\n};\n\nTracerManager.prototype = {\n\n  add(tracer) {\n\n    const $container = ModuleContainer.create();\n\n    const capsule = {\n      module: tracer.module,\n      tracer,\n      allocated: true,\n      defaultName: null,\n      $container,\n      isNew: true\n    };\n\n    this.capsules.push(capsule);\n    return capsule;\n  },\n\n  allocate(newTracer) {\n    let selectedCapsule = null;\n    let count = 0;\n\n    each(this.capsules, (i, capsule) => {\n      if (capsule.module === newTracer.module) {\n        count++;\n        if (!capsule.allocated) {\n          capsule.tracer = newTracer;\n          capsule.allocated = true;\n          capsule.isNew = false;\n          selectedCapsule = capsule;\n          return false;\n        }\n      }\n    });\n\n    if (selectedCapsule === null) {\n      count++;\n      selectedCapsule = this.add(newTracer);\n    }\n\n    const className = newTracer.module.getClassName();\n    selectedCapsule.defaultName = `${className} ${count}`;\n    selectedCapsule.order = this.order++;\n    return selectedCapsule;\n  },\n\n  deallocateAll() {\n    this.order = 0;\n    this.reset();\n    each(this.capsules, (i, capsule) => {\n      capsule.allocated = false;\n    });\n  },\n\n  removeUnallocated() {\n    let changed = false;\n\n    this.capsules = grep(this.capsules, (capsule) => {\n      let removed = !capsule.allocated;\n\n      if (capsule.isNew || removed) {\n        changed = true;\n      }\n      if (removed) {\n        capsule.$container.remove();\n      }\n\n      return !removed;\n    });\n\n    if (changed) {\n      this.place();\n    }\n  },\n\n  place() {\n    const {\n      capsules\n    } = this;\n\n    each(capsules, (i, capsule) => {\n      let width = 100;\n      let height = (100 / capsules.length);\n      let top = height * capsule.order;\n\n      capsule.$container.css({\n        top: `${top}%`,\n        width: `${width}%`,\n        height: `${height}%`\n      });\n\n      capsule.tracer.resize();\n    });\n  },\n\n  resize() {\n    this.command('resize');\n  },\n\n  isPause() {\n    return this.pause;\n  },\n\n  setInterval(interval) {\n    TopMenu.setInterval(interval);\n  },\n\n  reset() {\n    this.traces = [];\n    this.traceIndex = -1;\n    this.stepCnt = 0;\n    if (this.timer) {\n      clearTimeout(this.timer);\n    }\n    this.command('clear');\n  },\n\n  pushStep(capsule, step) {\n    if (this.stepCnt++ > stepLimit) throw \"Tracer's stack overflow\";\n    let len = this.traces.length;\n    if (len == 0) len += this.newStep();\n    const last = this.traces[len - 1];\n    last.push(extend(step, {\n      capsule\n    }));\n  },\n\n  newStep(line = -1) {\n    let len = this.traces.length;\n    if (len > 0 && ~line) {\n      this.traces[len - 1].push(line);\n    }\n    return this.traces.push([]);\n  },\n\n  pauseStep() {\n    if (this.traceIndex < 0) return;\n    this.pause = true;\n    if (this.timer) {\n      clearTimeout(this.timer);\n    }\n    TopMenu.activateBtnPause();\n  },\n\n  resumeStep() {\n    this.pause = false;\n    this.step(this.traceIndex + 1);\n    TopMenu.deactivateBtnPause();\n  },\n\n  step(i, options = {}) {\n    const tracer = this;\n\n    if (isNaN(i) || i >= this.traces.length || i < 0) return;\n\n    this.traceIndex = i;\n    const trace = this.traces[i];\n    trace.forEach((step) => {\n      if (typeof step === 'number') {\n        app.getEditor().highlightLine(step);\n        return;\n      }\n      step.capsule.tracer.processStep(step, options);\n    });\n\n    if (!options.virtual) {\n      this.command('refresh');\n    }\n\n    if (this.pause) return;\n\n    this.timer = setTimeout(() => {\n      if (!tracer.nextStep(options)) {\n        TopMenu.resetTopMenuButtons();\n      }\n    }, this.interval);\n  },\n\n  prevStep(options = {}) {\n    this.command('clear');\n\n    const finalIndex = this.traceIndex - 1;\n    if (finalIndex < 0) {\n      this.traceIndex = -1;\n      this.command('refresh');\n      return false;\n    }\n\n    for (let i = 0; i < finalIndex; i++) {\n      this.step(i, extend(options, {\n        virtual: true\n      }));\n    }\n\n    this.step(finalIndex);\n    return true;\n  },\n\n  nextStep(options = {}) {\n    const finalIndex = this.traceIndex + 1;\n    if (finalIndex >= this.traces.length) {\n      this.traceIndex = this.traces.length - 1;\n      return false;\n    }\n\n    this.step(finalIndex, options);\n    return true;\n  },\n\n  visualize() {\n    this.traceIndex = -1;\n    this.resumeStep();\n  },\n\n  command(...args) {\n    const functionName = args.shift();\n    each(this.capsules, (i, capsule) => {\n      if (capsule.allocated) {\n        capsule.tracer.module.prototype[functionName].apply(capsule.tracer, args);\n      }\n    });\n  },\n\n  findOwner(container) {\n    let selectedCapsule = null;\n    each(this.capsules, (i, capsule) => {\n      if (capsule.$container[0] === container) {\n        selectedCapsule = capsule;\n        return false;\n      }\n    });\n    return selectedCapsule.tracer;\n  }\n};\n\nmodule.exports = TracerManager;\n","'use strict';\n\nconst {\n  parse\n} = JSON;\n\nconst fromJSON = (obj) => {\n  return parse(obj, (key, value) => {\n    return value === 'Infinity' ? Infinity : value;\n  });\n};\n\nmodule.exports = fromJSON;\n","'use strict';\n\nconst toJSON = require('./to_json');\nconst fromJSON = require('./from_json');\nconst refineByType = require('./refine_by_type');\n\nmodule.exports = {\n  toJSON,\n  fromJSON,\n  refineByType\n};\n","'use strict';\n\nconst refineByType = (item) => {\n  switch (typeof(item)) {\n    case 'number':\n      return refineNumber(item);\n    case 'boolean':\n      return refineBoolean(item);\n    default:\n      return refineString(item);\n  }\n};\n\nconst refineString = (str) => {\n  return str === '' ? ' ' : str;\n};\n\nconst refineNumber = (num) => {\n  return num === Infinity ? '∞' : num;\n};\n\nconst refineBoolean = (bool) => {\n  return bool ? 'T' : 'F';\n};\n\nmodule.exports = refineByType;\n","'use strict';\n\nconst {\n  stringify\n} = JSON;\n\nconst toJSON = (obj) => {\n  return stringify(obj, (key, value) => {\n    return value === Infinity ? 'Infinity' : value;\n  });\n};\n\nmodule.exports = toJSON;\n","'use strict';\n\nconst isScratchPaper = (category, algorithm) => {\n  return category == 'scratch';\n};\n\nconst getAlgorithmDir = (category, algorithm) => {\n  if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n  return `./algorithm/${category}/${algorithm}/`;\n};\n\nconst getFileDir = (category, algorithm, file) => {\n  if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n  return `./algorithm/${category}/${algorithm}/${file}/`;\n};\n\nmodule.exports = {\n  isScratchPaper,\n  getAlgorithmDir,\n  getFileDir\n};","// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = setTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    clearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        setTimeout(drainQueue, 0);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\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\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","/*!\n * @overview RSVP - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors\n * @license   Licensed under MIT license\n *            See https://raw.githubusercontent.com/tildeio/rsvp.js/master/LICENSE\n * @version   3.2.1\n */\n\n(function() {\n    \"use strict\";\n    function lib$rsvp$utils$$objectOrFunction(x) {\n      return typeof x === 'function' || (typeof x === 'object' && x !== null);\n    }\n\n    function lib$rsvp$utils$$isFunction(x) {\n      return typeof x === 'function';\n    }\n\n    function lib$rsvp$utils$$isMaybeThenable(x) {\n      return typeof x === 'object' && x !== null;\n    }\n\n    var lib$rsvp$utils$$_isArray;\n    if (!Array.isArray) {\n      lib$rsvp$utils$$_isArray = function (x) {\n        return Object.prototype.toString.call(x) === '[object Array]';\n      };\n    } else {\n      lib$rsvp$utils$$_isArray = Array.isArray;\n    }\n\n    var lib$rsvp$utils$$isArray = lib$rsvp$utils$$_isArray;\n\n    var lib$rsvp$utils$$now = Date.now || function() { return new Date().getTime(); };\n\n    function lib$rsvp$utils$$F() { }\n\n    var lib$rsvp$utils$$o_create = (Object.create || function (o) {\n      if (arguments.length > 1) {\n        throw new Error('Second argument not supported');\n      }\n      if (typeof o !== 'object') {\n        throw new TypeError('Argument must be an object');\n      }\n      lib$rsvp$utils$$F.prototype = o;\n      return new lib$rsvp$utils$$F();\n    });\n    function lib$rsvp$events$$indexOf(callbacks, callback) {\n      for (var i=0, l=callbacks.length; i<l; i++) {\n        if (callbacks[i] === callback) { return i; }\n      }\n\n      return -1;\n    }\n\n    function lib$rsvp$events$$callbacksFor(object) {\n      var callbacks = object._promiseCallbacks;\n\n      if (!callbacks) {\n        callbacks = object._promiseCallbacks = {};\n      }\n\n      return callbacks;\n    }\n\n    var lib$rsvp$events$$default = {\n\n      /**\n        `RSVP.EventTarget.mixin` extends an object with EventTarget methods. For\n        Example:\n\n        ```javascript\n        var object = {};\n\n        RSVP.EventTarget.mixin(object);\n\n        object.on('finished', function(event) {\n          // handle event\n        });\n\n        object.trigger('finished', { detail: value });\n        ```\n\n        `EventTarget.mixin` also works with prototypes:\n\n        ```javascript\n        var Person = function() {};\n        RSVP.EventTarget.mixin(Person.prototype);\n\n        var yehuda = new Person();\n        var tom = new Person();\n\n        yehuda.on('poke', function(event) {\n          console.log('Yehuda says OW');\n        });\n\n        tom.on('poke', function(event) {\n          console.log('Tom says OW');\n        });\n\n        yehuda.trigger('poke');\n        tom.trigger('poke');\n        ```\n\n        @method mixin\n        @for RSVP.EventTarget\n        @private\n        @param {Object} object object to extend with EventTarget methods\n      */\n      'mixin': function(object) {\n        object['on']      = this['on'];\n        object['off']     = this['off'];\n        object['trigger'] = this['trigger'];\n        object._promiseCallbacks = undefined;\n        return object;\n      },\n\n      /**\n        Registers a callback to be executed when `eventName` is triggered\n\n        ```javascript\n        object.on('event', function(eventInfo){\n          // handle the event\n        });\n\n        object.trigger('event');\n        ```\n\n        @method on\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName name of the event to listen for\n        @param {Function} callback function to be called when the event is triggered.\n      */\n      'on': function(eventName, callback) {\n        if (typeof callback !== 'function') {\n          throw new TypeError('Callback must be a function');\n        }\n\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks;\n\n        callbacks = allCallbacks[eventName];\n\n        if (!callbacks) {\n          callbacks = allCallbacks[eventName] = [];\n        }\n\n        if (lib$rsvp$events$$indexOf(callbacks, callback) === -1) {\n          callbacks.push(callback);\n        }\n      },\n\n      /**\n        You can use `off` to stop firing a particular callback for an event:\n\n        ```javascript\n        function doStuff() { // do stuff! }\n        object.on('stuff', doStuff);\n\n        object.trigger('stuff'); // doStuff will be called\n\n        // Unregister ONLY the doStuff callback\n        object.off('stuff', doStuff);\n        object.trigger('stuff'); // doStuff will NOT be called\n        ```\n\n        If you don't pass a `callback` argument to `off`, ALL callbacks for the\n        event will not be executed when the event fires. For example:\n\n        ```javascript\n        var callback1 = function(){};\n        var callback2 = function(){};\n\n        object.on('stuff', callback1);\n        object.on('stuff', callback2);\n\n        object.trigger('stuff'); // callback1 and callback2 will be executed.\n\n        object.off('stuff');\n        object.trigger('stuff'); // callback1 and callback2 will not be executed!\n        ```\n\n        @method off\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName event to stop listening to\n        @param {Function} callback optional argument. If given, only the function\n        given will be removed from the event's callback queue. If no `callback`\n        argument is given, all callbacks will be removed from the event's callback\n        queue.\n      */\n      'off': function(eventName, callback) {\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, index;\n\n        if (!callback) {\n          allCallbacks[eventName] = [];\n          return;\n        }\n\n        callbacks = allCallbacks[eventName];\n\n        index = lib$rsvp$events$$indexOf(callbacks, callback);\n\n        if (index !== -1) { callbacks.splice(index, 1); }\n      },\n\n      /**\n        Use `trigger` to fire custom events. For example:\n\n        ```javascript\n        object.on('foo', function(){\n          console.log('foo event happened!');\n        });\n        object.trigger('foo');\n        // 'foo event happened!' logged to the console\n        ```\n\n        You can also pass a value as a second argument to `trigger` that will be\n        passed as an argument to all event listeners for the event:\n\n        ```javascript\n        object.on('foo', function(value){\n          console.log(value.name);\n        });\n\n        object.trigger('foo', { name: 'bar' });\n        // 'bar' logged to the console\n        ```\n\n        @method trigger\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName name of the event to be triggered\n        @param {*} options optional value to be passed to any event handlers for\n        the given `eventName`\n      */\n      'trigger': function(eventName, options, label) {\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, callback;\n\n        if (callbacks = allCallbacks[eventName]) {\n          // Don't cache the callbacks.length since it may grow\n          for (var i=0; i<callbacks.length; i++) {\n            callback = callbacks[i];\n\n            callback(options, label);\n          }\n        }\n      }\n    };\n\n    var lib$rsvp$config$$config = {\n      instrument: false\n    };\n\n    lib$rsvp$events$$default['mixin'](lib$rsvp$config$$config);\n\n    function lib$rsvp$config$$configure(name, value) {\n      if (name === 'onerror') {\n        // handle for legacy users that expect the actual\n        // error to be passed to their function added via\n        // `RSVP.configure('onerror', someFunctionHere);`\n        lib$rsvp$config$$config['on']('error', value);\n        return;\n      }\n\n      if (arguments.length === 2) {\n        lib$rsvp$config$$config[name] = value;\n      } else {\n        return lib$rsvp$config$$config[name];\n      }\n    }\n\n    var lib$rsvp$instrument$$queue = [];\n\n    function lib$rsvp$instrument$$scheduleFlush() {\n      setTimeout(function() {\n        var entry;\n        for (var i = 0; i < lib$rsvp$instrument$$queue.length; i++) {\n          entry = lib$rsvp$instrument$$queue[i];\n\n          var payload = entry.payload;\n\n          payload.guid = payload.key + payload.id;\n          payload.childGuid = payload.key + payload.childId;\n          if (payload.error) {\n            payload.stack = payload.error.stack;\n          }\n\n          lib$rsvp$config$$config['trigger'](entry.name, entry.payload);\n        }\n        lib$rsvp$instrument$$queue.length = 0;\n      }, 50);\n    }\n\n    function lib$rsvp$instrument$$instrument(eventName, promise, child) {\n      if (1 === lib$rsvp$instrument$$queue.push({\n        name: eventName,\n        payload: {\n          key: promise._guidKey,\n          id:  promise._id,\n          eventName: eventName,\n          detail: promise._result,\n          childId: child && child._id,\n          label: promise._label,\n          timeStamp: lib$rsvp$utils$$now(),\n          error: lib$rsvp$config$$config[\"instrument-with-stack\"] ? new Error(promise._label) : null\n        }})) {\n          lib$rsvp$instrument$$scheduleFlush();\n        }\n      }\n    var lib$rsvp$instrument$$default = lib$rsvp$instrument$$instrument;\n    function lib$rsvp$then$$then(onFulfillment, onRejection, label) {\n      var parent = this;\n      var state = parent._state;\n\n      if (state === lib$rsvp$$internal$$FULFILLED && !onFulfillment || state === lib$rsvp$$internal$$REJECTED && !onRejection) {\n        lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, parent);\n        return parent;\n      }\n\n      parent._onError = null;\n\n      var child = new parent.constructor(lib$rsvp$$internal$$noop, label);\n      var result = parent._result;\n\n      lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, child);\n\n      if (state) {\n        var callback = arguments[state - 1];\n        lib$rsvp$config$$config.async(function(){\n          lib$rsvp$$internal$$invokeCallback(state, child, callback, result);\n        });\n      } else {\n        lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection);\n      }\n\n      return child;\n    }\n    var lib$rsvp$then$$default = lib$rsvp$then$$then;\n    function lib$rsvp$promise$resolve$$resolve(object, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n\n      if (object && typeof object === 'object' && object.constructor === Constructor) {\n        return object;\n      }\n\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      lib$rsvp$$internal$$resolve(promise, object);\n      return promise;\n    }\n    var lib$rsvp$promise$resolve$$default = lib$rsvp$promise$resolve$$resolve;\n    function lib$rsvp$enumerator$$makeSettledResult(state, position, value) {\n      if (state === lib$rsvp$$internal$$FULFILLED) {\n        return {\n          state: 'fulfilled',\n          value: value\n        };\n      } else {\n         return {\n          state: 'rejected',\n          reason: value\n        };\n      }\n    }\n\n    function lib$rsvp$enumerator$$Enumerator(Constructor, input, abortOnReject, label) {\n      this._instanceConstructor = Constructor;\n      this.promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      this._abortOnReject = abortOnReject;\n\n      if (this._validateInput(input)) {\n        this._input     = input;\n        this.length     = input.length;\n        this._remaining = input.length;\n\n        this._init();\n\n        if (this.length === 0) {\n          lib$rsvp$$internal$$fulfill(this.promise, this._result);\n        } else {\n          this.length = this.length || 0;\n          this._enumerate();\n          if (this._remaining === 0) {\n            lib$rsvp$$internal$$fulfill(this.promise, this._result);\n          }\n        }\n      } else {\n        lib$rsvp$$internal$$reject(this.promise, this._validationError());\n      }\n    }\n\n    var lib$rsvp$enumerator$$default = lib$rsvp$enumerator$$Enumerator;\n\n    lib$rsvp$enumerator$$Enumerator.prototype._validateInput = function(input) {\n      return lib$rsvp$utils$$isArray(input);\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._validationError = function() {\n      return new Error('Array Methods must be provided an Array');\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._init = function() {\n      this._result = new Array(this.length);\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._enumerate = function() {\n      var length     = this.length;\n      var promise    = this.promise;\n      var input      = this._input;\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        this._eachEntry(input[i], i);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._settleMaybeThenable = function(entry, i) {\n      var c = this._instanceConstructor;\n      var resolve = c.resolve;\n\n      if (resolve === lib$rsvp$promise$resolve$$default) {\n        var then = lib$rsvp$$internal$$getThen(entry);\n\n        if (then === lib$rsvp$then$$default &&\n            entry._state !== lib$rsvp$$internal$$PENDING) {\n          entry._onError = null;\n          this._settledAt(entry._state, i, entry._result);\n        } else if (typeof then !== 'function') {\n          this._remaining--;\n          this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n        } else if (c === lib$rsvp$promise$$default) {\n          var promise = new c(lib$rsvp$$internal$$noop);\n          lib$rsvp$$internal$$handleMaybeThenable(promise, entry, then);\n          this._willSettleAt(promise, i);\n        } else {\n          this._willSettleAt(new c(function(resolve) { resolve(entry); }), i);\n        }\n      } else {\n        this._willSettleAt(resolve(entry), i);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._eachEntry = function(entry, i) {\n      if (lib$rsvp$utils$$isMaybeThenable(entry)) {\n        this._settleMaybeThenable(entry, i);\n      } else {\n        this._remaining--;\n        this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._settledAt = function(state, i, value) {\n      var promise = this.promise;\n\n      if (promise._state === lib$rsvp$$internal$$PENDING) {\n        this._remaining--;\n\n        if (this._abortOnReject && state === lib$rsvp$$internal$$REJECTED) {\n          lib$rsvp$$internal$$reject(promise, value);\n        } else {\n          this._result[i] = this._makeResult(state, i, value);\n        }\n      }\n\n      if (this._remaining === 0) {\n        lib$rsvp$$internal$$fulfill(promise, this._result);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._makeResult = function(state, i, value) {\n      return value;\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._willSettleAt = function(promise, i) {\n      var enumerator = this;\n\n      lib$rsvp$$internal$$subscribe(promise, undefined, function(value) {\n        enumerator._settledAt(lib$rsvp$$internal$$FULFILLED, i, value);\n      }, function(reason) {\n        enumerator._settledAt(lib$rsvp$$internal$$REJECTED, i, reason);\n      });\n    };\n    function lib$rsvp$promise$all$$all(entries, label) {\n      return new lib$rsvp$enumerator$$default(this, entries, true /* abort on reject */, label).promise;\n    }\n    var lib$rsvp$promise$all$$default = lib$rsvp$promise$all$$all;\n    function lib$rsvp$promise$race$$race(entries, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n\n      if (!lib$rsvp$utils$$isArray(entries)) {\n        lib$rsvp$$internal$$reject(promise, new TypeError('You must pass an array to race.'));\n        return promise;\n      }\n\n      var length = entries.length;\n\n      function onFulfillment(value) {\n        lib$rsvp$$internal$$resolve(promise, value);\n      }\n\n      function onRejection(reason) {\n        lib$rsvp$$internal$$reject(promise, reason);\n      }\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        lib$rsvp$$internal$$subscribe(Constructor.resolve(entries[i]), undefined, onFulfillment, onRejection);\n      }\n\n      return promise;\n    }\n    var lib$rsvp$promise$race$$default = lib$rsvp$promise$race$$race;\n    function lib$rsvp$promise$reject$$reject(reason, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      lib$rsvp$$internal$$reject(promise, reason);\n      return promise;\n    }\n    var lib$rsvp$promise$reject$$default = lib$rsvp$promise$reject$$reject;\n\n    var lib$rsvp$promise$$guidKey = 'rsvp_' + lib$rsvp$utils$$now() + '-';\n    var lib$rsvp$promise$$counter = 0;\n\n    function lib$rsvp$promise$$needsResolver() {\n      throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n    }\n\n    function lib$rsvp$promise$$needsNew() {\n      throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n    }\n\n    function lib$rsvp$promise$$Promise(resolver, label) {\n      this._id = lib$rsvp$promise$$counter++;\n      this._label = label;\n      this._state = undefined;\n      this._result = undefined;\n      this._subscribers = [];\n\n      lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('created', this);\n\n      if (lib$rsvp$$internal$$noop !== resolver) {\n        typeof resolver !== 'function' && lib$rsvp$promise$$needsResolver();\n        this instanceof lib$rsvp$promise$$Promise ? lib$rsvp$$internal$$initializePromise(this, resolver) : lib$rsvp$promise$$needsNew();\n      }\n    }\n\n    var lib$rsvp$promise$$default = lib$rsvp$promise$$Promise;\n\n    // deprecated\n    lib$rsvp$promise$$Promise.cast = lib$rsvp$promise$resolve$$default;\n    lib$rsvp$promise$$Promise.all = lib$rsvp$promise$all$$default;\n    lib$rsvp$promise$$Promise.race = lib$rsvp$promise$race$$default;\n    lib$rsvp$promise$$Promise.resolve = lib$rsvp$promise$resolve$$default;\n    lib$rsvp$promise$$Promise.reject = lib$rsvp$promise$reject$$default;\n\n    lib$rsvp$promise$$Promise.prototype = {\n      constructor: lib$rsvp$promise$$Promise,\n\n      _guidKey: lib$rsvp$promise$$guidKey,\n\n      _onError: function (reason) {\n        var promise = this;\n        lib$rsvp$config$$config.after(function() {\n          if (promise._onError) {\n            lib$rsvp$config$$config['trigger']('error', reason, promise._label);\n          }\n        });\n      },\n\n    /**\n      The primary way of interacting with a promise is through its `then` method,\n      which registers callbacks to receive either a promise's eventual value or the\n      reason why the promise cannot be fulfilled.\n\n      ```js\n      findUser().then(function(user){\n        // user is available\n      }, function(reason){\n        // user is unavailable, and you are given the reason why\n      });\n      ```\n\n      Chaining\n      --------\n\n      The return value of `then` is itself a promise.  This second, 'downstream'\n      promise is resolved with the return value of the first promise's fulfillment\n      or rejection handler, or rejected if the handler throws an exception.\n\n      ```js\n      findUser().then(function (user) {\n        return user.name;\n      }, function (reason) {\n        return 'default name';\n      }).then(function (userName) {\n        // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n        // will be `'default name'`\n      });\n\n      findUser().then(function (user) {\n        throw new Error('Found user, but still unhappy');\n      }, function (reason) {\n        throw new Error('`findUser` rejected and we're unhappy');\n      }).then(function (value) {\n        // never reached\n      }, function (reason) {\n        // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n        // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n      });\n      ```\n      If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n\n      ```js\n      findUser().then(function (user) {\n        throw new PedagogicalException('Upstream error');\n      }).then(function (value) {\n        // never reached\n      }).then(function (value) {\n        // never reached\n      }, function (reason) {\n        // The `PedgagocialException` is propagated all the way down to here\n      });\n      ```\n\n      Assimilation\n      ------------\n\n      Sometimes the value you want to propagate to a downstream promise can only be\n      retrieved asynchronously. This can be achieved by returning a promise in the\n      fulfillment or rejection handler. The downstream promise will then be pending\n      until the returned promise is settled. This is called *assimilation*.\n\n      ```js\n      findUser().then(function (user) {\n        return findCommentsByAuthor(user);\n      }).then(function (comments) {\n        // The user's comments are now available\n      });\n      ```\n\n      If the assimliated promise rejects, then the downstream promise will also reject.\n\n      ```js\n      findUser().then(function (user) {\n        return findCommentsByAuthor(user);\n      }).then(function (comments) {\n        // If `findCommentsByAuthor` fulfills, we'll have the value here\n      }, function (reason) {\n        // If `findCommentsByAuthor` rejects, we'll have the reason here\n      });\n      ```\n\n      Simple Example\n      --------------\n\n      Synchronous Example\n\n      ```javascript\n      var result;\n\n      try {\n        result = findResult();\n        // success\n      } catch(reason) {\n        // failure\n      }\n      ```\n\n      Errback Example\n\n      ```js\n      findResult(function(result, err){\n        if (err) {\n          // failure\n        } else {\n          // success\n        }\n      });\n      ```\n\n      Promise Example;\n\n      ```javascript\n      findResult().then(function(result){\n        // success\n      }, function(reason){\n        // failure\n      });\n      ```\n\n      Advanced Example\n      --------------\n\n      Synchronous Example\n\n      ```javascript\n      var author, books;\n\n      try {\n        author = findAuthor();\n        books  = findBooksByAuthor(author);\n        // success\n      } catch(reason) {\n        // failure\n      }\n      ```\n\n      Errback Example\n\n      ```js\n\n      function foundBooks(books) {\n\n      }\n\n      function failure(reason) {\n\n      }\n\n      findAuthor(function(author, err){\n        if (err) {\n          failure(err);\n          // failure\n        } else {\n          try {\n            findBoooksByAuthor(author, function(books, err) {\n              if (err) {\n                failure(err);\n              } else {\n                try {\n                  foundBooks(books);\n                } catch(reason) {\n                  failure(reason);\n                }\n              }\n            });\n          } catch(error) {\n            failure(err);\n          }\n          // success\n        }\n      });\n      ```\n\n      Promise Example;\n\n      ```javascript\n      findAuthor().\n        then(findBooksByAuthor).\n        then(function(books){\n          // found books\n      }).catch(function(reason){\n        // something went wrong\n      });\n      ```\n\n      @method then\n      @param {Function} onFulfillment\n      @param {Function} onRejection\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      then: lib$rsvp$then$$default,\n\n    /**\n      `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n      as the catch block of a try/catch statement.\n\n      ```js\n      function findAuthor(){\n        throw new Error('couldn't find that author');\n      }\n\n      // synchronous\n      try {\n        findAuthor();\n      } catch(reason) {\n        // something went wrong\n      }\n\n      // async with promises\n      findAuthor().catch(function(reason){\n        // something went wrong\n      });\n      ```\n\n      @method catch\n      @param {Function} onRejection\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      'catch': function(onRejection, label) {\n        return this.then(undefined, onRejection, label);\n      },\n\n    /**\n      `finally` will be invoked regardless of the promise's fate just as native\n      try/catch/finally behaves\n\n      Synchronous example:\n\n      ```js\n      findAuthor() {\n        if (Math.random() > 0.5) {\n          throw new Error();\n        }\n        return new Author();\n      }\n\n      try {\n        return findAuthor(); // succeed or fail\n      } catch(error) {\n        return findOtherAuther();\n      } finally {\n        // always runs\n        // doesn't affect the return value\n      }\n      ```\n\n      Asynchronous example:\n\n      ```js\n      findAuthor().catch(function(reason){\n        return findOtherAuther();\n      }).finally(function(){\n        // author was either found, or not\n      });\n      ```\n\n      @method finally\n      @param {Function} callback\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      'finally': function(callback, label) {\n        var promise = this;\n        var constructor = promise.constructor;\n\n        return promise.then(function(value) {\n          return constructor.resolve(callback()).then(function() {\n            return value;\n          });\n        }, function(reason) {\n          return constructor.resolve(callback()).then(function() {\n            return constructor.reject(reason);\n          });\n        }, label);\n      }\n    };\n    function  lib$rsvp$$internal$$withOwnPromise() {\n      return new TypeError('A promises callback cannot return that same promise.');\n    }\n\n    function lib$rsvp$$internal$$noop() {}\n\n    var lib$rsvp$$internal$$PENDING   = void 0;\n    var lib$rsvp$$internal$$FULFILLED = 1;\n    var lib$rsvp$$internal$$REJECTED  = 2;\n\n    var lib$rsvp$$internal$$GET_THEN_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n    function lib$rsvp$$internal$$getThen(promise) {\n      try {\n        return promise.then;\n      } catch(error) {\n        lib$rsvp$$internal$$GET_THEN_ERROR.error = error;\n        return lib$rsvp$$internal$$GET_THEN_ERROR;\n      }\n    }\n\n    function lib$rsvp$$internal$$tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n      try {\n        then.call(value, fulfillmentHandler, rejectionHandler);\n      } catch(e) {\n        return e;\n      }\n    }\n\n    function lib$rsvp$$internal$$handleForeignThenable(promise, thenable, then) {\n      lib$rsvp$config$$config.async(function(promise) {\n        var sealed = false;\n        var error = lib$rsvp$$internal$$tryThen(then, thenable, function(value) {\n          if (sealed) { return; }\n          sealed = true;\n          if (thenable !== value) {\n            lib$rsvp$$internal$$resolve(promise, value, undefined);\n          } else {\n            lib$rsvp$$internal$$fulfill(promise, value);\n          }\n        }, function(reason) {\n          if (sealed) { return; }\n          sealed = true;\n\n          lib$rsvp$$internal$$reject(promise, reason);\n        }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n        if (!sealed && error) {\n          sealed = true;\n          lib$rsvp$$internal$$reject(promise, error);\n        }\n      }, promise);\n    }\n\n    function lib$rsvp$$internal$$handleOwnThenable(promise, thenable) {\n      if (thenable._state === lib$rsvp$$internal$$FULFILLED) {\n        lib$rsvp$$internal$$fulfill(promise, thenable._result);\n      } else if (thenable._state === lib$rsvp$$internal$$REJECTED) {\n        thenable._onError = null;\n        lib$rsvp$$internal$$reject(promise, thenable._result);\n      } else {\n        lib$rsvp$$internal$$subscribe(thenable, undefined, function(value) {\n          if (thenable !== value) {\n            lib$rsvp$$internal$$resolve(promise, value, undefined);\n          } else {\n            lib$rsvp$$internal$$fulfill(promise, value);\n          }\n        }, function(reason) {\n          lib$rsvp$$internal$$reject(promise, reason);\n        });\n      }\n    }\n\n    function lib$rsvp$$internal$$handleMaybeThenable(promise, maybeThenable, then) {\n      if (maybeThenable.constructor === promise.constructor &&\n          then === lib$rsvp$then$$default &&\n          constructor.resolve === lib$rsvp$promise$resolve$$default) {\n        lib$rsvp$$internal$$handleOwnThenable(promise, maybeThenable);\n      } else {\n        if (then === lib$rsvp$$internal$$GET_THEN_ERROR) {\n          lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$GET_THEN_ERROR.error);\n        } else if (then === undefined) {\n          lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n        } else if (lib$rsvp$utils$$isFunction(then)) {\n          lib$rsvp$$internal$$handleForeignThenable(promise, maybeThenable, then);\n        } else {\n          lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n        }\n      }\n    }\n\n    function lib$rsvp$$internal$$resolve(promise, value) {\n      if (promise === value) {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      } else if (lib$rsvp$utils$$objectOrFunction(value)) {\n        lib$rsvp$$internal$$handleMaybeThenable(promise, value, lib$rsvp$$internal$$getThen(value));\n      } else {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      }\n    }\n\n    function lib$rsvp$$internal$$publishRejection(promise) {\n      if (promise._onError) {\n        promise._onError(promise._result);\n      }\n\n      lib$rsvp$$internal$$publish(promise);\n    }\n\n    function lib$rsvp$$internal$$fulfill(promise, value) {\n      if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n\n      promise._result = value;\n      promise._state = lib$rsvp$$internal$$FULFILLED;\n\n      if (promise._subscribers.length === 0) {\n        if (lib$rsvp$config$$config.instrument) {\n          lib$rsvp$instrument$$default('fulfilled', promise);\n        }\n      } else {\n        lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, promise);\n      }\n    }\n\n    function lib$rsvp$$internal$$reject(promise, reason) {\n      if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n      promise._state = lib$rsvp$$internal$$REJECTED;\n      promise._result = reason;\n      lib$rsvp$config$$config.async(lib$rsvp$$internal$$publishRejection, promise);\n    }\n\n    function lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection) {\n      var subscribers = parent._subscribers;\n      var length = subscribers.length;\n\n      parent._onError = null;\n\n      subscribers[length] = child;\n      subscribers[length + lib$rsvp$$internal$$FULFILLED] = onFulfillment;\n      subscribers[length + lib$rsvp$$internal$$REJECTED]  = onRejection;\n\n      if (length === 0 && parent._state) {\n        lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, parent);\n      }\n    }\n\n    function lib$rsvp$$internal$$publish(promise) {\n      var subscribers = promise._subscribers;\n      var settled = promise._state;\n\n      if (lib$rsvp$config$$config.instrument) {\n        lib$rsvp$instrument$$default(settled === lib$rsvp$$internal$$FULFILLED ? 'fulfilled' : 'rejected', promise);\n      }\n\n      if (subscribers.length === 0) { return; }\n\n      var child, callback, detail = promise._result;\n\n      for (var i = 0; i < subscribers.length; i += 3) {\n        child = subscribers[i];\n        callback = subscribers[i + settled];\n\n        if (child) {\n          lib$rsvp$$internal$$invokeCallback(settled, child, callback, detail);\n        } else {\n          callback(detail);\n        }\n      }\n\n      promise._subscribers.length = 0;\n    }\n\n    function lib$rsvp$$internal$$ErrorObject() {\n      this.error = null;\n    }\n\n    var lib$rsvp$$internal$$TRY_CATCH_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n    function lib$rsvp$$internal$$tryCatch(callback, detail) {\n      try {\n        return callback(detail);\n      } catch(e) {\n        lib$rsvp$$internal$$TRY_CATCH_ERROR.error = e;\n        return lib$rsvp$$internal$$TRY_CATCH_ERROR;\n      }\n    }\n\n    function lib$rsvp$$internal$$invokeCallback(settled, promise, callback, detail) {\n      var hasCallback = lib$rsvp$utils$$isFunction(callback),\n          value, error, succeeded, failed;\n\n      if (hasCallback) {\n        value = lib$rsvp$$internal$$tryCatch(callback, detail);\n\n        if (value === lib$rsvp$$internal$$TRY_CATCH_ERROR) {\n          failed = true;\n          error = value.error;\n          value = null;\n        } else {\n          succeeded = true;\n        }\n\n        if (promise === value) {\n          lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$withOwnPromise());\n          return;\n        }\n\n      } else {\n        value = detail;\n        succeeded = true;\n      }\n\n      if (promise._state !== lib$rsvp$$internal$$PENDING) {\n        // noop\n      } else if (hasCallback && succeeded) {\n        lib$rsvp$$internal$$resolve(promise, value);\n      } else if (failed) {\n        lib$rsvp$$internal$$reject(promise, error);\n      } else if (settled === lib$rsvp$$internal$$FULFILLED) {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      } else if (settled === lib$rsvp$$internal$$REJECTED) {\n        lib$rsvp$$internal$$reject(promise, value);\n      }\n    }\n\n    function lib$rsvp$$internal$$initializePromise(promise, resolver) {\n      var resolved = false;\n      try {\n        resolver(function resolvePromise(value){\n          if (resolved) { return; }\n          resolved = true;\n          lib$rsvp$$internal$$resolve(promise, value);\n        }, function rejectPromise(reason) {\n          if (resolved) { return; }\n          resolved = true;\n          lib$rsvp$$internal$$reject(promise, reason);\n        });\n      } catch(e) {\n        lib$rsvp$$internal$$reject(promise, e);\n      }\n    }\n\n    function lib$rsvp$all$settled$$AllSettled(Constructor, entries, label) {\n      this._superConstructor(Constructor, entries, false /* don't abort on reject */, label);\n    }\n\n    lib$rsvp$all$settled$$AllSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n    lib$rsvp$all$settled$$AllSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$all$settled$$AllSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n    lib$rsvp$all$settled$$AllSettled.prototype._validationError = function() {\n      return new Error('allSettled must be called with an array');\n    };\n\n    function lib$rsvp$all$settled$$allSettled(entries, label) {\n      return new lib$rsvp$all$settled$$AllSettled(lib$rsvp$promise$$default, entries, label).promise;\n    }\n    var lib$rsvp$all$settled$$default = lib$rsvp$all$settled$$allSettled;\n    function lib$rsvp$all$$all(array, label) {\n      return lib$rsvp$promise$$default.all(array, label);\n    }\n    var lib$rsvp$all$$default = lib$rsvp$all$$all;\n    var lib$rsvp$asap$$len = 0;\n    var lib$rsvp$asap$$toString = {}.toString;\n    var lib$rsvp$asap$$vertxNext;\n    function lib$rsvp$asap$$asap(callback, arg) {\n      lib$rsvp$asap$$queue[lib$rsvp$asap$$len] = callback;\n      lib$rsvp$asap$$queue[lib$rsvp$asap$$len + 1] = arg;\n      lib$rsvp$asap$$len += 2;\n      if (lib$rsvp$asap$$len === 2) {\n        // If len is 1, that means that we need to schedule an async flush.\n        // If additional callbacks are queued before the queue is flushed, they\n        // will be processed by this flush that we are scheduling.\n        lib$rsvp$asap$$scheduleFlush();\n      }\n    }\n\n    var lib$rsvp$asap$$default = lib$rsvp$asap$$asap;\n\n    var lib$rsvp$asap$$browserWindow = (typeof window !== 'undefined') ? window : undefined;\n    var lib$rsvp$asap$$browserGlobal = lib$rsvp$asap$$browserWindow || {};\n    var lib$rsvp$asap$$BrowserMutationObserver = lib$rsvp$asap$$browserGlobal.MutationObserver || lib$rsvp$asap$$browserGlobal.WebKitMutationObserver;\n    var lib$rsvp$asap$$isNode = typeof self === 'undefined' &&\n      typeof process !== 'undefined' && {}.toString.call(process) === '[object process]';\n\n    // test for web worker but not in IE10\n    var lib$rsvp$asap$$isWorker = typeof Uint8ClampedArray !== 'undefined' &&\n      typeof importScripts !== 'undefined' &&\n      typeof MessageChannel !== 'undefined';\n\n    // node\n    function lib$rsvp$asap$$useNextTick() {\n      var nextTick = process.nextTick;\n      // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n      // setImmediate should be used instead instead\n      var version = process.versions.node.match(/^(?:(\\d+)\\.)?(?:(\\d+)\\.)?(\\*|\\d+)$/);\n      if (Array.isArray(version) && version[1] === '0' && version[2] === '10') {\n        nextTick = setImmediate;\n      }\n      return function() {\n        nextTick(lib$rsvp$asap$$flush);\n      };\n    }\n\n    // vertx\n    function lib$rsvp$asap$$useVertxTimer() {\n      return function() {\n        lib$rsvp$asap$$vertxNext(lib$rsvp$asap$$flush);\n      };\n    }\n\n    function lib$rsvp$asap$$useMutationObserver() {\n      var iterations = 0;\n      var observer = new lib$rsvp$asap$$BrowserMutationObserver(lib$rsvp$asap$$flush);\n      var node = document.createTextNode('');\n      observer.observe(node, { characterData: true });\n\n      return function() {\n        node.data = (iterations = ++iterations % 2);\n      };\n    }\n\n    // web worker\n    function lib$rsvp$asap$$useMessageChannel() {\n      var channel = new MessageChannel();\n      channel.port1.onmessage = lib$rsvp$asap$$flush;\n      return function () {\n        channel.port2.postMessage(0);\n      };\n    }\n\n    function lib$rsvp$asap$$useSetTimeout() {\n      return function() {\n        setTimeout(lib$rsvp$asap$$flush, 1);\n      };\n    }\n\n    var lib$rsvp$asap$$queue = new Array(1000);\n    function lib$rsvp$asap$$flush() {\n      for (var i = 0; i < lib$rsvp$asap$$len; i+=2) {\n        var callback = lib$rsvp$asap$$queue[i];\n        var arg = lib$rsvp$asap$$queue[i+1];\n\n        callback(arg);\n\n        lib$rsvp$asap$$queue[i] = undefined;\n        lib$rsvp$asap$$queue[i+1] = undefined;\n      }\n\n      lib$rsvp$asap$$len = 0;\n    }\n\n    function lib$rsvp$asap$$attemptVertex() {\n      try {\n        var r = require;\n        var vertx = r('vertx');\n        lib$rsvp$asap$$vertxNext = vertx.runOnLoop || vertx.runOnContext;\n        return lib$rsvp$asap$$useVertxTimer();\n      } catch(e) {\n        return lib$rsvp$asap$$useSetTimeout();\n      }\n    }\n\n    var lib$rsvp$asap$$scheduleFlush;\n    // Decide what async method to use to triggering processing of queued callbacks:\n    if (lib$rsvp$asap$$isNode) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useNextTick();\n    } else if (lib$rsvp$asap$$BrowserMutationObserver) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMutationObserver();\n    } else if (lib$rsvp$asap$$isWorker) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMessageChannel();\n    } else if (lib$rsvp$asap$$browserWindow === undefined && typeof require === 'function') {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$attemptVertex();\n    } else {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useSetTimeout();\n    }\n    function lib$rsvp$defer$$defer(label) {\n      var deferred = {};\n\n      deferred['promise'] = new lib$rsvp$promise$$default(function(resolve, reject) {\n        deferred['resolve'] = resolve;\n        deferred['reject'] = reject;\n      }, label);\n\n      return deferred;\n    }\n    var lib$rsvp$defer$$default = lib$rsvp$defer$$defer;\n    function lib$rsvp$filter$$filter(promises, filterFn, label) {\n      return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n        if (!lib$rsvp$utils$$isFunction(filterFn)) {\n          throw new TypeError(\"You must pass a function as filter's second argument.\");\n        }\n\n        var length = values.length;\n        var filtered = new Array(length);\n\n        for (var i = 0; i < length; i++) {\n          filtered[i] = filterFn(values[i]);\n        }\n\n        return lib$rsvp$promise$$default.all(filtered, label).then(function(filtered) {\n          var results = new Array(length);\n          var newLength = 0;\n\n          for (var i = 0; i < length; i++) {\n            if (filtered[i]) {\n              results[newLength] = values[i];\n              newLength++;\n            }\n          }\n\n          results.length = newLength;\n\n          return results;\n        });\n      });\n    }\n    var lib$rsvp$filter$$default = lib$rsvp$filter$$filter;\n\n    function lib$rsvp$promise$hash$$PromiseHash(Constructor, object, label) {\n      this._superConstructor(Constructor, object, true, label);\n    }\n\n    var lib$rsvp$promise$hash$$default = lib$rsvp$promise$hash$$PromiseHash;\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n    lib$rsvp$promise$hash$$PromiseHash.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$promise$hash$$PromiseHash.prototype._init = function() {\n      this._result = {};\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._validateInput = function(input) {\n      return input && typeof input === 'object';\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._validationError = function() {\n      return new Error('Promise.hash must be called with an object');\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._enumerate = function() {\n      var enumerator = this;\n      var promise    = enumerator.promise;\n      var input      = enumerator._input;\n      var results    = [];\n\n      for (var key in input) {\n        if (promise._state === lib$rsvp$$internal$$PENDING && Object.prototype.hasOwnProperty.call(input, key)) {\n          results.push({\n            position: key,\n            entry: input[key]\n          });\n        }\n      }\n\n      var length = results.length;\n      enumerator._remaining = length;\n      var result;\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        result = results[i];\n        enumerator._eachEntry(result.entry, result.position);\n      }\n    };\n\n    function lib$rsvp$hash$settled$$HashSettled(Constructor, object, label) {\n      this._superConstructor(Constructor, object, false, label);\n    }\n\n    lib$rsvp$hash$settled$$HashSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$promise$hash$$default.prototype);\n    lib$rsvp$hash$settled$$HashSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$hash$settled$$HashSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n\n    lib$rsvp$hash$settled$$HashSettled.prototype._validationError = function() {\n      return new Error('hashSettled must be called with an object');\n    };\n\n    function lib$rsvp$hash$settled$$hashSettled(object, label) {\n      return new lib$rsvp$hash$settled$$HashSettled(lib$rsvp$promise$$default, object, label).promise;\n    }\n    var lib$rsvp$hash$settled$$default = lib$rsvp$hash$settled$$hashSettled;\n    function lib$rsvp$hash$$hash(object, label) {\n      return new lib$rsvp$promise$hash$$default(lib$rsvp$promise$$default, object, label).promise;\n    }\n    var lib$rsvp$hash$$default = lib$rsvp$hash$$hash;\n    function lib$rsvp$map$$map(promises, mapFn, label) {\n      return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n        if (!lib$rsvp$utils$$isFunction(mapFn)) {\n          throw new TypeError(\"You must pass a function as map's second argument.\");\n        }\n\n        var length = values.length;\n        var results = new Array(length);\n\n        for (var i = 0; i < length; i++) {\n          results[i] = mapFn(values[i]);\n        }\n\n        return lib$rsvp$promise$$default.all(results, label);\n      });\n    }\n    var lib$rsvp$map$$default = lib$rsvp$map$$map;\n\n    function lib$rsvp$node$$Result() {\n      this.value = undefined;\n    }\n\n    var lib$rsvp$node$$ERROR = new lib$rsvp$node$$Result();\n    var lib$rsvp$node$$GET_THEN_ERROR = new lib$rsvp$node$$Result();\n\n    function lib$rsvp$node$$getThen(obj) {\n      try {\n       return obj.then;\n      } catch(error) {\n        lib$rsvp$node$$ERROR.value= error;\n        return lib$rsvp$node$$ERROR;\n      }\n    }\n\n\n    function lib$rsvp$node$$tryApply(f, s, a) {\n      try {\n        f.apply(s, a);\n      } catch(error) {\n        lib$rsvp$node$$ERROR.value = error;\n        return lib$rsvp$node$$ERROR;\n      }\n    }\n\n    function lib$rsvp$node$$makeObject(_, argumentNames) {\n      var obj = {};\n      var name;\n      var i;\n      var length = _.length;\n      var args = new Array(length);\n\n      for (var x = 0; x < length; x++) {\n        args[x] = _[x];\n      }\n\n      for (i = 0; i < argumentNames.length; i++) {\n        name = argumentNames[i];\n        obj[name] = args[i + 1];\n      }\n\n      return obj;\n    }\n\n    function lib$rsvp$node$$arrayResult(_) {\n      var length = _.length;\n      var args = new Array(length - 1);\n\n      for (var i = 1; i < length; i++) {\n        args[i - 1] = _[i];\n      }\n\n      return args;\n    }\n\n    function lib$rsvp$node$$wrapThenable(then, promise) {\n      return {\n        then: function(onFulFillment, onRejection) {\n          return then.call(promise, onFulFillment, onRejection);\n        }\n      };\n    }\n\n    function lib$rsvp$node$$denodeify(nodeFunc, options) {\n      var fn = function() {\n        var self = this;\n        var l = arguments.length;\n        var args = new Array(l + 1);\n        var arg;\n        var promiseInput = false;\n\n        for (var i = 0; i < l; ++i) {\n          arg = arguments[i];\n\n          if (!promiseInput) {\n            // TODO: clean this up\n            promiseInput = lib$rsvp$node$$needsPromiseInput(arg);\n            if (promiseInput === lib$rsvp$node$$GET_THEN_ERROR) {\n              var p = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n              lib$rsvp$$internal$$reject(p, lib$rsvp$node$$GET_THEN_ERROR.value);\n              return p;\n            } else if (promiseInput && promiseInput !== true) {\n              arg = lib$rsvp$node$$wrapThenable(promiseInput, arg);\n            }\n          }\n          args[i] = arg;\n        }\n\n        var promise = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n\n        args[l] = function(err, val) {\n          if (err)\n            lib$rsvp$$internal$$reject(promise, err);\n          else if (options === undefined)\n            lib$rsvp$$internal$$resolve(promise, val);\n          else if (options === true)\n            lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$arrayResult(arguments));\n          else if (lib$rsvp$utils$$isArray(options))\n            lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$makeObject(arguments, options));\n          else\n            lib$rsvp$$internal$$resolve(promise, val);\n        };\n\n        if (promiseInput) {\n          return lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self);\n        } else {\n          return lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self);\n        }\n      };\n\n      fn.__proto__ = nodeFunc;\n\n      return fn;\n    }\n\n    var lib$rsvp$node$$default = lib$rsvp$node$$denodeify;\n\n    function lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self) {\n      var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n      if (result === lib$rsvp$node$$ERROR) {\n        lib$rsvp$$internal$$reject(promise, result.value);\n      }\n      return promise;\n    }\n\n    function lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self){\n      return lib$rsvp$promise$$default.all(args).then(function(args){\n        var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n        if (result === lib$rsvp$node$$ERROR) {\n          lib$rsvp$$internal$$reject(promise, result.value);\n        }\n        return promise;\n      });\n    }\n\n    function lib$rsvp$node$$needsPromiseInput(arg) {\n      if (arg && typeof arg === 'object') {\n        if (arg.constructor === lib$rsvp$promise$$default) {\n          return true;\n        } else {\n          return lib$rsvp$node$$getThen(arg);\n        }\n      } else {\n        return false;\n      }\n    }\n    var lib$rsvp$platform$$platform;\n\n    /* global self */\n    if (typeof self === 'object') {\n      lib$rsvp$platform$$platform = self;\n\n    /* global global */\n    } else if (typeof global === 'object') {\n      lib$rsvp$platform$$platform = global;\n    } else {\n      throw new Error('no global: `self` or `global` found');\n    }\n\n    var lib$rsvp$platform$$default = lib$rsvp$platform$$platform;\n    function lib$rsvp$race$$race(array, label) {\n      return lib$rsvp$promise$$default.race(array, label);\n    }\n    var lib$rsvp$race$$default = lib$rsvp$race$$race;\n    function lib$rsvp$reject$$reject(reason, label) {\n      return lib$rsvp$promise$$default.reject(reason, label);\n    }\n    var lib$rsvp$reject$$default = lib$rsvp$reject$$reject;\n    function lib$rsvp$resolve$$resolve(value, label) {\n      return lib$rsvp$promise$$default.resolve(value, label);\n    }\n    var lib$rsvp$resolve$$default = lib$rsvp$resolve$$resolve;\n    function lib$rsvp$rethrow$$rethrow(reason) {\n      setTimeout(function() {\n        throw reason;\n      });\n      throw reason;\n    }\n    var lib$rsvp$rethrow$$default = lib$rsvp$rethrow$$rethrow;\n\n    // defaults\n    lib$rsvp$config$$config.async = lib$rsvp$asap$$default;\n    lib$rsvp$config$$config.after = function(cb) {\n      setTimeout(cb, 0);\n    };\n    var lib$rsvp$$cast = lib$rsvp$resolve$$default;\n    function lib$rsvp$$async(callback, arg) {\n      lib$rsvp$config$$config.async(callback, arg);\n    }\n\n    function lib$rsvp$$on() {\n      lib$rsvp$config$$config['on'].apply(lib$rsvp$config$$config, arguments);\n    }\n\n    function lib$rsvp$$off() {\n      lib$rsvp$config$$config['off'].apply(lib$rsvp$config$$config, arguments);\n    }\n\n    // Set up instrumentation through `window.__PROMISE_INTRUMENTATION__`\n    if (typeof window !== 'undefined' && typeof window['__PROMISE_INSTRUMENTATION__'] === 'object') {\n      var lib$rsvp$$callbacks = window['__PROMISE_INSTRUMENTATION__'];\n      lib$rsvp$config$$configure('instrument', true);\n      for (var lib$rsvp$$eventName in lib$rsvp$$callbacks) {\n        if (lib$rsvp$$callbacks.hasOwnProperty(lib$rsvp$$eventName)) {\n          lib$rsvp$$on(lib$rsvp$$eventName, lib$rsvp$$callbacks[lib$rsvp$$eventName]);\n        }\n      }\n    }\n\n    var lib$rsvp$umd$$RSVP = {\n      'race': lib$rsvp$race$$default,\n      'Promise': lib$rsvp$promise$$default,\n      'allSettled': lib$rsvp$all$settled$$default,\n      'hash': lib$rsvp$hash$$default,\n      'hashSettled': lib$rsvp$hash$settled$$default,\n      'denodeify': lib$rsvp$node$$default,\n      'on': lib$rsvp$$on,\n      'off': lib$rsvp$$off,\n      'map': lib$rsvp$map$$default,\n      'filter': lib$rsvp$filter$$default,\n      'resolve': lib$rsvp$resolve$$default,\n      'reject': lib$rsvp$reject$$default,\n      'all': lib$rsvp$all$$default,\n      'rethrow': lib$rsvp$rethrow$$default,\n      'defer': lib$rsvp$defer$$default,\n      'EventTarget': lib$rsvp$events$$default,\n      'configure': lib$rsvp$config$$configure,\n      'async': lib$rsvp$$async\n    };\n\n    /* global define:true module:true window: true */\n    if (typeof define === 'function' && define['amd']) {\n      define(function() { return lib$rsvp$umd$$RSVP; });\n    } else if (typeof module !== 'undefined' && module['exports']) {\n      module['exports'] = lib$rsvp$umd$$RSVP;\n    } else if (typeof lib$rsvp$platform$$default !== 'undefined') {\n      lib$rsvp$platform$$default['RSVP'] = lib$rsvp$umd$$RSVP;\n    }\n}).call(this);\n\n"]}\n"],"file":"algorithm_visualizer.js","sourceRoot":"/source/"} \ No newline at end of file +{"version":3,"names":[],"mappings":"","sources":["algorithm_visualizer.js"],"sourcesContent":["/**\n * algorithm-visualizer - Algorithm Visualizer\n * @version v0.1.0\n * @author Jason Park & contributors\n * @link https://github.com/parkjs814/AlgorithmVisualizer#readme\n * @license MIT\n */\n(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})({1:[function(require,module,exports){\n'use strict';\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\nvar cache = {\n lastFileUsed: '',\n files: {}\n};\n\nvar assertFileName = function assertFileName(name) {\n if (!name) {\n throw 'Missing file name';\n }\n};\n\n/**\n * Global application cache\n */\nmodule.exports = {\n getCachedFile: function getCachedFile(name) {\n assertFileName(name);\n return cache.files[name];\n },\n updateCachedFile: function updateCachedFile(name, updates) {\n assertFileName(name);\n if (!cache.files[name]) {\n cache.files[name] = {};\n }\n extend(cache.files[name], updates);\n },\n getLastFileUsed: function getLastFileUsed() {\n return cache.lastFileUsed;\n },\n setLastFileUsed: function setLastFileUsed(file) {\n cache.lastFileUsed = file;\n }\n};\n\n},{}],2:[function(require,module,exports){\n'use strict';\n\nvar Editor = require('../editor');\nvar TracerManager = require('../tracer_manager');\nvar DOM = require('../dom/setup');\n\nvar _require = require('../dom/loading_slider');\n\nvar showLoadingSlider = _require.showLoadingSlider;\nvar hideLoadingSlider = _require.hideLoadingSlider;\n\n\nvar Cache = require('./cache');\n\nvar state = {\n isLoading: null,\n editor: null,\n tracerManager: null,\n categories: null,\n loadedScratch: null,\n wikiList: null\n};\n\nvar initState = function initState(tracerManager) {\n state.isLoading = false;\n state.editor = new Editor(tracerManager);\n state.tracerManager = tracerManager;\n state.categories = {};\n state.loadedScratch = null;\n state.wikiList = [];\n};\n\n/**\n * Global application singleton.\n */\nvar App = function App() {\n\n this.getIsLoading = function () {\n return state.isLoading;\n };\n\n this.setIsLoading = function (loading) {\n state.isLoading = loading;\n if (loading) {\n showLoadingSlider();\n } else {\n hideLoadingSlider();\n }\n };\n\n this.getEditor = function () {\n return state.editor;\n };\n\n this.getCategories = function () {\n return state.categories;\n };\n\n this.getCategory = function (name) {\n return state.categories[name];\n };\n\n this.setCategories = function (categories) {\n state.categories = categories;\n };\n\n this.updateCategory = function (name, updates) {\n $.extend(state.categories[name], updates);\n };\n\n this.getTracerManager = function () {\n return state.tracerManager;\n };\n\n this.getLoadedScratch = function () {\n return state.loadedScratch;\n };\n\n this.setLoadedScratch = function (loadedScratch) {\n state.loadedScratch = loadedScratch;\n };\n\n this.getWikiList = function () {\n return state.wikiList;\n };\n\n this.setWikiList = function (wikiList) {\n state.wikiList = wikiList;\n };\n\n this.hasWiki = function (wiki) {\n return ~state.wikiList.indexOf(wiki);\n };\n\n var tracerManager = TracerManager.init();\n\n initState(tracerManager);\n DOM.setup(tracerManager);\n};\n\nApp.prototype = Cache;\n\nmodule.exports = App;\n\n},{\"../dom/loading_slider\":7,\"../dom/setup\":9,\"../editor\":28,\"../tracer_manager\":64,\"./cache\":1}],3:[function(require,module,exports){\n'use strict';\n\n/**\n * This is the main application instance.\n * Gets populated on page load. \n */\n\nmodule.exports = {};\n\n},{}],4:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar Server = require('../server');\nvar showAlgorithm = require('./show_algorithm');\n\nvar _$ = $;\nvar each = _$.each;\n\n\nvar getAlgorithmDOM = function getAlgorithmDOM(category, subList, algorithm) {\n return $('<button class=\"indent\">').append(subList[algorithm]).attr('data-algorithm', algorithm).attr('data-category', category).click(function () {\n Server.loadAlgorithm(category, algorithm).then(function (data) {\n showAlgorithm(category, algorithm, data);\n });\n });\n\n $('#list').append($algorithm);\n};\n\nvar addCategoryToDOM = function addCategoryToDOM(category) {\n var _app$getCategory = app.getCategory(category);\n\n var categoryName = _app$getCategory.name;\n var categorySubList = _app$getCategory.list;\n\n\n var $category = $('<button class=\"category\">').append('<i class=\"fa fa-fw fa-caret-right\">').append(categoryName).attr('data-category', category);\n\n $category.click(function () {\n var $self = $(this);\n $self.toggleClass('open');\n $self.next().toggleClass('collapse');\n $self.find('i.fa').toggleClass('fa-caret-right fa-caret-down');\n });\n\n var $algorithms = $('<div class=\"algorithms collapse\">');\n $('#list').append($category).append($algorithms);\n\n each(categorySubList, function (algorithm) {\n var $algorithm = getAlgorithmDOM(category, categorySubList, algorithm);\n $algorithms.append($algorithm);\n });\n};\n\nmodule.exports = function () {\n each(app.getCategories(), addCategoryToDOM);\n};\n\n},{\"../app\":3,\"../server\":56,\"./show_algorithm\":19}],5:[function(require,module,exports){\n'use strict';\n\nvar Server = require('../server');\n\nvar _$ = $;\nvar each = _$.each;\n\n\nvar addFileToDOM = function addFileToDOM(category, algorithm, file, explanation) {\n var $file = $('<button>').append(file).attr('data-file', file).click(function () {\n Server.loadFile(category, algorithm, file, explanation);\n $('.files_bar > .wrapper > button').removeClass('active');\n $(this).addClass('active');\n });\n $('.files_bar > .wrapper').append($file);\n return $file;\n};\n\nmodule.exports = function (category, algorithm, files, requestedFile) {\n $('.files_bar > .wrapper').empty();\n\n each(files, function (file, explanation) {\n var $file = addFileToDOM(category, algorithm, file, explanation);\n if (requestedFile && requestedFile == file) $file.click();\n });\n\n if (!requestedFile) $('.files_bar > .wrapper > button').first().click();\n $('.files_bar > .wrapper').scroll();\n};\n\n},{\"../server\":56}],6:[function(require,module,exports){\n'use strict';\n\nvar showAlgorithm = require('./show_algorithm');\nvar addCategories = require('./add_categories');\nvar showDescription = require('./show_description');\nvar addFiles = require('./add_files');\nvar showFirstAlgorithm = require('./show_first_algorithm');\nvar showRequestedAlgorithm = require('./show_requested_algorithm');\nvar showWiki = require('./show_wiki');\n\nmodule.exports = {\n showAlgorithm: showAlgorithm,\n addCategories: addCategories,\n showDescription: showDescription,\n addFiles: addFiles,\n showFirstAlgorithm: showFirstAlgorithm,\n showRequestedAlgorithm: showRequestedAlgorithm,\n showWiki: showWiki\n};\n\n},{\"./add_categories\":4,\"./add_files\":5,\"./show_algorithm\":19,\"./show_description\":20,\"./show_first_algorithm\":21,\"./show_requested_algorithm\":22,\"./show_wiki\":23}],7:[function(require,module,exports){\n'use strict';\n\nvar showLoadingSlider = function showLoadingSlider() {\n $('#loading-slider').removeClass('loaded');\n};\n\nvar hideLoadingSlider = function hideLoadingSlider() {\n $('#loading-slider').addClass('loaded');\n};\n\nmodule.exports = {\n showLoadingSlider: showLoadingSlider,\n hideLoadingSlider: hideLoadingSlider\n};\n\n},{}],8:[function(require,module,exports){\n'use strict';\n\nvar create = function create() {\n var $container = $('<section class=\"module_wrapper\">');\n $('.module_container').append($container);\n return $container;\n};\n\nmodule.exports = {\n create: create\n};\n\n},{}],9:[function(require,module,exports){\n'use strict';\n\nvar setupDividers = require('./setup_dividers');\nvar setupDocument = require('./setup_document');\nvar setupFilesBar = require('./setup_files_bar');\nvar setupInterval = require('./setup_interval');\nvar setupModuleContainer = require('./setup_module_container');\nvar setupTabContainer = require('./setup_tab_container');\nvar setupSideMenu = require('./setup_side_menu');\nvar setupTopMenu = require('./setup_top_menu');\nvar setupWindow = require('./setup_window');\n\n/**\n * Initializes elements once the app loads in the DOM.\n */\nvar setup = function setup() {\n\n $('.btn input').click(function (e) {\n e.stopPropagation();\n });\n\n // dividers\n setupDividers();\n\n // document\n setupDocument();\n\n // files bar\n setupFilesBar();\n\n // interval\n setupInterval();\n\n // module container\n setupModuleContainer();\n\n // tab container\n setupTabContainer();\n\n // side menu\n setupSideMenu();\n\n // top menu\n setupTopMenu();\n\n // window\n setupWindow();\n};\n\nmodule.exports = {\n setup: setup\n};\n\n},{\"./setup_dividers\":10,\"./setup_document\":11,\"./setup_files_bar\":12,\"./setup_interval\":13,\"./setup_module_container\":14,\"./setup_side_menu\":15,\"./setup_tab_container\":16,\"./setup_top_menu\":17,\"./setup_window\":18}],10:[function(require,module,exports){\n'use strict';\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar app = require('../../app');\n\nvar addDividerToDom = function addDividerToDom(divider) {\n var _divider = _slicedToArray(divider, 3);\n\n var vertical = _divider[0];\n var $first = _divider[1];\n var $second = _divider[2];\n\n var $parent = $first.parent();\n var thickness = 5;\n\n var $divider = $('<div class=\"divider\">');\n\n var dragging = false;\n if (vertical) {\n (function () {\n $divider.addClass('vertical');\n\n var _left = -thickness / 2;\n $divider.css({\n top: 0,\n bottom: 0,\n left: _left,\n width: thickness\n });\n\n var x = void 0;\n $divider.mousedown(function (_ref) {\n var pageX = _ref.pageX;\n\n x = pageX;\n dragging = true;\n });\n\n $(document).mousemove(function (_ref2) {\n var pageX = _ref2.pageX;\n\n if (dragging) {\n var new_left = $second.position().left + pageX - x;\n var percent = new_left / $parent.width() * 100;\n percent = Math.min(90, Math.max(10, percent));\n $first.css('right', 100 - percent + '%');\n $second.css('left', percent + '%');\n x = pageX;\n app.getTracerManager().resize();\n $('.files_bar > .wrapper').scroll();\n }\n });\n\n $(document).mouseup(function (e) {\n dragging = false;\n });\n })();\n } else {\n (function () {\n\n $divider.addClass('horizontal');\n var _top = -thickness / 2;\n $divider.css({\n top: _top,\n height: thickness,\n left: 0,\n right: 0\n });\n\n var y = void 0;\n $divider.mousedown(function (_ref3) {\n var pageY = _ref3.pageY;\n\n y = pageY;\n dragging = true;\n });\n\n $(document).mousemove(function (_ref4) {\n var pageY = _ref4.pageY;\n\n if (dragging) {\n var new_top = $second.position().top + pageY - y;\n var percent = new_top / $parent.height() * 100;\n percent = Math.min(90, Math.max(10, percent));\n $first.css('bottom', 100 - percent + '%');\n $second.css('top', percent + '%');\n y = pageY;\n app.getTracerManager().resize();\n }\n });\n\n $(document).mouseup(function (e) {\n dragging = false;\n });\n })();\n }\n\n $second.append($divider);\n};\n\nmodule.exports = function () {\n var dividers = [['v', $('.sidemenu'), $('.workspace')], ['v', $('.viewer_container'), $('.editor_container')], ['h', $('.data_container'), $('.code_container')]];\n for (var i = 0; i < dividers.length; i++) {\n addDividerToDom(dividers[i]);\n }\n};\n\n},{\"../../app\":3}],11:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n $(document).on('click', 'a', function (e) {\n var href = $(this).attr('href');\n if (/^(https?:\\/\\/).+/.test(href)) {\n e.preventDefault();\n if (!window.open(href, '_blank')) {\n alert('Please allow popups for this site');\n }\n }\n });\n\n $(document).mouseup(function (e) {\n app.getTracerManager().command('mouseup', e);\n });\n};\n\n},{\"../../app\":3}],12:[function(require,module,exports){\n'use strict';\n\nvar definitelyBigger = function definitelyBigger(x, y) {\n return x > y + 2;\n};\n\nmodule.exports = function () {\n\n $('.files_bar > .btn-left').click(function () {\n var $wrapper = $('.files_bar > .wrapper');\n var clipWidth = $wrapper.width();\n var scrollLeft = $wrapper.scrollLeft();\n\n $($wrapper.children('button').get().reverse()).each(function () {\n var left = $(this).position().left;\n var right = left + $(this).outerWidth();\n if (0 > left) {\n $wrapper.scrollLeft(scrollLeft + right - clipWidth);\n return false;\n }\n });\n });\n\n $('.files_bar > .btn-right').click(function () {\n var $wrapper = $('.files_bar > .wrapper');\n var clipWidth = $wrapper.width();\n var scrollLeft = $wrapper.scrollLeft();\n\n $wrapper.children('button').each(function () {\n var left = $(this).position().left;\n var right = left + $(this).outerWidth();\n if (clipWidth < right) {\n $wrapper.scrollLeft(scrollLeft + left);\n return false;\n }\n });\n });\n\n $('.files_bar > .wrapper').scroll(function () {\n\n var $wrapper = $('.files_bar > .wrapper');\n var clipWidth = $wrapper.width();\n var $left = $wrapper.children('button:first-child');\n var $right = $wrapper.children('button:last-child');\n var left = $left.position().left;\n var right = $right.position().left + $right.outerWidth();\n\n if (definitelyBigger(0, left) && definitelyBigger(clipWidth, right)) {\n var scrollLeft = $wrapper.scrollLeft();\n $wrapper.scrollLeft(scrollLeft + clipWidth - right);\n return;\n }\n\n var lefter = definitelyBigger(0, left);\n var righter = definitelyBigger(right, clipWidth);\n $wrapper.toggleClass('shadow-left', lefter);\n $wrapper.toggleClass('shadow-right', righter);\n $('.files_bar > .btn-left').attr('disabled', !lefter);\n $('.files_bar > .btn-right').attr('disabled', !righter);\n });\n};\n\n},{}],13:[function(require,module,exports){\n'use strict';\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar app = require('../../app');\nvar Toast = require('../toast');\n\nvar parseFloat = Number.parseFloat;\n\n\nvar minInterval = 0.1;\nvar maxInterval = 10;\nvar startInterval = 0.5;\nvar stepInterval = 0.1;\n\nvar normalize = function normalize(sec) {\n\n var interval = void 0;\n var message = void 0;\n if (sec < minInterval) {\n interval = minInterval;\n message = 'Interval of ' + sec + ' seconds is too low. Setting to min allowed interval of ' + minInterval + ' second(s).';\n } else if (sec > maxInterval) {\n interval = maxInterval;\n message = 'Interval of ' + sec + ' seconds is too high. Setting to max allowed interval of ' + maxInterval + ' second(s).';\n } else {\n interval = sec;\n message = 'Interval has been set to ' + sec + ' second(s).';\n }\n\n return [interval, message];\n};\n\nmodule.exports = function () {\n\n var $interval = $('#interval');\n $interval.val(startInterval);\n $interval.attr({\n max: maxInterval,\n min: minInterval,\n step: stepInterval\n });\n\n $('#interval').on('change', function () {\n var tracerManager = app.getTracerManager();\n\n var _normalize = normalize(parseFloat($(this).val()));\n\n var _normalize2 = _slicedToArray(_normalize, 2);\n\n var seconds = _normalize2[0];\n var message = _normalize2[1];\n\n\n $(this).val(seconds);\n tracerManager.interval = seconds * 1000;\n Toast.showInfoToast(message);\n });\n};\n\n},{\"../../app\":3,\"../toast\":24}],14:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n\n var $module_container = $('.module_container');\n\n $module_container.on('mousedown', '.module_wrapper', function (e) {\n app.getTracerManager().findOwner(this).mousedown(e);\n });\n\n $module_container.on('mousemove', '.module_wrapper', function (e) {\n app.getTracerManager().findOwner(this).mousemove(e);\n });\n\n $module_container.on('DOMMouseScroll mousewheel', '.module_wrapper', function (e) {\n app.getTracerManager().findOwner(this).mousewheel(e);\n });\n};\n\n},{\"../../app\":3}],15:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\nvar Server = require('../../server');\nvar showAlgorithm = require('../show_algorithm');\n\nvar sidemenu_percent = void 0;\n\nmodule.exports = function () {\n $('#navigation').click(function () {\n var $sidemenu = $('.sidemenu');\n var $workspace = $('.workspace');\n\n $sidemenu.toggleClass('active');\n $('.nav-dropdown').toggleClass('fa-caret-down fa-caret-up');\n\n if ($sidemenu.hasClass('active')) {\n $sidemenu.css('right', 100 - sidemenu_percent + '%');\n $workspace.css('left', sidemenu_percent + '%');\n } else {\n sidemenu_percent = $workspace.position().left / $('body').width() * 100;\n $sidemenu.css('right', 0);\n $workspace.css('left', 0);\n }\n\n app.getTracerManager().resize();\n });\n\n $('#documentation').click(function () {\n $('#btn_doc').click();\n });\n\n $('#powered-by').click(function () {\n $('#powered-by-list button').toggleClass('collapse');\n });\n\n $('#scratch-paper').click(function () {\n var category = 'scratch';\n var algorithm = app.getLoadedScratch();\n Server.loadAlgorithm(category, algorithm).then(function (data) {\n showAlgorithm(category, algorithm, data);\n });\n });\n};\n\n},{\"../../app\":3,\"../../server\":56,\"../show_algorithm\":19}],16:[function(require,module,exports){\n'use strict';\n\nmodule.exports = function () {\n $('.tab_bar > button').click(function () {\n $('.tab_bar > button').removeClass('active');\n $('.tab_container > .tab').removeClass('active');\n $(this).addClass('active');\n $($(this).attr('data-target')).addClass('active');\n });\n};\n\n},{}],17:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\nvar Server = require('../../server');\nvar Toast = require('../toast');\nvar TopMenu = require('../top_menu');\n\nmodule.exports = function () {\n\n // shared\n $('#shared').mouseup(function () {\n $(this).select();\n });\n\n $('#btn_share').click(function () {\n\n var $icon = $(this).find('.fa-share');\n $icon.addClass('fa-spin fa-spin-faster');\n\n Server.shareScratchPaper().then(function (url) {\n $icon.removeClass('fa-spin fa-spin-faster');\n $('#shared').removeClass('collapse');\n $('#shared').val(url);\n Toast.showInfoToast('Shareable link is created.');\n });\n });\n\n // control\n\n var $btnRun = $('#btn_run');\n var $btnTrace = $('#btn_trace');\n var $btnPause = $('#btn_pause');\n var $btnPrev = $('#btn_prev');\n var $btnNext = $('#btn_next');\n\n // initially, control buttons are disabled\n TopMenu.disableFlowControl();\n\n $btnRun.click(function () {\n $btnTrace.click();\n $btnPause.removeClass('active');\n $btnRun.addClass('active');\n TopMenu.enableFlowControl();\n var err = app.getEditor().execute();\n if (err) {\n console.error(err);\n Toast.showErrorToast(err);\n TopMenu.resetTopMenuButtons();\n }\n });\n\n $btnPause.click(function () {\n $btnRun.toggleClass('active');\n $btnPause.toggleClass('active');\n if (app.getTracerManager().isPause()) {\n app.getTracerManager().resumeStep();\n } else {\n app.getTracerManager().pauseStep();\n }\n });\n\n $btnPrev.click(function () {\n $btnRun.removeClass('active');\n $btnPause.addClass('active');\n app.getTracerManager().pauseStep();\n app.getTracerManager().prevStep();\n });\n\n $btnNext.click(function () {\n $btnRun.removeClass('active');\n $btnPause.addClass('active');\n app.getTracerManager().pauseStep();\n app.getTracerManager().nextStep();\n });\n};\n\n},{\"../../app\":3,\"../../server\":56,\"../toast\":24,\"../top_menu\":25}],18:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n $(window).resize(function () {\n app.getTracerManager().resize();\n });\n};\n\n},{\"../../app\":3}],19:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\n\nvar _require = require('../utils');\n\nvar isScratchPaper = _require.isScratchPaper;\n\n\nvar showDescription = require('./show_description');\nvar addFiles = require('./add_files');\n\nmodule.exports = function (category, algorithm, data, requestedFile) {\n var $menu = void 0;\n var category_name = void 0;\n var algorithm_name = void 0;\n\n if (isScratchPaper(category)) {\n $menu = $('#scratch-paper');\n category_name = 'Scratch Paper';\n algorithm_name = algorithm ? 'Shared' : 'Temporary';\n } else {\n $menu = $('[data-category=\"' + category + '\"][data-algorithm=\"' + algorithm + '\"]');\n var categoryObj = app.getCategory(category);\n category_name = categoryObj.name;\n algorithm_name = categoryObj.list[algorithm];\n }\n\n $('.sidemenu button').removeClass('active');\n $menu.addClass('active');\n\n $('#category').html(category_name);\n $('#algorithm').html(algorithm_name);\n $('#tab_desc > .wrapper').empty();\n $('.files_bar > .wrapper').empty();\n $('#explanation').html('');\n\n app.setLastFileUsed(null);\n app.getEditor().clearContent();\n\n var files = data.files;\n\n\n delete data.files;\n\n showDescription(data);\n addFiles(category, algorithm, files, requestedFile);\n};\n\n},{\"../app\":3,\"../utils\":70,\"./add_files\":5,\"./show_description\":20}],20:[function(require,module,exports){\n'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol ? \"symbol\" : typeof obj; };\n\nvar isArray = Array.isArray;\nvar _$ = $;\nvar each = _$.each;\n\n\nmodule.exports = function (data) {\n var $container = $('#tab_desc > .wrapper');\n $container.empty();\n\n each(data, function (key, value) {\n\n if (key) {\n $container.append($('<h3>').html(key));\n }\n\n if (typeof value === 'string') {\n $container.append($('<p>').html(value));\n } else if (isArray(value)) {\n (function () {\n\n var $ul = $('<ul class=\"applications\">');\n $container.append($ul);\n\n value.forEach(function (li) {\n $ul.append($('<li>').html(li));\n });\n })();\n } else if ((typeof value === 'undefined' ? 'undefined' : _typeof(value)) === 'object') {\n (function () {\n\n var $ul = $('<ul class=\"complexities\">');\n $container.append($ul);\n\n each(value, function (prop) {\n var $wrapper = $('<div class=\"complexity\">');\n var $type = $('<span class=\"complexity-type\">').html(prop + ': ');\n var $value = $('<span class=\"complexity-value\">').html('' + value[prop]);\n\n $wrapper.append($type).append($value);\n\n $ul.append($('<li>').append($wrapper));\n });\n })();\n }\n });\n};\n\n},{}],21:[function(require,module,exports){\n'use strict';\n\n// click the first algorithm in the first category\n\nmodule.exports = function () {\n $('#list .category').first().click();\n $('#list .category + .algorithms > .indent').first().click();\n};\n\n},{}],22:[function(require,module,exports){\n'use strict';\n\nvar Server = require('../server');\nvar showAlgorithm = require('./show_algorithm');\n\nmodule.exports = function (category, algorithm, file) {\n $('.category[data-category=\"' + category + '\"]').click();\n Server.loadAlgorithm(category, algorithm).then(function (data) {\n showAlgorithm(category, algorithm, data, file);\n });\n};\n\n},{\"../server\":56,\"./show_algorithm\":19}],23:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar Server = require('../server');\nvar converter = new showdown.Converter({ tables: true });\n\nmodule.exports = function (wiki) {\n Server.loadWiki(wiki).then(function (data) {\n $('#tab_doc > .wrapper').html(converter.makeHtml('#' + wiki + '\\n' + data));\n $('#tab_doc').scrollTop(0);\n $('#tab_doc > .wrapper a').click(function (e) {\n var href = $(this).attr('href');\n if (app.hasWiki(href)) {\n e.preventDefault();\n module.exports(href);\n }\n });\n });\n};\n\n},{\"../app\":3,\"../server\":56}],24:[function(require,module,exports){\n'use strict';\n\nvar showToast = function showToast(data, type) {\n var $toast = $('<div class=\"toast ' + type + '\">').append(data);\n\n $('.toast_container').append($toast);\n setTimeout(function () {\n $toast.fadeOut(function () {\n $toast.remove();\n });\n }, 3000);\n};\n\nvar showErrorToast = function showErrorToast(err) {\n showToast(err, 'error');\n};\n\nvar showInfoToast = function showInfoToast(err) {\n showToast(err, 'info');\n};\n\nmodule.exports = {\n showErrorToast: showErrorToast,\n showInfoToast: showInfoToast\n};\n\n},{}],25:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\n\nvar flowControlBtns = [$('#btn_pause'), $('#btn_prev'), $('#btn_next')];\nvar setFlowControlState = function setFlowControlState(isDisabled) {\n flowControlBtns.forEach(function ($btn) {\n return $btn.attr('disabled', isDisabled);\n });\n};\n\nvar enableFlowControl = function enableFlowControl() {\n setFlowControlState(false);\n};\n\nvar disableFlowControl = function disableFlowControl() {\n setFlowControlState(true);\n};\n\nvar resetTopMenuButtons = function resetTopMenuButtons() {\n $('.top-menu-buttons button').removeClass('active');\n disableFlowControl();\n app.getEditor().unhighlightLine();\n};\n\nvar setInterval = function setInterval(val) {\n $('#interval').val(interval);\n};\n\nvar activateBtnPause = function activateBtnPause() {\n $('#btn_pause').addClass('active');\n};\n\nvar deactivateBtnPause = function deactivateBtnPause() {\n $('#btn_pause').removeClass('active');\n};\n\nmodule.exports = {\n enableFlowControl: enableFlowControl,\n disableFlowControl: disableFlowControl,\n resetTopMenuButtons: resetTopMenuButtons,\n setInterval: setInterval,\n activateBtnPause: activateBtnPause,\n deactivateBtnPause: deactivateBtnPause\n};\n\n},{\"../app\":3}],26:[function(require,module,exports){\n'use strict';\n\nmodule.exports = function (id) {\n var editor = ace.edit(id);\n\n editor.setOptions({\n enableBasicAutocompletion: true,\n enableSnippets: true,\n enableLiveAutocompletion: true\n });\n\n editor.setTheme('ace/theme/tomorrow_night_eighties');\n editor.session.setMode('ace/mode/javascript');\n editor.$blockScrolling = Infinity;\n\n return editor;\n};\n\n},{}],27:[function(require,module,exports){\n'use strict';\n\nvar execute = function execute(tracerManager, code, dataLines) {\n // all modules available to eval are obtained from window\n try {\n (function () {\n tracerManager.deallocateAll();\n var lines = code.split('\\n');\n var newLines = [];\n lines.forEach(function (line, i) {\n newLines.push(line.replace(/(.+\\. *_wait *)(\\( *\\))/g, '$1(' + (i - dataLines) + ')'));\n });\n eval(newLines.join('\\n'));\n tracerManager.visualize();\n })();\n } catch (err) {\n return err;\n } finally {\n tracerManager.removeUnallocated();\n }\n};\n\nvar executeData = function executeData(tracerManager, algoData) {\n return execute(tracerManager, algoData);\n};\n\nvar executeDataAndCode = function executeDataAndCode(tracerManager, algoData, algoCode) {\n var dataLines = algoData.split('\\n').length;\n return execute(tracerManager, algoData + '\\n' + algoCode, dataLines);\n};\n\nmodule.exports = {\n executeData: executeData,\n executeDataAndCode: executeDataAndCode\n};\n\n},{}],28:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar createEditor = require('./create');\nvar Executor = require('./executor');\nvar TopMenu = require('../dom/top_menu');\n\nfunction Editor(tracerManager) {\n var _this = this;\n\n if (!tracerManager) {\n throw 'Cannot create Editor. Missing the tracerManager';\n }\n\n ace.require('ace/ext/language_tools');\n var Range = ace.require(\"ace/range\").Range;\n\n this.dataEditor = createEditor('data');\n this.codeEditor = createEditor('code');\n\n // Setting data\n\n this.setData = function (data) {\n _this.dataEditor.setValue(data, -1);\n };\n\n this.setCode = function (code) {\n _this.codeEditor.setValue(code, -1);\n };\n\n this.setContent = function (_ref) {\n var data = _ref.data;\n var code = _ref.code;\n\n _this.setData(data);\n _this.setCode(code);\n };\n\n // Clearing data\n\n this.clearData = function () {\n _this.dataEditor.setValue('');\n };\n\n this.clearCode = function () {\n _this.codeEditor.setValue('');\n };\n\n this.clearContent = function () {\n _this.clearData();\n _this.clearCode();\n };\n\n this.execute = function () {\n var data = _this.dataEditor.getValue();\n var code = _this.codeEditor.getValue();\n return Executor.executeDataAndCode(tracerManager, data, code);\n };\n\n this.highlightLine = function (lineNumber) {\n var session = _this.codeEditor.getSession();\n if (_this.marker) session.removeMarker(_this.marker);\n _this.marker = session.addMarker(new Range(lineNumber, 0, lineNumber, Infinity), \"executing\", \"line\", true);\n };\n\n this.unhighlightLine = function () {\n var session = _this.codeEditor.getSession();\n if (_this.marker) session.removeMarker(_this.marker);\n };\n\n // listeners\n\n this.dataEditor.on('change', function () {\n var data = _this.dataEditor.getValue();\n var lastFileUsed = app.getLastFileUsed();\n if (lastFileUsed) {\n app.updateCachedFile(lastFileUsed, {\n data: data\n });\n }\n Executor.executeData(tracerManager, data);\n TopMenu.resetTopMenuButtons();\n });\n\n this.codeEditor.on('change', function () {\n var code = _this.codeEditor.getValue();\n var lastFileUsed = app.getLastFileUsed();\n if (lastFileUsed) {\n app.updateCachedFile(lastFileUsed, {\n code: code\n });\n }\n tracerManager.reset();\n TopMenu.resetTopMenuButtons();\n });\n}\n\nmodule.exports = Editor;\n\n},{\"../app\":3,\"../dom/top_menu\":25,\"./create\":26,\"./executor\":27}],29:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('./app');\nvar AppConstructor = require('./app/constructor');\nvar DOM = require('./dom');\nvar Server = require('./server');\n\nvar modules = require('./module');\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\n$.ajaxSetup({\n cache: false,\n dataType: 'text'\n});\n\nvar _require = require('./utils');\n\nvar isScratchPaper = _require.isScratchPaper;\n\nvar _require2 = require('./server/helpers');\n\nvar getHashValue = _require2.getHashValue;\nvar getParameterByName = _require2.getParameterByName;\nvar getPath = _require2.getPath;\n\n// set global promise error handler\n\nRSVP.on('error', function (reason) {\n console.assert(false, reason);\n});\n\n$(function () {\n\n // initialize the application and attach in to the instance module\n var appConstructor = new AppConstructor();\n extend(true, app, appConstructor);\n\n // load modules to the global scope so they can be evaled\n extend(true, window, modules);\n\n Server.loadCategories().then(function (data) {\n app.setCategories(data);\n DOM.addCategories();\n\n // determine if the app is loading a pre-existing scratch-pad\n // or the home page\n\n var _getPath = getPath();\n\n var category = _getPath.category;\n var algorithm = _getPath.algorithm;\n var file = _getPath.file;\n\n if (isScratchPaper(category)) {\n if (algorithm) {\n Server.loadScratchPaper(algorithm).then(function (_ref) {\n var category = _ref.category;\n var algorithm = _ref.algorithm;\n var data = _ref.data;\n\n DOM.showAlgorithm(category, algorithm, data);\n });\n } else {\n Server.loadAlgorithm(category).then(function (data) {\n DOM.showAlgorithm(category, null, data);\n });\n }\n } else if (category && algorithm) {\n DOM.showRequestedAlgorithm(category, algorithm, file);\n } else {\n DOM.showFirstAlgorithm();\n }\n });\n\n Server.loadWikiList().then(function (data) {\n app.setWikiList(data.wikis);\n\n DOM.showWiki('Tracer');\n });\n\n var v1LoadedScratch = getHashValue('scratch-paper');\n var v2LoadedScratch = getParameterByName('scratch-paper');\n var vLoadedScratch = v1LoadedScratch || v2LoadedScratch;\n if (vLoadedScratch) {\n window.location.href = window.location.protocol + '//' + window.location.host + window.location.pathname + '#path=scratch/' + vLoadedScratch;\n }\n});\n\n},{\"./app\":3,\"./app/constructor\":2,\"./dom\":6,\"./module\":39,\"./server\":56,\"./server/helpers\":55,\"./utils\":70,\"rsvp\":72}],30:[function(require,module,exports){\n'use strict';\n\nvar Array2D = require('./array2d');\n\nvar random = function random(N, min, max) {\n return Array2D.random(1, N, min, max)[0];\n};\n\nvar randomSorted = function randomSorted(N, min, max) {\n return Array2D.randomSorted(1, N, min, max)[0];\n};\n\nmodule.exports = {\n random: random,\n randomSorted: randomSorted\n};\n\n},{\"./array2d\":31}],31:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, M, min, max) {\n if (!N) N = 10;\n if (!M) M = 10;\n if (min === undefined) min = 1;\n if (max === undefined) max = 9;\n var D = [];\n for (var i = 0; i < N; i++) {\n D.push([]);\n for (var j = 0; j < M; j++) {\n D[i].push(Integer.random(min, max));\n }\n }\n return D;\n};\n\nvar randomSorted = function randomSorted(N, M, min, max) {\n return random(N, M, min, max).map(function (arr) {\n return arr.sort(function (a, b) {\n return a - b;\n });\n });\n};\n\nmodule.exports = {\n random: random,\n randomSorted: randomSorted\n};\n\n},{\"./integer\":35}],32:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, min, max) {\n if (!N) N = 7;\n if (!min) min = 1;\n if (!max) max = 10;\n var C = new Array(N);\n for (var i = 0; i < N; i++) {\n C[i] = new Array(2);\n }for (var i = 0; i < N; i++) {\n for (var j = 0; j < C[i].length; j++) {\n C[i][j] = Integer.random(min, max);\n }\n }return C;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{\"./integer\":35}],33:[function(require,module,exports){\n'use strict';\n\nvar random = function random(N, ratio) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n for (var j = 0; j < N; j++) {\n if (i != j) {\n G[i][j] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],34:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\nvar Array1D = require('./array1d');\nvar Array2D = require('./array2d');\nvar CoordinateSystem = require('./coordinate_system');\nvar DirectedGraph = require('./directed_graph');\nvar UndirectedGraph = require('./undirected_graph');\nvar WeightedDirectedGraph = require('./weighted_directed_graph');\nvar WeightedUndirectedGraph = require('./weighted_undirected_graph');\n\nmodule.exports = {\n Integer: Integer,\n Array1D: Array1D,\n Array2D: Array2D,\n CoordinateSystem: CoordinateSystem,\n DirectedGraph: DirectedGraph,\n UndirectedGraph: UndirectedGraph,\n WeightedDirectedGraph: WeightedDirectedGraph,\n WeightedUndirectedGraph: WeightedUndirectedGraph\n};\n\n},{\"./array1d\":30,\"./array2d\":31,\"./coordinate_system\":32,\"./directed_graph\":33,\"./integer\":35,\"./undirected_graph\":36,\"./weighted_directed_graph\":37,\"./weighted_undirected_graph\":38}],35:[function(require,module,exports){\n'use strict';\n\nvar random = function random(min, max) {\n return (Math.random() * (max - min + 1) | 0) + min;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],36:[function(require,module,exports){\n'use strict';\n\nvar random = function random(N, ratio) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n }for (var i = 0; i < N; i++) {\n for (var j = 0; j < N; j++) {\n if (i > j) {\n G[i][j] = G[j][i] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],37:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, ratio, min, max) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n if (!min) min = 1;\n if (!max) max = 5;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n for (var j = 0; j < N; j++) {\n if (i != j && (Math.random() * (1 / ratio) | 0) == 0) {\n G[i][j] = Integer.random(min, max);\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{\"./integer\":35}],38:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, ratio, min, max) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n if (!min) min = 1;\n if (!max) max = 5;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n }for (var i = 0; i < N; i++) {\n for (var j = 0; j < N; j++) {\n if (i > j && (Math.random() * (1 / ratio) | 0) == 0) {\n G[i][j] = G[j][i] = Integer.random(min, max);\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{\"./integer\":35}],39:[function(require,module,exports){\n'use strict';\n\nvar tracers = require('./tracer');\nvar datas = require('./data');\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\nmodule.exports = extend(true, {}, tracers, datas);\n\n},{\"./data\":34,\"./tracer\":45}],40:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Array2DTracer = require('./array2d');\n\nvar Array1DTracer = function (_Array2DTracer) {\n _inherits(Array1DTracer, _Array2DTracer);\n\n _createClass(Array1DTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'Array1DTracer';\n }\n }]);\n\n function Array1DTracer(name) {\n _classCallCheck(this, Array1DTracer);\n\n return _possibleConstructorReturn(this, Object.getPrototypeOf(Array1DTracer).call(this, name));\n }\n\n _createClass(Array1DTracer, [{\n key: '_notify',\n value: function _notify(idx, v) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_notify', this).call(this, 0, idx, v);\n return this;\n }\n }, {\n key: '_denotify',\n value: function _denotify(idx) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_denotify', this).call(this, 0, idx);\n return this;\n }\n }, {\n key: '_select',\n value: function _select(s, e) {\n if (e === undefined) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_select', this).call(this, 0, s);\n } else {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_selectRow', this).call(this, 0, s, e);\n }\n return this;\n }\n }, {\n key: '_deselect',\n value: function _deselect(s, e) {\n if (e === undefined) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_deselect', this).call(this, 0, s);\n } else {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_deselectRow', this).call(this, 0, s, e);\n }\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), 'processStep', this).call(this, step, options);\n if (this.chartTracer) {\n var newStep = $.extend(true, {}, step);\n newStep.capsule = this.chartTracer.capsule;\n newStep.s = newStep.sy;\n newStep.e = newStep.ey;\n if (newStep.s === undefined) newStep.s = newStep.y;\n delete newStep.x;\n delete newStep.y;\n delete newStep.sx;\n delete newStep.sy;\n delete newStep.ex;\n delete newStep.ey;\n this.chartTracer.processStep(newStep, options);\n }\n }\n }, {\n key: 'setData',\n value: function setData(D) {\n return _get(Object.getPrototypeOf(Array1DTracer.prototype), 'setData', this).call(this, [D]);\n }\n }]);\n\n return Array1DTracer;\n}(Array2DTracer);\n\nmodule.exports = Array1DTracer;\n\n},{\"./array2d\":41}],41:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar refineByType = _require.refineByType;\n\nvar Array2DTracer = function (_Tracer) {\n _inherits(Array2DTracer, _Tracer);\n\n _createClass(Array2DTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'Array2DTracer';\n }\n }]);\n\n function Array2DTracer(name) {\n _classCallCheck(this, Array2DTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(Array2DTracer).call(this, name));\n\n _this.colorClass = {\n selected: 'selected',\n notified: 'notified'\n };\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(Array2DTracer, [{\n key: '_notify',\n value: function _notify(x, y, v) {\n this.manager.pushStep(this.capsule, {\n type: 'notify',\n x: x,\n y: y,\n v: v\n });\n return this;\n }\n }, {\n key: '_denotify',\n value: function _denotify(x, y) {\n this.manager.pushStep(this.capsule, {\n type: 'denotify',\n x: x,\n y: y\n });\n return this;\n }\n }, {\n key: '_select',\n value: function _select(sx, sy, ex, ey) {\n this.pushSelectingStep('select', null, arguments);\n return this;\n }\n }, {\n key: '_selectRow',\n value: function _selectRow(x, sy, ey) {\n this.pushSelectingStep('select', 'row', arguments);\n return this;\n }\n }, {\n key: '_selectCol',\n value: function _selectCol(y, sx, ex) {\n this.pushSelectingStep('select', 'col', arguments);\n return this;\n }\n }, {\n key: '_deselect',\n value: function _deselect(sx, sy, ex, ey) {\n this.pushSelectingStep('deselect', null, arguments);\n return this;\n }\n }, {\n key: '_deselectRow',\n value: function _deselectRow(x, sy, ey) {\n this.pushSelectingStep('deselect', 'row', arguments);\n return this;\n }\n }, {\n key: '_deselectCol',\n value: function _deselectCol(y, sx, ex) {\n this.pushSelectingStep('deselect', 'col', arguments);\n return this;\n }\n }, {\n key: '_separate',\n value: function _separate(x, y) {\n this.manager.pushStep(this.capsule, {\n type: 'separate',\n x: x,\n y: y\n });\n return this;\n }\n }, {\n key: '_separateRow',\n value: function _separateRow(x) {\n this._separate(x, -1);\n return this;\n }\n }, {\n key: '_separateCol',\n value: function _separateCol(y) {\n this._separate(-1, y);\n return this;\n }\n }, {\n key: '_deseparate',\n value: function _deseparate(x, y) {\n this.manager.pushStep(this.capsule, {\n type: 'deseparate',\n x: x,\n y: y\n });\n return this;\n }\n }, {\n key: '_deseparateRow',\n value: function _deseparateRow(x) {\n this._deseparate(x, -1);\n return this;\n }\n }, {\n key: '_deseparateCol',\n value: function _deseparateCol(y) {\n this._deseparate(-1, y);\n return this;\n }\n }, {\n key: 'pushSelectingStep',\n value: function pushSelectingStep() {\n var args = Array.prototype.slice.call(arguments);\n var type = args.shift();\n var mode = args.shift();\n args = Array.prototype.slice.call(args.shift());\n var coord;\n switch (mode) {\n case 'row':\n coord = {\n x: args[0],\n sy: args[1],\n ey: args[2]\n };\n break;\n case 'col':\n coord = {\n y: args[0],\n sx: args[1],\n ex: args[2]\n };\n break;\n default:\n if (args[2] === undefined && args[3] === undefined) {\n coord = {\n x: args[0],\n y: args[1]\n };\n } else {\n coord = {\n sx: args[0],\n sy: args[1],\n ex: args[2],\n ey: args[3]\n };\n }\n }\n var step = {\n type: type\n };\n $.extend(step, coord);\n this.manager.pushStep(this.capsule, step);\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'notify':\n if (step.v !== undefined) {\n var $row = this.$table.find('.mtbl-row').eq(step.x);\n var $col = $row.find('.mtbl-col').eq(step.y);\n $col.text(refineByType(step.v));\n }\n case 'denotify':\n case 'select':\n case 'deselect':\n var colorClass = step.type == 'select' || step.type == 'deselect' ? this.colorClass.selected : this.colorClass.notified;\n var addClass = step.type == 'select' || step.type == 'notify';\n var sx = step.sx;\n var sy = step.sy;\n var ex = step.ex;\n var ey = step.ey;\n if (sx === undefined) sx = step.x;\n if (sy === undefined) sy = step.y;\n if (ex === undefined) ex = step.x;\n if (ey === undefined) ey = step.y;\n this.paintColor(sx, sy, ex, ey, colorClass, addClass);\n break;\n case 'separate':\n this.deseparate(step.x, step.y);\n this.separate(step.x, step.y);\n break;\n case 'deseparate':\n this.deseparate(step.x, step.y);\n break;\n default:\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'setData',\n value: function setData(D) {\n this.viewX = this.viewY = 0;\n this.paddingH = 6;\n this.paddingV = 3;\n this.fontSize = 16;\n\n if (_get(Object.getPrototypeOf(Array2DTracer.prototype), 'setData', this).apply(this, arguments)) {\n this.$table.find('.mtbl-row').each(function (i) {\n $(this).find('.mtbl-col').each(function (j) {\n $(this).text(refineByType(D[i][j]));\n });\n });\n return true;\n }\n\n this.$table.empty();\n for (var i = 0; i < D.length; i++) {\n var $row = $('<div class=\"mtbl-row\">');\n this.$table.append($row);\n for (var j = 0; j < D[i].length; j++) {\n var $col = $('<div class=\"mtbl-col\">').css(this.getCellCss()).text(refineByType(D[i][j]));\n $row.append($col);\n }\n }\n this.resize();\n\n return false;\n }\n }, {\n key: 'resize',\n value: function resize() {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'resize', this).call(this);\n\n this.refresh();\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'clear', this).call(this);\n\n this.clearColor();\n this.deseparateAll();\n }\n }, {\n key: 'getCellCss',\n value: function getCellCss() {\n return {\n padding: this.paddingV.toFixed(1) + 'px ' + this.paddingH.toFixed(1) + 'px',\n 'font-size': this.fontSize.toFixed(1) + 'px'\n };\n }\n }, {\n key: 'refresh',\n value: function refresh() {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'refresh', this).call(this);\n\n var $parent = this.$table.parent();\n var top = $parent.height() / 2 - this.$table.height() / 2 + this.viewY;\n var left = $parent.width() / 2 - this.$table.width() / 2 + this.viewX;\n this.$table.css('margin-top', top);\n this.$table.css('margin-left', left);\n }\n }, {\n key: 'mousedown',\n value: function mousedown(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mousedown', this).call(this, e);\n\n this.dragX = e.pageX;\n this.dragY = e.pageY;\n this.dragging = true;\n }\n }, {\n key: 'mousemove',\n value: function mousemove(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mousemove', this).call(this, e);\n\n if (this.dragging) {\n this.viewX += e.pageX - this.dragX;\n this.viewY += e.pageY - this.dragY;\n this.dragX = e.pageX;\n this.dragY = e.pageY;\n this.refresh();\n }\n }\n }, {\n key: 'mouseup',\n value: function mouseup(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mouseup', this).call(this, e);\n\n this.dragging = false;\n }\n }, {\n key: 'mousewheel',\n value: function mousewheel(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mousewheel', this).call(this, e);\n\n e.preventDefault();\n e = e.originalEvent;\n var delta = e.wheelDelta !== undefined && e.wheelDelta || e.detail !== undefined && -e.detail;\n var weight = 1.01;\n var ratio = delta > 0 ? 1 / weight : weight;\n if (this.fontSize < 4 && ratio < 1) return;\n if (this.fontSize > 40 && ratio > 1) return;\n this.paddingV *= ratio;\n this.paddingH *= ratio;\n this.fontSize *= ratio;\n this.$table.find('.mtbl-col').css(this.getCellCss());\n this.refresh();\n }\n }, {\n key: 'paintColor',\n value: function paintColor(sx, sy, ex, ey, colorClass, addClass) {\n for (var i = sx; i <= ex; i++) {\n var $row = this.$table.find('.mtbl-row').eq(i);\n for (var j = sy; j <= ey; j++) {\n var $col = $row.find('.mtbl-col').eq(j);\n if (addClass) $col.addClass(colorClass);else $col.removeClass(colorClass);\n }\n }\n }\n }, {\n key: 'clearColor',\n value: function clearColor() {\n this.$table.find('.mtbl-col').removeClass(Object.keys(this.colorClass).join(' '));\n }\n }, {\n key: 'separate',\n value: function separate(x, y) {\n this.$table.find('.mtbl-row').each(function (i) {\n var $row = $(this);\n if (i == x) {\n $row.after($('<div class=\"mtbl-empty-row\">').attr('data-row', i));\n }\n $row.find('.mtbl-col').each(function (j) {\n var $col = $(this);\n if (j == y) {\n $col.after($('<div class=\"mtbl-empty-col\">').attr('data-col', j));\n }\n });\n });\n }\n }, {\n key: 'deseparate',\n value: function deseparate(x, y) {\n this.$table.find('[data-row=' + x + ']').remove();\n this.$table.find('[data-col=' + y + ']').remove();\n }\n }, {\n key: 'deseparateAll',\n value: function deseparateAll() {\n this.$table.find('.mtbl-empty-row, .mtbl-empty-col').remove();\n }\n }]);\n\n return Array2DTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.$table = tracer.capsule.$table = $('<div class=\"mtbl-table\">');\n tracer.$container.append(tracer.$table);\n};\n\nmodule.exports = Array2DTracer;\n\n},{\"../../tracer_manager/util/index\":67,\"./tracer\":47}],42:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar ChartTracer = function (_Tracer) {\n _inherits(ChartTracer, _Tracer);\n\n _createClass(ChartTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'ChartTracer';\n }\n }]);\n\n function ChartTracer(name) {\n _classCallCheck(this, ChartTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(ChartTracer).call(this, name));\n\n _this.color = {\n selected: 'rgb(0, 0, 255)',\n notified: 'rgb(255, 0, 0)',\n default: 'rgb(136, 136, 136)'\n };\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(ChartTracer, [{\n key: 'setData',\n value: function setData(C) {\n if (_get(Object.getPrototypeOf(ChartTracer.prototype), 'setData', this).apply(this, arguments)) {\n this.chart.config.data.datasets[0].data = C;\n this.chart.update();\n return true;\n }\n\n var color = [];\n for (var i = 0; i < C.length; i++) {\n color.push(this.color.default);\n }this.chart.config.data = {\n labels: C.map(String),\n datasets: [{\n backgroundColor: color,\n data: C\n }]\n };\n this.chart.update();\n }\n }, {\n key: '_notify',\n value: function _notify(s, v) {\n this.manager.pushStep(this.capsule, {\n type: 'notify',\n s: s,\n v: v\n });\n return this;\n }\n }, {\n key: '_denotify',\n value: function _denotify(s) {\n this.manager.pushStep(this.capsule, {\n type: 'denotify',\n s: s\n });\n return this;\n }\n }, {\n key: '_select',\n value: function _select(s, e) {\n this.manager.pushStep(this.capsule, {\n type: 'select',\n s: s,\n e: e\n });\n return this;\n }\n }, {\n key: '_deselect',\n value: function _deselect(s, e) {\n this.manager.pushStep(this.capsule, {\n type: 'deselect',\n s: s,\n e: e\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'notify':\n if (step.v !== undefined) {\n this.chart.config.data.datasets[0].data[step.s] = step.v;\n this.chart.config.data.labels[step.s] = step.v.toString();\n }\n case 'denotify':\n case 'select':\n case 'deselect':\n var color = step.type == 'notify' ? this.color.notified : step.type == 'select' ? this.color.selected : this.color.default;\n if (step.e !== undefined) for (var i = step.s; i <= step.e; i++) {\n this.chart.config.data.datasets[0].backgroundColor[i] = color;\n } else this.chart.config.data.datasets[0].backgroundColor[step.s] = color;\n this.chart.update();\n break;\n default:\n _get(Object.getPrototypeOf(ChartTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'resize',\n value: function resize() {\n _get(Object.getPrototypeOf(ChartTracer.prototype), 'resize', this).call(this);\n\n this.chart.resize();\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(ChartTracer.prototype), 'clear', this).call(this);\n\n var data = this.chart.config.data;\n if (data.datasets.length) {\n var backgroundColor = data.datasets[0].backgroundColor;\n for (var i = 0; i < backgroundColor.length; i++) {\n backgroundColor[i] = this.color.default;\n }\n this.chart.update();\n }\n }\n }]);\n\n return ChartTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.$wrapper = tracer.capsule.$wrapper = $('<canvas class=\"mchrt-chart\">');\n tracer.$container.append(tracer.$wrapper);\n tracer.chart = tracer.capsule.chart = new Chart(tracer.$wrapper, {\n type: 'bar',\n data: {\n labels: [],\n datasets: []\n },\n options: {\n scales: {\n yAxes: [{\n ticks: {\n beginAtZero: true\n }\n }]\n },\n animation: false,\n legend: false,\n responsive: true,\n maintainAspectRatio: false\n }\n });\n};\n\nmodule.exports = ChartTracer;\n\n},{\"./tracer\":47}],43:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar DirectedGraphTracer = require('./directed_graph');\n\nvar CoordinateSystemTracer = function (_DirectedGraphTracer) {\n _inherits(CoordinateSystemTracer, _DirectedGraphTracer);\n\n _createClass(CoordinateSystemTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'CoordinateSystemTracer';\n }\n }]);\n\n function CoordinateSystemTracer(name) {\n _classCallCheck(this, CoordinateSystemTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(CoordinateSystemTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(CoordinateSystemTracer, [{\n key: 'setData',\n value: function setData(C) {\n if (Tracer.prototype.setData.apply(this, arguments)) return true;\n\n this.graph.clear();\n var nodes = [];\n var edges = [];\n for (var i = 0; i < C.length; i++) {\n nodes.push({\n id: this.n(i),\n x: C[i][0],\n y: C[i][1],\n label: '' + i,\n size: 1,\n color: this.color.default\n });\n }this.graph.read({\n nodes: nodes,\n edges: edges\n });\n this.s.camera.goTo({\n x: 0,\n y: 0,\n angle: 0,\n ratio: 1\n });\n this.refresh();\n\n return false;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'visit':\n case 'leave':\n var visit = step.type == 'visit';\n var targetNode = this.graph.nodes(this.n(step.target));\n var color = visit ? this.color.visited : this.color.left;\n targetNode.color = color;\n if (step.source !== undefined) {\n var edgeId = this.e(step.source, step.target);\n if (this.graph.edges(edgeId)) {\n var edge = this.graph.edges(edgeId);\n edge.color = color;\n this.graph.dropEdge(edgeId).addEdge(edge);\n } else {\n this.graph.addEdge({\n id: this.e(step.target, step.source),\n source: this.n(step.source),\n target: this.n(step.target),\n color: color,\n size: 1\n });\n }\n }\n if (this.logTracer) {\n var source = step.source;\n if (source === undefined) source = '';\n this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n }\n break;\n default:\n _get(Object.getPrototypeOf(CoordinateSystemTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'e',\n value: function e(v1, v2) {\n if (v1 > v2) {\n var temp = v1;\n v1 = v2;\n v2 = temp;\n }\n return 'e' + v1 + '_' + v2;\n }\n }, {\n key: 'drawOnHover',\n value: function drawOnHover(node, context, settings, next) {\n var tracer = this;\n\n context.setLineDash([5, 5]);\n var nodeIdx = node.id.substring(1);\n this.graph.edges().forEach(function (edge) {\n var ends = edge.id.substring(1).split(\"_\");\n if (ends[0] == nodeIdx) {\n var color = '#0ff';\n var source = node;\n var target = tracer.graph.nodes('n' + ends[1]);\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n } else if (ends[1] == nodeIdx) {\n var color = '#0ff';\n var source = tracer.graph.nodes('n' + ends[0]);\n var target = node;\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n }\n });\n }\n }, {\n key: 'drawEdge',\n value: function drawEdge(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1;\n\n context.strokeStyle = color;\n context.lineWidth = size;\n context.beginPath();\n context.moveTo(source[prefix + 'x'], source[prefix + 'y']);\n context.lineTo(target[prefix + 'x'], target[prefix + 'y']);\n context.stroke();\n }\n }]);\n\n return CoordinateSystemTracer;\n}(DirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n defaultEdgeType: 'def',\n funcEdgesDef: function funcEdgesDef(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawEdge(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = CoordinateSystemTracer;\n\n},{\"./directed_graph\":44}],44:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar refineByType = _require.refineByType;\n\nvar DirectedGraphTracer = function (_Tracer) {\n _inherits(DirectedGraphTracer, _Tracer);\n\n _createClass(DirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'DirectedGraphTracer';\n }\n }]);\n\n function DirectedGraphTracer(name) {\n _classCallCheck(this, DirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(DirectedGraphTracer).call(this, name));\n\n _this.color = {\n selected: '#0f0',\n visited: '#f00',\n left: '#000',\n default: '#888'\n };\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(DirectedGraphTracer, [{\n key: '_setTreeData',\n value: function _setTreeData(G, root) {\n this.manager.pushStep(this.capsule, {\n type: 'setTreeData',\n arguments: arguments\n });\n return this;\n }\n }, {\n key: '_visit',\n value: function _visit(target, source) {\n this.manager.pushStep(this.capsule, {\n type: 'visit',\n target: target,\n source: source\n });\n return this;\n }\n }, {\n key: '_leave',\n value: function _leave(target, source) {\n this.manager.pushStep(this.capsule, {\n type: 'leave',\n target: target,\n source: source\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'setTreeData':\n this.setTreeData.apply(this, step.arguments);\n break;\n case 'visit':\n case 'leave':\n var visit = step.type == 'visit';\n var targetNode = this.graph.nodes(this.n(step.target));\n var color = visit ? this.color.visited : this.color.left;\n targetNode.color = color;\n if (step.source !== undefined) {\n var edgeId = this.e(step.source, step.target);\n var edge = this.graph.edges(edgeId);\n edge.color = color;\n this.graph.dropEdge(edgeId).addEdge(edge);\n }\n if (this.logTracer) {\n var source = step.source;\n if (source === undefined) source = '';\n this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n }\n break;\n default:\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'setTreeData',\n value: function setTreeData(G, root, undirected) {\n var tracer = this;\n\n root = root || 0;\n var maxDepth = -1;\n\n var chk = new Array(G.length);\n var getDepth = function getDepth(node, depth) {\n if (chk[node]) throw \"the given graph is not a tree because it forms a circuit\";\n chk[node] = true;\n if (maxDepth < depth) maxDepth = depth;\n for (var i = 0; i < G[node].length; i++) {\n if (G[node][i]) getDepth(i, depth + 1);\n }\n };\n getDepth(root, 1);\n\n if (this.setData(G, undirected)) return true;\n\n var place = function place(node, x, y) {\n var temp = tracer.graph.nodes(tracer.n(node));\n temp.x = x;\n temp.y = y;\n };\n\n var wgap = 1 / (maxDepth - 1);\n var dfs = function dfs(node, depth, top, bottom) {\n place(node, top + bottom, depth * wgap);\n var children = 0;\n for (var i = 0; i < G[node].length; i++) {\n if (G[node][i]) children++;\n }\n var vgap = (bottom - top) / children;\n var cnt = 0;\n for (var i = 0; i < G[node].length; i++) {\n if (G[node][i]) dfs(i, depth + 1, top + vgap * cnt, top + vgap * ++cnt);\n }\n };\n dfs(root, 0, 0, 1);\n\n this.refresh();\n }\n }, {\n key: 'setData',\n value: function setData(G, undirected) {\n if (_get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'setData', this).apply(this, arguments)) return true;\n\n this.graph.clear();\n var nodes = [];\n var edges = [];\n var unitAngle = 2 * Math.PI / G.length;\n var currentAngle = 0;\n for (var i = 0; i < G.length; i++) {\n currentAngle += unitAngle;\n nodes.push({\n id: this.n(i),\n label: '' + i,\n x: .5 + Math.sin(currentAngle) / 2,\n y: .5 + Math.cos(currentAngle) / 2,\n size: 1,\n color: this.color.default,\n weight: 0\n });\n\n if (undirected) {\n for (var j = 0; j <= i; j++) {\n var value = G[i][j] || G[j][i];\n if (value) {\n edges.push({\n id: this.e(i, j),\n source: this.n(i),\n target: this.n(j),\n color: this.color.default,\n size: 1,\n weight: refineByType(value)\n });\n }\n }\n } else {\n for (var _j = 0; _j < G[i].length; _j++) {\n if (G[i][_j]) {\n edges.push({\n id: this.e(i, _j),\n source: this.n(i),\n target: this.n(_j),\n color: this.color.default,\n size: 1,\n weight: refineByType(G[i][_j])\n });\n }\n }\n }\n }\n\n this.graph.read({\n nodes: nodes,\n edges: edges\n });\n this.s.camera.goTo({\n x: 0,\n y: 0,\n angle: 0,\n ratio: 1\n });\n this.refresh();\n\n return false;\n }\n }, {\n key: 'resize',\n value: function resize() {\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'resize', this).call(this);\n\n this.s.renderers[0].resize();\n this.refresh();\n }\n }, {\n key: 'refresh',\n value: function refresh() {\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'refresh', this).call(this);\n\n this.s.refresh();\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'clear', this).call(this);\n\n this.clearGraphColor();\n this.refresh();\n }\n }, {\n key: 'clearGraphColor',\n value: function clearGraphColor() {\n var tracer = this;\n\n this.graph.nodes().forEach(function (node) {\n node.color = tracer.color.default;\n });\n this.graph.edges().forEach(function (edge) {\n edge.color = tracer.color.default;\n });\n }\n }, {\n key: 'n',\n value: function n(v) {\n return 'n' + v;\n }\n }, {\n key: 'e',\n value: function e(v1, v2) {\n return 'e' + v1 + '_' + v2;\n }\n }, {\n key: 'getColor',\n value: function getColor(edge, source, target, settings) {\n var color = edge.color,\n edgeColor = settings('edgeColor'),\n defaultNodeColor = settings('defaultNodeColor'),\n defaultEdgeColor = settings('defaultEdgeColor');\n if (!color) switch (edgeColor) {\n case 'source':\n color = source.color || defaultNodeColor;\n break;\n case 'target':\n color = target.color || defaultNodeColor;\n break;\n default:\n color = defaultEdgeColor;\n break;\n }\n\n return color;\n }\n }, {\n key: 'drawLabel',\n value: function drawLabel(node, context, settings) {\n var fontSize,\n prefix = settings('prefix') || '',\n size = node[prefix + 'size'];\n\n if (size < settings('labelThreshold')) return;\n\n if (!node.label || typeof node.label !== 'string') return;\n\n fontSize = settings('labelSize') === 'fixed' ? settings('defaultLabelSize') : settings('labelSizeRatio') * size;\n\n context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') + fontSize + 'px ' + settings('font');\n context.fillStyle = settings('labelColor') === 'node' ? node.color || settings('defaultNodeColor') : settings('defaultLabelColor');\n\n context.textAlign = 'center';\n context.fillText(node.label, Math.round(node[prefix + 'x']), Math.round(node[prefix + 'y'] + fontSize / 3));\n }\n }, {\n key: 'drawArrow',\n value: function drawArrow(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1,\n tSize = target[prefix + 'size'],\n sX = source[prefix + 'x'],\n sY = source[prefix + 'y'],\n tX = target[prefix + 'x'],\n tY = target[prefix + 'y'],\n angle = Math.atan2(tY - sY, tX - sX),\n dist = 3;\n sX += Math.sin(angle) * dist;\n tX += Math.sin(angle) * dist;\n sY += -Math.cos(angle) * dist;\n tY += -Math.cos(angle) * dist;\n var aSize = Math.max(size * 2.5, settings('minArrowSize')),\n d = Math.sqrt(Math.pow(tX - sX, 2) + Math.pow(tY - sY, 2)),\n aX = sX + (tX - sX) * (d - aSize - tSize) / d,\n aY = sY + (tY - sY) * (d - aSize - tSize) / d,\n vX = (tX - sX) * aSize / d,\n vY = (tY - sY) * aSize / d;\n\n context.strokeStyle = color;\n context.lineWidth = size;\n context.beginPath();\n context.moveTo(sX, sY);\n context.lineTo(aX, aY);\n context.stroke();\n\n context.fillStyle = color;\n context.beginPath();\n context.moveTo(aX + vX, aY + vY);\n context.lineTo(aX + vY * 0.6, aY - vX * 0.6);\n context.lineTo(aX - vY * 0.6, aY + vX * 0.6);\n context.lineTo(aX + vX, aY + vY);\n context.closePath();\n context.fill();\n }\n }, {\n key: 'drawOnHover',\n value: function drawOnHover(node, context, settings, next) {\n var tracer = this;\n\n context.setLineDash([5, 5]);\n var nodeIdx = node.id.substring(1);\n this.graph.edges().forEach(function (edge) {\n var ends = edge.id.substring(1).split(\"_\");\n if (ends[0] == nodeIdx) {\n var color = '#0ff';\n var source = node;\n var target = tracer.graph.nodes('n' + ends[1]);\n tracer.drawArrow(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n } else if (ends[1] == nodeIdx) {\n var color = '#ff0';\n var source = tracer.graph.nodes('n' + ends[0]);\n var target = node;\n tracer.drawArrow(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n }\n });\n }\n }]);\n\n return DirectedGraphTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.s = tracer.capsule.s = new sigma({\n renderer: {\n container: tracer.$container[0],\n type: 'canvas'\n },\n settings: {\n minArrowSize: 8,\n defaultEdgeType: 'arrow',\n maxEdgeSize: 2.5,\n labelThreshold: 4,\n font: 'Roboto',\n defaultLabelColor: '#fff',\n zoomMin: 0.6,\n zoomMax: 1.2,\n skipErrors: true,\n minNodeSize: .5,\n maxNodeSize: 12,\n labelSize: 'proportional',\n labelSizeRatio: 1.3,\n funcLabelsDef: function funcLabelsDef(node, context, settings) {\n tracer.drawLabel(node, context, settings);\n },\n funcHoversDef: function funcHoversDef(node, context, settings, next) {\n tracer.drawOnHover(node, context, settings, next);\n },\n funcEdgesArrow: function funcEdgesArrow(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawArrow(edge, source, target, color, context, settings);\n }\n }\n });\n sigma.plugins.dragNodes(tracer.s, tracer.s.renderers[0]);\n tracer.graph = tracer.capsule.graph = tracer.s.graph;\n};\n\nsigma.canvas.labels.def = function (node, context, settings) {\n var func = settings('funcLabelsDef');\n if (func) {\n func(node, context, settings);\n }\n};\nsigma.canvas.hovers.def = function (node, context, settings) {\n var func = settings('funcHoversDef');\n if (func) {\n func(node, context, settings);\n }\n};\nsigma.canvas.edges.def = function (edge, source, target, context, settings) {\n var func = settings('funcEdgesDef');\n if (func) {\n func(edge, source, target, context, settings);\n }\n};\nsigma.canvas.edges.arrow = function (edge, source, target, context, settings) {\n var func = settings('funcEdgesArrow');\n if (func) {\n func(edge, source, target, context, settings);\n }\n};\n\nmodule.exports = DirectedGraphTracer;\n\n},{\"../../tracer_manager/util/index\":67,\"./tracer\":47}],45:[function(require,module,exports){\n'use strict';\n\nvar Tracer = require('./tracer');\nvar LogTracer = require('./log');\nvar Array1DTracer = require('./array1d');\nvar Array2DTracer = require('./array2d');\nvar ChartTracer = require('./chart');\nvar CoordinateSystemTracer = require('./coordinate_system');\nvar DirectedGraphTracer = require('./directed_graph');\nvar UndirectedGraphTracer = require('./undirected_graph');\nvar WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nvar WeightedUndirectedGraphTracer = require('./weighted_undirected_graph');\n\nmodule.exports = {\n Tracer: Tracer,\n LogTracer: LogTracer,\n Array1DTracer: Array1DTracer,\n Array2DTracer: Array2DTracer,\n ChartTracer: ChartTracer,\n CoordinateSystemTracer: CoordinateSystemTracer,\n DirectedGraphTracer: DirectedGraphTracer,\n UndirectedGraphTracer: UndirectedGraphTracer,\n WeightedDirectedGraphTracer: WeightedDirectedGraphTracer,\n WeightedUndirectedGraphTracer: WeightedUndirectedGraphTracer\n};\n\n},{\"./array1d\":40,\"./array2d\":41,\"./chart\":42,\"./coordinate_system\":43,\"./directed_graph\":44,\"./log\":46,\"./tracer\":47,\"./undirected_graph\":48,\"./weighted_directed_graph\":49,\"./weighted_undirected_graph\":50}],46:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar LogTracer = function (_Tracer) {\n _inherits(LogTracer, _Tracer);\n\n _createClass(LogTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'LogTracer';\n }\n }]);\n\n function LogTracer(name) {\n _classCallCheck(this, LogTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(LogTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(LogTracer, [{\n key: '_print',\n value: function _print(msg) {\n this.manager.pushStep(this.capsule, {\n type: 'print',\n msg: msg\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'print':\n this.print(step.msg);\n break;\n }\n }\n }, {\n key: 'refresh',\n value: function refresh() {\n this.scrollToEnd(Math.min(50, this.interval));\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(LogTracer.prototype), 'clear', this).call(this);\n\n this.$wrapper.empty();\n }\n }, {\n key: 'print',\n value: function print(message) {\n this.$wrapper.append($('<span>').append(message + '<br/>'));\n }\n }, {\n key: 'scrollToEnd',\n value: function scrollToEnd(duration) {\n this.$container.animate({\n scrollTop: this.$container[0].scrollHeight\n }, duration);\n }\n }]);\n\n return LogTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.$wrapper = tracer.capsule.$wrapper = $('<div class=\"wrapper\">');\n tracer.$container.append(tracer.$wrapper);\n};\n\nmodule.exports = LogTracer;\n\n},{\"./tracer\":47}],47:[function(require,module,exports){\n'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar app = require('../../app');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar toJSON = _require.toJSON;\nvar fromJSON = _require.fromJSON;\n\nvar Tracer = function () {\n _createClass(Tracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'Tracer';\n }\n }]);\n\n function Tracer(name) {\n _classCallCheck(this, Tracer);\n\n this.module = this.constructor;\n\n this.manager = app.getTracerManager();\n this.capsule = this.manager.allocate(this);\n $.extend(this, this.capsule);\n\n this.setName(name);\n }\n\n _createClass(Tracer, [{\n key: '_setData',\n value: function _setData() {\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n this.manager.pushStep(this.capsule, {\n type: 'setData',\n args: toJSON(args)\n });\n return this;\n }\n }, {\n key: '_clear',\n value: function _clear() {\n this.manager.pushStep(this.capsule, {\n type: 'clear'\n });\n return this;\n }\n }, {\n key: '_wait',\n value: function _wait(line) {\n this.manager.newStep(line);\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n var type = step.type;\n var args = step.args;\n\n\n switch (type) {\n case 'setData':\n this.setData.apply(this, _toConsumableArray(fromJSON(args)));\n break;\n case 'clear':\n this.clear();\n break;\n }\n }\n }, {\n key: 'setName',\n value: function setName(name) {\n var $name = void 0;\n if (this.isNew) {\n $name = $('<span class=\"name\">');\n this.$container.append($name);\n } else {\n $name = this.$container.find('span.name');\n }\n $name.text(name || this.defaultName);\n }\n }, {\n key: 'setData',\n value: function setData() {\n var data = toJSON(arguments);\n if (!this.isNew && this.lastData === data) {\n return true;\n }\n this.lastData = this.capsule.lastData = data;\n return false;\n }\n }, {\n key: 'resize',\n value: function resize() {}\n }, {\n key: 'refresh',\n value: function refresh() {}\n }, {\n key: 'clear',\n value: function clear() {}\n }, {\n key: 'attach',\n value: function attach(tracer) {\n switch (tracer.module) {\n case LogTracer:\n this.logTracer = tracer;\n break;\n case ChartTracer:\n this.chartTracer = tracer;\n break;\n }\n return this;\n }\n }, {\n key: 'mousedown',\n value: function mousedown(e) {}\n }, {\n key: 'mousemove',\n value: function mousemove(e) {}\n }, {\n key: 'mouseup',\n value: function mouseup(e) {}\n }, {\n key: 'mousewheel',\n value: function mousewheel(e) {}\n }]);\n\n return Tracer;\n}();\n\nmodule.exports = Tracer;\n\n},{\"../../app\":3,\"../../tracer_manager/util/index\":67}],48:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar DirectedGraphTracer = require('./directed_graph');\n\nvar UndirectedGraphTracer = function (_DirectedGraphTracer) {\n _inherits(UndirectedGraphTracer, _DirectedGraphTracer);\n\n _createClass(UndirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'UndirectedGraphTracer';\n }\n }]);\n\n function UndirectedGraphTracer(name) {\n _classCallCheck(this, UndirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(UndirectedGraphTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(UndirectedGraphTracer, [{\n key: 'setTreeData',\n value: function setTreeData(G, root) {\n return _get(Object.getPrototypeOf(UndirectedGraphTracer.prototype), 'setTreeData', this).call(this, G, root, true);\n }\n }, {\n key: 'setData',\n value: function setData(G) {\n return _get(Object.getPrototypeOf(UndirectedGraphTracer.prototype), 'setData', this).call(this, G, true);\n }\n }, {\n key: 'e',\n value: function e(v1, v2) {\n if (v1 > v2) {\n var temp = v1;\n v1 = v2;\n v2 = temp;\n }\n return 'e' + v1 + '_' + v2;\n }\n }, {\n key: 'drawOnHover',\n value: function drawOnHover(node, context, settings, next) {\n var tracer = this;\n\n context.setLineDash([5, 5]);\n var nodeIdx = node.id.substring(1);\n this.graph.edges().forEach(function (edge) {\n var ends = edge.id.substring(1).split(\"_\");\n if (ends[0] == nodeIdx) {\n var color = '#0ff';\n var source = node;\n var target = tracer.graph.nodes('n' + ends[1]);\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n } else if (ends[1] == nodeIdx) {\n var color = '#0ff';\n var source = tracer.graph.nodes('n' + ends[0]);\n var target = node;\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n }\n });\n }\n }, {\n key: 'drawEdge',\n value: function drawEdge(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1;\n\n context.strokeStyle = color;\n context.lineWidth = size;\n context.beginPath();\n context.moveTo(source[prefix + 'x'], source[prefix + 'y']);\n context.lineTo(target[prefix + 'x'], target[prefix + 'y']);\n context.stroke();\n }\n }]);\n\n return UndirectedGraphTracer;\n}(DirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n defaultEdgeType: 'def',\n funcEdgesDef: function funcEdgesDef(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawEdge(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = UndirectedGraphTracer;\n\n},{\"./directed_graph\":44}],49:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar DirectedGraphTracer = require('./directed_graph');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar refineByType = _require.refineByType;\n\nvar WeightedDirectedGraphTracer = function (_DirectedGraphTracer) {\n _inherits(WeightedDirectedGraphTracer, _DirectedGraphTracer);\n\n _createClass(WeightedDirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'WeightedDirectedGraphTracer';\n }\n }]);\n\n function WeightedDirectedGraphTracer(name) {\n _classCallCheck(this, WeightedDirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(WeightedDirectedGraphTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(WeightedDirectedGraphTracer, [{\n key: '_weight',\n value: function _weight(target, weight) {\n this.manager.pushStep(this.capsule, {\n type: 'weight',\n target: target,\n weight: weight\n });\n return this;\n }\n }, {\n key: '_visit',\n value: function _visit(target, source, weight) {\n this.manager.pushStep(this.capsule, {\n type: 'visit',\n target: target,\n source: source,\n weight: weight\n });\n return this;\n }\n }, {\n key: '_leave',\n value: function _leave(target, source, weight) {\n this.manager.pushStep(this.capsule, {\n type: 'leave',\n target: target,\n source: source,\n weight: weight\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'weight':\n var targetNode = this.graph.nodes(this.n(step.target));\n if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n break;\n case 'visit':\n case 'leave':\n var visit = step.type == 'visit';\n var targetNode = this.graph.nodes(this.n(step.target));\n var color = visit ? step.weight === undefined ? this.color.selected : this.color.visited : this.color.left;\n targetNode.color = color;\n if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n if (step.source !== undefined) {\n var edgeId = this.e(step.source, step.target);\n var edge = this.graph.edges(edgeId);\n edge.color = color;\n this.graph.dropEdge(edgeId).addEdge(edge);\n }\n if (this.logTracer) {\n var source = step.source;\n if (source === undefined) source = '';\n this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n }\n break;\n default:\n _get(Object.getPrototypeOf(WeightedDirectedGraphTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(WeightedDirectedGraphTracer.prototype), 'clear', this).call(this);\n\n this.clearWeights();\n }\n }, {\n key: 'clearWeights',\n value: function clearWeights() {\n this.graph.nodes().forEach(function (node) {\n node.weight = 0;\n });\n }\n }, {\n key: 'drawEdgeWeight',\n value: function drawEdgeWeight(edge, source, target, color, context, settings) {\n if (source == target) return;\n\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1;\n\n if (size < settings('edgeLabelThreshold')) return;\n\n if (0 === settings('edgeLabelSizePowRatio')) throw '\"edgeLabelSizePowRatio\" must not be 0.';\n\n var fontSize,\n x = (source[prefix + 'x'] + target[prefix + 'x']) / 2,\n y = (source[prefix + 'y'] + target[prefix + 'y']) / 2,\n dX = target[prefix + 'x'] - source[prefix + 'x'],\n dY = target[prefix + 'y'] - source[prefix + 'y'],\n angle = Math.atan2(dY, dX);\n\n fontSize = settings('edgeLabelSize') === 'fixed' ? settings('defaultEdgeLabelSize') : settings('defaultEdgeLabelSize') * size * Math.pow(size, -1 / settings('edgeLabelSizePowRatio'));\n\n context.save();\n\n if (edge.active) {\n context.font = [settings('activeFontStyle'), fontSize + 'px', settings('activeFont') || settings('font')].join(' ');\n\n context.fillStyle = color;\n } else {\n context.font = [settings('fontStyle'), fontSize + 'px', settings('font')].join(' ');\n\n context.fillStyle = color;\n }\n\n context.textAlign = 'center';\n context.textBaseline = 'alphabetic';\n\n context.translate(x, y);\n context.rotate(angle);\n context.fillText(edge.weight, 0, -size / 2 - 3);\n\n context.restore();\n }\n }, {\n key: 'drawNodeWeight',\n value: function drawNodeWeight(node, context, settings) {\n var fontSize,\n prefix = settings('prefix') || '',\n size = node[prefix + 'size'];\n\n if (size < settings('labelThreshold')) return;\n\n fontSize = settings('labelSize') === 'fixed' ? settings('defaultLabelSize') : settings('labelSizeRatio') * size;\n\n context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') + fontSize + 'px ' + settings('font');\n context.fillStyle = settings('labelColor') === 'node' ? node.color || settings('defaultNodeColor') : settings('defaultLabelColor');\n\n context.textAlign = 'left';\n context.fillText(node.weight, Math.round(node[prefix + 'x'] + size * 1.5), Math.round(node[prefix + 'y'] + fontSize / 3));\n }\n }]);\n\n return WeightedDirectedGraphTracer;\n}(DirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n edgeLabelSize: 'proportional',\n defaultEdgeLabelSize: 20,\n edgeLabelSizePowRatio: 0.8,\n funcLabelsDef: function funcLabelsDef(node, context, settings) {\n tracer.drawNodeWeight(node, context, settings);\n tracer.drawLabel(node, context, settings);\n },\n funcHoversDef: function funcHoversDef(node, context, settings) {\n tracer.drawOnHover(node, context, settings, tracer.drawEdgeWeight);\n },\n funcEdgesArrow: function funcEdgesArrow(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawArrow(edge, source, target, color, context, settings);\n tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = WeightedDirectedGraphTracer;\n\n},{\"../../tracer_manager/util/index\":67,\"./directed_graph\":44}],50:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nvar UndirectedGraphTracer = require('./undirected_graph');\n\nvar WeightedUndirectedGraphTracer = function (_WeightedDirectedGrap) {\n _inherits(WeightedUndirectedGraphTracer, _WeightedDirectedGrap);\n\n _createClass(WeightedUndirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'WeightedUndirectedGraphTracer';\n }\n }]);\n\n function WeightedUndirectedGraphTracer(name) {\n _classCallCheck(this, WeightedUndirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(WeightedUndirectedGraphTracer).call(this, name));\n\n _this.e = UndirectedGraphTracer.prototype.e;\n _this.drawOnHover = UndirectedGraphTracer.prototype.drawOnHover;\n _this.drawEdge = UndirectedGraphTracer.prototype.drawEdge;\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(WeightedUndirectedGraphTracer, [{\n key: 'setTreeData',\n value: function setTreeData(G, root) {\n return _get(Object.getPrototypeOf(WeightedUndirectedGraphTracer.prototype), 'setTreeData', this).call(this, G, root, true);\n }\n }, {\n key: 'setData',\n value: function setData(G) {\n return _get(Object.getPrototypeOf(WeightedUndirectedGraphTracer.prototype), 'setData', this).call(this, G, true);\n }\n }, {\n key: 'drawEdgeWeight',\n value: function drawEdgeWeight(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '';\n if (source[prefix + 'x'] > target[prefix + 'x']) {\n var temp = source;\n source = target;\n target = temp;\n }\n WeightedDirectedGraphTracer.prototype.drawEdgeWeight.call(this, edge, source, target, color, context, settings);\n }\n }]);\n\n return WeightedUndirectedGraphTracer;\n}(WeightedDirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n defaultEdgeType: 'def',\n funcEdgesDef: function funcEdgesDef(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawEdge(edge, source, target, color, context, settings);\n tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = WeightedUndirectedGraphTracer;\n\n},{\"./undirected_graph\":48,\"./weighted_directed_graph\":49}],51:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url) {\n return request(url, {\n type: 'GET'\n });\n};\n\n},{\"./request\":54}],52:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url) {\n return request(url, {\n dataType: 'json',\n type: 'GET'\n });\n};\n\n},{\"./request\":54}],53:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url, data) {\n return request(url, {\n dataType: 'json',\n type: 'POST',\n data: JSON.stringify(data)\n });\n};\n\n},{\"./request\":54}],54:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('../../app');\n\nvar _$ = $;\nvar ajax = _$.ajax;\nvar extend = _$.extend;\n\n\nvar defaults = {};\n\nmodule.exports = function (url) {\n var options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1];\n\n app.setIsLoading(true);\n\n return new RSVP.Promise(function (resolve, reject) {\n var callbacks = {\n success: function success(response) {\n app.setIsLoading(false);\n resolve(response);\n },\n error: function error(reason) {\n app.setIsLoading(false);\n reject(reason);\n }\n };\n\n var opts = extend({}, defaults, options, callbacks, {\n url: url\n });\n\n ajax(opts);\n });\n};\n\n},{\"../../app\":3,\"rsvp\":72}],55:[function(require,module,exports){\n'use strict';\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar app = require('../app');\nvar Toast = require('../dom/toast');\n\nvar checkLoading = function checkLoading() {\n if (app.getIsLoading()) {\n Toast.showErrorToast('Wait until it completes loading of previous file.');\n return true;\n }\n return false;\n};\n\nvar getParameterByName = function getParameterByName(name) {\n var url = window.location.href;\n var regex = new RegExp('[?&]' + name + '(=([^&#]*)|&|#|$)');\n\n var results = regex.exec(url);\n\n if (!results || results.length !== 3) {\n return null;\n }\n\n var _results = _slicedToArray(results, 3);\n\n var id = _results[2];\n\n\n return id;\n};\n\nvar getHashValue = function getHashValue(key) {\n if (!key) return null;\n var hash = window.location.hash.substr(1);\n var params = hash ? hash.split('&') : [];\n for (var i = 0; i < params.length; i++) {\n var pair = params[i].split('=');\n if (pair[0] === key) {\n return pair[1];\n }\n }\n return null;\n};\n\nvar setHashValue = function setHashValue(key, value) {\n if (!key || !value) return;\n var hash = window.location.hash.substr(1);\n var params = hash ? hash.split('&') : [];\n\n var found = false;\n for (var i = 0; i < params.length && !found; i++) {\n var pair = params[i].split('=');\n if (pair[0] === key) {\n pair[1] = value;\n params[i] = pair.join('=');\n found = true;\n }\n }\n if (!found) {\n params.push([key, value].join('='));\n }\n\n var newHash = params.join('&');\n window.location.hash = '#' + newHash;\n};\n\nvar removeHashValue = function removeHashValue(key) {\n if (!key) return;\n var hash = window.location.hash.substr(1);\n var params = hash ? hash.split('&') : [];\n\n for (var i = 0; i < params.length; i++) {\n var pair = params[i].split('=');\n if (pair[0] === key) {\n params.splice(i, 1);\n break;\n }\n }\n\n var newHash = params.join('&');\n window.location.hash = '#' + newHash;\n};\n\nvar setPath = function setPath(category, algorithm, file) {\n var path = category ? category + (algorithm ? '/' + algorithm + (file ? '/' + file : '') : '') : '';\n setHashValue('path', path);\n};\n\nvar getPath = function getPath() {\n var hash = getHashValue('path');\n if (hash) {\n var _hash$split = hash.split('/');\n\n var _hash$split2 = _slicedToArray(_hash$split, 3);\n\n var category = _hash$split2[0];\n var algorithm = _hash$split2[1];\n var file = _hash$split2[2];\n\n return { category: category, algorithm: algorithm, file: file };\n } else {\n return false;\n }\n};\n\nmodule.exports = {\n checkLoading: checkLoading,\n getParameterByName: getParameterByName,\n getHashValue: getHashValue,\n setHashValue: setHashValue,\n removeHashValue: removeHashValue,\n setPath: setPath,\n getPath: getPath\n};\n\n},{\"../app\":3,\"../dom/toast\":24}],56:[function(require,module,exports){\n'use strict';\n\nvar loadAlgorithm = require('./load_algorithm');\nvar loadCategories = require('./load_categories');\nvar loadFile = require('./load_file');\nvar loadScratchPaper = require('./load_scratch_paper');\nvar shareScratchPaper = require('./share_scratch_paper');\nvar loadWikiList = require('./load_wiki_list');\nvar loadWiki = require('./load_wiki');\n\nmodule.exports = {\n loadAlgorithm: loadAlgorithm,\n loadCategories: loadCategories,\n loadFile: loadFile,\n loadScratchPaper: loadScratchPaper,\n shareScratchPaper: shareScratchPaper,\n loadWikiList: loadWikiList,\n loadWiki: loadWiki\n};\n\n},{\"./load_algorithm\":57,\"./load_categories\":58,\"./load_file\":59,\"./load_scratch_paper\":60,\"./load_wiki\":61,\"./load_wiki_list\":62,\"./share_scratch_paper\":63}],57:[function(require,module,exports){\n'use strict';\n\nvar getJSON = require('./ajax/get_json');\n\nvar _require = require('../utils');\n\nvar getAlgorithmDir = _require.getAlgorithmDir;\n\n\nmodule.exports = function (category, algorithm) {\n var dir = getAlgorithmDir(category, algorithm);\n return getJSON(dir + 'desc.json');\n};\n\n},{\"../utils\":70,\"./ajax/get_json\":52}],58:[function(require,module,exports){\n'use strict';\n\nvar getJSON = require('./ajax/get_json');\n\nmodule.exports = function () {\n return getJSON('./algorithm/category.json');\n};\n\n},{\"./ajax/get_json\":52}],59:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\n\nvar app = require('../app');\n\nvar _require = require('../utils');\n\nvar getFileDir = _require.getFileDir;\nvar isScratchPaper = _require.isScratchPaper;\n\nvar _require2 = require('./helpers');\n\nvar checkLoading = _require2.checkLoading;\nvar setPath = _require2.setPath;\n\n\nvar get = require('./ajax/get');\n\nvar loadDataAndCode = function loadDataAndCode(dir) {\n return RSVP.hash({\n data: get(dir + 'data.js'),\n code: get(dir + 'code.js')\n });\n};\n\nvar loadFileAndUpdateContent = function loadFileAndUpdateContent(dir) {\n app.getEditor().clearContent();\n\n return loadDataAndCode(dir).then(function (content) {\n app.updateCachedFile(dir, content);\n app.getEditor().setContent(content);\n });\n};\n\nvar cachedContentExists = function cachedContentExists(cachedFile) {\n return cachedFile && cachedFile.data !== undefined && cachedFile.code !== undefined;\n};\n\nmodule.exports = function (category, algorithm, file, explanation) {\n return new RSVP.Promise(function (resolve, reject) {\n if (checkLoading()) {\n reject();\n } else {\n if (isScratchPaper(category)) {\n setPath(category, app.getLoadedScratch());\n } else {\n setPath(category, algorithm, file);\n }\n $('#explanation').html(explanation);\n\n var dir = getFileDir(category, algorithm, file);\n app.setLastFileUsed(dir);\n var cachedFile = app.getCachedFile(dir);\n\n if (cachedContentExists(cachedFile)) {\n app.getEditor().setContent(cachedFile);\n resolve();\n } else {\n loadFileAndUpdateContent(dir).then(resolve, reject);\n }\n }\n });\n};\n\n},{\"../app\":3,\"../utils\":70,\"./ajax/get\":51,\"./helpers\":55,\"rsvp\":72}],60:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('../app');\n\nvar _require = require('../utils');\n\nvar getFileDir = _require.getFileDir;\n\n\nvar getJSON = require('./ajax/get_json');\nvar loadAlgorithm = require('./load_algorithm');\n\nvar extractGistCode = function extractGistCode(files, name) {\n return files[name + '.js'].content;\n};\n\nmodule.exports = function (gistID) {\n return new RSVP.Promise(function (resolve, reject) {\n app.setLoadedScratch(gistID);\n\n getJSON('https://api.github.com/gists/' + gistID).then(function (_ref) {\n var files = _ref.files;\n\n\n var category = 'scratch';\n var algorithm = gistID;\n\n loadAlgorithm(category, algorithm).then(function (data) {\n\n var algoData = extractGistCode(files, 'data');\n var algoCode = extractGistCode(files, 'code');\n\n // update scratch paper algo code with the loaded gist code\n var dir = getFileDir(category, algorithm, 'scratch_paper');\n app.updateCachedFile(dir, {\n data: algoData,\n code: algoCode,\n 'CREDIT.md': 'Shared by an anonymous user from http://parkjs814.github.io/AlgorithmVisualizer'\n });\n\n resolve({\n category: category,\n algorithm: algorithm,\n data: data\n });\n });\n });\n });\n};\n\n},{\"../app\":3,\"../utils\":70,\"./ajax/get_json\":52,\"./load_algorithm\":57,\"rsvp\":72}],61:[function(require,module,exports){\n'use strict';\n\nvar get = require('./ajax/get');\n\nmodule.exports = function (wiki) {\n return get('./AlgorithmVisualizer.wiki/' + wiki + '.md');\n};\n\n},{\"./ajax/get\":51}],62:[function(require,module,exports){\n'use strict';\n\nvar getJSON = require('./ajax/get_json');\n\nmodule.exports = function () {\n return getJSON('./wiki.json');\n};\n\n},{\"./ajax/get_json\":52}],63:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('../app');\n\nvar postJSON = require('./ajax/post_json');\n\nvar _require = require('./helpers');\n\nvar setPath = _require.setPath;\n\n\nmodule.exports = function () {\n return new RSVP.Promise(function (resolve, reject) {\n var _app$getEditor = app.getEditor();\n\n var dataEditor = _app$getEditor.dataEditor;\n var codeEditor = _app$getEditor.codeEditor;\n\n\n var gist = {\n 'description': 'temp',\n 'public': true,\n 'files': {\n 'data.js': {\n 'content': dataEditor.getValue()\n },\n 'code.js': {\n 'content': codeEditor.getValue()\n }\n }\n };\n\n postJSON('https://api.github.com/gists', gist).then(function (_ref) {\n var id = _ref.id;\n\n app.setLoadedScratch(id);\n setPath('scratch', id);\n var _location = location;\n var href = _location.href;\n\n $('#algorithm').html('Shared');\n resolve(href);\n });\n });\n};\n\n},{\"../app\":3,\"./ajax/post_json\":53,\"./helpers\":55,\"rsvp\":72}],64:[function(require,module,exports){\n'use strict';\n\nvar TracerManager = require('./manager');\nvar Tracer = require('../module/tracer/tracer');\n\nmodule.exports = {\n init: function init() {\n var tm = new TracerManager();\n Tracer.prototype.manager = tm;\n return tm;\n }\n};\n\n},{\"../module/tracer/tracer\":47,\"./manager\":65}],65:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar ModuleContainer = require('../dom/module_container');\nvar TopMenu = require('../dom/top_menu');\n\nvar _$ = $;\nvar each = _$.each;\nvar extend = _$.extend;\nvar grep = _$.grep;\n\n\nvar stepLimit = 1e6;\n\nvar TracerManager = function TracerManager() {\n this.timer = null;\n this.pause = false;\n this.capsules = [];\n this.interval = 500;\n};\n\nTracerManager.prototype = {\n add: function add(tracer) {\n\n var $container = ModuleContainer.create();\n\n var capsule = {\n module: tracer.module,\n tracer: tracer,\n allocated: true,\n defaultName: null,\n $container: $container,\n isNew: true\n };\n\n this.capsules.push(capsule);\n return capsule;\n },\n allocate: function allocate(newTracer) {\n var selectedCapsule = null;\n var count = 0;\n\n each(this.capsules, function (i, capsule) {\n if (capsule.module === newTracer.module) {\n count++;\n if (!capsule.allocated) {\n capsule.tracer = newTracer;\n capsule.allocated = true;\n capsule.isNew = false;\n selectedCapsule = capsule;\n return false;\n }\n }\n });\n\n if (selectedCapsule === null) {\n count++;\n selectedCapsule = this.add(newTracer);\n }\n\n var className = newTracer.module.getClassName();\n selectedCapsule.defaultName = className + ' ' + count;\n selectedCapsule.order = this.order++;\n return selectedCapsule;\n },\n deallocateAll: function deallocateAll() {\n this.order = 0;\n this.reset();\n each(this.capsules, function (i, capsule) {\n capsule.allocated = false;\n });\n },\n removeUnallocated: function removeUnallocated() {\n var changed = false;\n\n this.capsules = grep(this.capsules, function (capsule) {\n var removed = !capsule.allocated;\n\n if (capsule.isNew || removed) {\n changed = true;\n }\n if (removed) {\n capsule.$container.remove();\n }\n\n return !removed;\n });\n\n if (changed) {\n this.place();\n }\n },\n place: function place() {\n var capsules = this.capsules;\n\n\n each(capsules, function (i, capsule) {\n var width = 100;\n var height = 100 / capsules.length;\n var top = height * capsule.order;\n\n capsule.$container.css({\n top: top + '%',\n width: width + '%',\n height: height + '%'\n });\n\n capsule.tracer.resize();\n });\n },\n resize: function resize() {\n this.command('resize');\n },\n isPause: function isPause() {\n return this.pause;\n },\n setInterval: function setInterval(interval) {\n TopMenu.setInterval(interval);\n },\n reset: function reset() {\n this.traces = [];\n this.traceIndex = -1;\n this.stepCnt = 0;\n if (this.timer) {\n clearTimeout(this.timer);\n }\n this.command('clear');\n },\n pushStep: function pushStep(capsule, step) {\n if (this.stepCnt++ > stepLimit) throw \"Tracer's stack overflow\";\n var len = this.traces.length;\n if (len == 0) len += this.newStep();\n var last = this.traces[len - 1];\n last.push(extend(step, {\n capsule: capsule\n }));\n },\n newStep: function newStep() {\n var line = arguments.length <= 0 || arguments[0] === undefined ? -1 : arguments[0];\n\n var len = this.traces.length;\n if (len > 0 && ~line) {\n this.traces[len - 1].push(line);\n }\n return this.traces.push([]);\n },\n pauseStep: function pauseStep() {\n if (this.traceIndex < 0) return;\n this.pause = true;\n if (this.timer) {\n clearTimeout(this.timer);\n }\n TopMenu.activateBtnPause();\n },\n resumeStep: function resumeStep() {\n this.pause = false;\n this.step(this.traceIndex + 1);\n TopMenu.deactivateBtnPause();\n },\n step: function step(i) {\n var options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1];\n\n var tracer = this;\n\n if (isNaN(i) || i >= this.traces.length || i < 0) return;\n\n this.traceIndex = i;\n var trace = this.traces[i];\n trace.forEach(function (step) {\n if (typeof step === 'number') {\n app.getEditor().highlightLine(step);\n return;\n }\n step.capsule.tracer.processStep(step, options);\n });\n\n if (!options.virtual) {\n this.command('refresh');\n }\n\n if (this.pause) return;\n\n this.timer = setTimeout(function () {\n if (!tracer.nextStep(options)) {\n TopMenu.resetTopMenuButtons();\n }\n }, this.interval);\n },\n prevStep: function prevStep() {\n var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n this.command('clear');\n\n var finalIndex = this.traceIndex - 1;\n if (finalIndex < 0) {\n this.traceIndex = -1;\n this.command('refresh');\n return false;\n }\n\n for (var i = 0; i < finalIndex; i++) {\n this.step(i, extend(options, {\n virtual: true\n }));\n }\n\n this.step(finalIndex);\n return true;\n },\n nextStep: function nextStep() {\n var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n var finalIndex = this.traceIndex + 1;\n if (finalIndex >= this.traces.length) {\n this.traceIndex = this.traces.length - 1;\n return false;\n }\n\n this.step(finalIndex, options);\n return true;\n },\n visualize: function visualize() {\n this.traceIndex = -1;\n this.resumeStep();\n },\n command: function command() {\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var functionName = args.shift();\n each(this.capsules, function (i, capsule) {\n if (capsule.allocated) {\n capsule.tracer.module.prototype[functionName].apply(capsule.tracer, args);\n }\n });\n },\n findOwner: function findOwner(container) {\n var selectedCapsule = null;\n each(this.capsules, function (i, capsule) {\n if (capsule.$container[0] === container) {\n selectedCapsule = capsule;\n return false;\n }\n });\n return selectedCapsule.tracer;\n }\n};\n\nmodule.exports = TracerManager;\n\n},{\"../app\":3,\"../dom/module_container\":8,\"../dom/top_menu\":25}],66:[function(require,module,exports){\n'use strict';\n\nvar parse = JSON.parse;\n\n\nvar fromJSON = function fromJSON(obj) {\n return parse(obj, function (key, value) {\n return value === 'Infinity' ? Infinity : value;\n });\n};\n\nmodule.exports = fromJSON;\n\n},{}],67:[function(require,module,exports){\n'use strict';\n\nvar toJSON = require('./to_json');\nvar fromJSON = require('./from_json');\nvar refineByType = require('./refine_by_type');\n\nmodule.exports = {\n toJSON: toJSON,\n fromJSON: fromJSON,\n refineByType: refineByType\n};\n\n},{\"./from_json\":66,\"./refine_by_type\":68,\"./to_json\":69}],68:[function(require,module,exports){\n'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol ? \"symbol\" : typeof obj; };\n\nvar refineByType = function refineByType(item) {\n switch (typeof item === 'undefined' ? 'undefined' : _typeof(item)) {\n case 'number':\n return refineNumber(item);\n case 'boolean':\n return refineBoolean(item);\n default:\n return refineString(item);\n }\n};\n\nvar refineString = function refineString(str) {\n return str === '' ? ' ' : str;\n};\n\nvar refineNumber = function refineNumber(num) {\n return num === Infinity ? '∞' : num;\n};\n\nvar refineBoolean = function refineBoolean(bool) {\n return bool ? 'T' : 'F';\n};\n\nmodule.exports = refineByType;\n\n},{}],69:[function(require,module,exports){\n'use strict';\n\nvar stringify = JSON.stringify;\n\n\nvar toJSON = function toJSON(obj) {\n return stringify(obj, function (key, value) {\n return value === Infinity ? 'Infinity' : value;\n });\n};\n\nmodule.exports = toJSON;\n\n},{}],70:[function(require,module,exports){\n'use strict';\n\nvar isScratchPaper = function isScratchPaper(category, algorithm) {\n return category == 'scratch';\n};\n\nvar getAlgorithmDir = function getAlgorithmDir(category, algorithm) {\n if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n return './algorithm/' + category + '/' + algorithm + '/';\n};\n\nvar getFileDir = function getFileDir(category, algorithm, file) {\n if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n return './algorithm/' + category + '/' + algorithm + '/' + file + '/';\n};\n\nmodule.exports = {\n isScratchPaper: isScratchPaper,\n getAlgorithmDir: getAlgorithmDir,\n getFileDir: getFileDir\n};\n\n},{}],71:[function(require,module,exports){\n// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = setTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n clearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n setTimeout(drainQueue, 0);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\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\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n\n},{}],72:[function(require,module,exports){\n(function (process,global){\n/*!\n * @overview RSVP - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors\n * @license Licensed under MIT license\n * See https://raw.githubusercontent.com/tildeio/rsvp.js/master/LICENSE\n * @version 3.2.1\n */\n\n(function() {\n \"use strict\";\n function lib$rsvp$utils$$objectOrFunction(x) {\n return typeof x === 'function' || (typeof x === 'object' && x !== null);\n }\n\n function lib$rsvp$utils$$isFunction(x) {\n return typeof x === 'function';\n }\n\n function lib$rsvp$utils$$isMaybeThenable(x) {\n return typeof x === 'object' && x !== null;\n }\n\n var lib$rsvp$utils$$_isArray;\n if (!Array.isArray) {\n lib$rsvp$utils$$_isArray = function (x) {\n return Object.prototype.toString.call(x) === '[object Array]';\n };\n } else {\n lib$rsvp$utils$$_isArray = Array.isArray;\n }\n\n var lib$rsvp$utils$$isArray = lib$rsvp$utils$$_isArray;\n\n var lib$rsvp$utils$$now = Date.now || function() { return new Date().getTime(); };\n\n function lib$rsvp$utils$$F() { }\n\n var lib$rsvp$utils$$o_create = (Object.create || function (o) {\n if (arguments.length > 1) {\n throw new Error('Second argument not supported');\n }\n if (typeof o !== 'object') {\n throw new TypeError('Argument must be an object');\n }\n lib$rsvp$utils$$F.prototype = o;\n return new lib$rsvp$utils$$F();\n });\n function lib$rsvp$events$$indexOf(callbacks, callback) {\n for (var i=0, l=callbacks.length; i<l; i++) {\n if (callbacks[i] === callback) { return i; }\n }\n\n return -1;\n }\n\n function lib$rsvp$events$$callbacksFor(object) {\n var callbacks = object._promiseCallbacks;\n\n if (!callbacks) {\n callbacks = object._promiseCallbacks = {};\n }\n\n return callbacks;\n }\n\n var lib$rsvp$events$$default = {\n\n /**\n `RSVP.EventTarget.mixin` extends an object with EventTarget methods. For\n Example:\n\n ```javascript\n var object = {};\n\n RSVP.EventTarget.mixin(object);\n\n object.on('finished', function(event) {\n // handle event\n });\n\n object.trigger('finished', { detail: value });\n ```\n\n `EventTarget.mixin` also works with prototypes:\n\n ```javascript\n var Person = function() {};\n RSVP.EventTarget.mixin(Person.prototype);\n\n var yehuda = new Person();\n var tom = new Person();\n\n yehuda.on('poke', function(event) {\n console.log('Yehuda says OW');\n });\n\n tom.on('poke', function(event) {\n console.log('Tom says OW');\n });\n\n yehuda.trigger('poke');\n tom.trigger('poke');\n ```\n\n @method mixin\n @for RSVP.EventTarget\n @private\n @param {Object} object object to extend with EventTarget methods\n */\n 'mixin': function(object) {\n object['on'] = this['on'];\n object['off'] = this['off'];\n object['trigger'] = this['trigger'];\n object._promiseCallbacks = undefined;\n return object;\n },\n\n /**\n Registers a callback to be executed when `eventName` is triggered\n\n ```javascript\n object.on('event', function(eventInfo){\n // handle the event\n });\n\n object.trigger('event');\n ```\n\n @method on\n @for RSVP.EventTarget\n @private\n @param {String} eventName name of the event to listen for\n @param {Function} callback function to be called when the event is triggered.\n */\n 'on': function(eventName, callback) {\n if (typeof callback !== 'function') {\n throw new TypeError('Callback must be a function');\n }\n\n var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks;\n\n callbacks = allCallbacks[eventName];\n\n if (!callbacks) {\n callbacks = allCallbacks[eventName] = [];\n }\n\n if (lib$rsvp$events$$indexOf(callbacks, callback) === -1) {\n callbacks.push(callback);\n }\n },\n\n /**\n You can use `off` to stop firing a particular callback for an event:\n\n ```javascript\n function doStuff() { // do stuff! }\n object.on('stuff', doStuff);\n\n object.trigger('stuff'); // doStuff will be called\n\n // Unregister ONLY the doStuff callback\n object.off('stuff', doStuff);\n object.trigger('stuff'); // doStuff will NOT be called\n ```\n\n If you don't pass a `callback` argument to `off`, ALL callbacks for the\n event will not be executed when the event fires. For example:\n\n ```javascript\n var callback1 = function(){};\n var callback2 = function(){};\n\n object.on('stuff', callback1);\n object.on('stuff', callback2);\n\n object.trigger('stuff'); // callback1 and callback2 will be executed.\n\n object.off('stuff');\n object.trigger('stuff'); // callback1 and callback2 will not be executed!\n ```\n\n @method off\n @for RSVP.EventTarget\n @private\n @param {String} eventName event to stop listening to\n @param {Function} callback optional argument. If given, only the function\n given will be removed from the event's callback queue. If no `callback`\n argument is given, all callbacks will be removed from the event's callback\n queue.\n */\n 'off': function(eventName, callback) {\n var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, index;\n\n if (!callback) {\n allCallbacks[eventName] = [];\n return;\n }\n\n callbacks = allCallbacks[eventName];\n\n index = lib$rsvp$events$$indexOf(callbacks, callback);\n\n if (index !== -1) { callbacks.splice(index, 1); }\n },\n\n /**\n Use `trigger` to fire custom events. For example:\n\n ```javascript\n object.on('foo', function(){\n console.log('foo event happened!');\n });\n object.trigger('foo');\n // 'foo event happened!' logged to the console\n ```\n\n You can also pass a value as a second argument to `trigger` that will be\n passed as an argument to all event listeners for the event:\n\n ```javascript\n object.on('foo', function(value){\n console.log(value.name);\n });\n\n object.trigger('foo', { name: 'bar' });\n // 'bar' logged to the console\n ```\n\n @method trigger\n @for RSVP.EventTarget\n @private\n @param {String} eventName name of the event to be triggered\n @param {*} options optional value to be passed to any event handlers for\n the given `eventName`\n */\n 'trigger': function(eventName, options, label) {\n var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, callback;\n\n if (callbacks = allCallbacks[eventName]) {\n // Don't cache the callbacks.length since it may grow\n for (var i=0; i<callbacks.length; i++) {\n callback = callbacks[i];\n\n callback(options, label);\n }\n }\n }\n };\n\n var lib$rsvp$config$$config = {\n instrument: false\n };\n\n lib$rsvp$events$$default['mixin'](lib$rsvp$config$$config);\n\n function lib$rsvp$config$$configure(name, value) {\n if (name === 'onerror') {\n // handle for legacy users that expect the actual\n // error to be passed to their function added via\n // `RSVP.configure('onerror', someFunctionHere);`\n lib$rsvp$config$$config['on']('error', value);\n return;\n }\n\n if (arguments.length === 2) {\n lib$rsvp$config$$config[name] = value;\n } else {\n return lib$rsvp$config$$config[name];\n }\n }\n\n var lib$rsvp$instrument$$queue = [];\n\n function lib$rsvp$instrument$$scheduleFlush() {\n setTimeout(function() {\n var entry;\n for (var i = 0; i < lib$rsvp$instrument$$queue.length; i++) {\n entry = lib$rsvp$instrument$$queue[i];\n\n var payload = entry.payload;\n\n payload.guid = payload.key + payload.id;\n payload.childGuid = payload.key + payload.childId;\n if (payload.error) {\n payload.stack = payload.error.stack;\n }\n\n lib$rsvp$config$$config['trigger'](entry.name, entry.payload);\n }\n lib$rsvp$instrument$$queue.length = 0;\n }, 50);\n }\n\n function lib$rsvp$instrument$$instrument(eventName, promise, child) {\n if (1 === lib$rsvp$instrument$$queue.push({\n name: eventName,\n payload: {\n key: promise._guidKey,\n id: promise._id,\n eventName: eventName,\n detail: promise._result,\n childId: child && child._id,\n label: promise._label,\n timeStamp: lib$rsvp$utils$$now(),\n error: lib$rsvp$config$$config[\"instrument-with-stack\"] ? new Error(promise._label) : null\n }})) {\n lib$rsvp$instrument$$scheduleFlush();\n }\n }\n var lib$rsvp$instrument$$default = lib$rsvp$instrument$$instrument;\n function lib$rsvp$then$$then(onFulfillment, onRejection, label) {\n var parent = this;\n var state = parent._state;\n\n if (state === lib$rsvp$$internal$$FULFILLED && !onFulfillment || state === lib$rsvp$$internal$$REJECTED && !onRejection) {\n lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, parent);\n return parent;\n }\n\n parent._onError = null;\n\n var child = new parent.constructor(lib$rsvp$$internal$$noop, label);\n var result = parent._result;\n\n lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, child);\n\n if (state) {\n var callback = arguments[state - 1];\n lib$rsvp$config$$config.async(function(){\n lib$rsvp$$internal$$invokeCallback(state, child, callback, result);\n });\n } else {\n lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection);\n }\n\n return child;\n }\n var lib$rsvp$then$$default = lib$rsvp$then$$then;\n function lib$rsvp$promise$resolve$$resolve(object, label) {\n /*jshint validthis:true */\n var Constructor = this;\n\n if (object && typeof object === 'object' && object.constructor === Constructor) {\n return object;\n }\n\n var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n lib$rsvp$$internal$$resolve(promise, object);\n return promise;\n }\n var lib$rsvp$promise$resolve$$default = lib$rsvp$promise$resolve$$resolve;\n function lib$rsvp$enumerator$$makeSettledResult(state, position, value) {\n if (state === lib$rsvp$$internal$$FULFILLED) {\n return {\n state: 'fulfilled',\n value: value\n };\n } else {\n return {\n state: 'rejected',\n reason: value\n };\n }\n }\n\n function lib$rsvp$enumerator$$Enumerator(Constructor, input, abortOnReject, label) {\n this._instanceConstructor = Constructor;\n this.promise = new Constructor(lib$rsvp$$internal$$noop, label);\n this._abortOnReject = abortOnReject;\n\n if (this._validateInput(input)) {\n this._input = input;\n this.length = input.length;\n this._remaining = input.length;\n\n this._init();\n\n if (this.length === 0) {\n lib$rsvp$$internal$$fulfill(this.promise, this._result);\n } else {\n this.length = this.length || 0;\n this._enumerate();\n if (this._remaining === 0) {\n lib$rsvp$$internal$$fulfill(this.promise, this._result);\n }\n }\n } else {\n lib$rsvp$$internal$$reject(this.promise, this._validationError());\n }\n }\n\n var lib$rsvp$enumerator$$default = lib$rsvp$enumerator$$Enumerator;\n\n lib$rsvp$enumerator$$Enumerator.prototype._validateInput = function(input) {\n return lib$rsvp$utils$$isArray(input);\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._validationError = function() {\n return new Error('Array Methods must be provided an Array');\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._init = function() {\n this._result = new Array(this.length);\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._enumerate = function() {\n var length = this.length;\n var promise = this.promise;\n var input = this._input;\n\n for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n this._eachEntry(input[i], i);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._settleMaybeThenable = function(entry, i) {\n var c = this._instanceConstructor;\n var resolve = c.resolve;\n\n if (resolve === lib$rsvp$promise$resolve$$default) {\n var then = lib$rsvp$$internal$$getThen(entry);\n\n if (then === lib$rsvp$then$$default &&\n entry._state !== lib$rsvp$$internal$$PENDING) {\n entry._onError = null;\n this._settledAt(entry._state, i, entry._result);\n } else if (typeof then !== 'function') {\n this._remaining--;\n this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n } else if (c === lib$rsvp$promise$$default) {\n var promise = new c(lib$rsvp$$internal$$noop);\n lib$rsvp$$internal$$handleMaybeThenable(promise, entry, then);\n this._willSettleAt(promise, i);\n } else {\n this._willSettleAt(new c(function(resolve) { resolve(entry); }), i);\n }\n } else {\n this._willSettleAt(resolve(entry), i);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._eachEntry = function(entry, i) {\n if (lib$rsvp$utils$$isMaybeThenable(entry)) {\n this._settleMaybeThenable(entry, i);\n } else {\n this._remaining--;\n this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._settledAt = function(state, i, value) {\n var promise = this.promise;\n\n if (promise._state === lib$rsvp$$internal$$PENDING) {\n this._remaining--;\n\n if (this._abortOnReject && state === lib$rsvp$$internal$$REJECTED) {\n lib$rsvp$$internal$$reject(promise, value);\n } else {\n this._result[i] = this._makeResult(state, i, value);\n }\n }\n\n if (this._remaining === 0) {\n lib$rsvp$$internal$$fulfill(promise, this._result);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._makeResult = function(state, i, value) {\n return value;\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._willSettleAt = function(promise, i) {\n var enumerator = this;\n\n lib$rsvp$$internal$$subscribe(promise, undefined, function(value) {\n enumerator._settledAt(lib$rsvp$$internal$$FULFILLED, i, value);\n }, function(reason) {\n enumerator._settledAt(lib$rsvp$$internal$$REJECTED, i, reason);\n });\n };\n function lib$rsvp$promise$all$$all(entries, label) {\n return new lib$rsvp$enumerator$$default(this, entries, true /* abort on reject */, label).promise;\n }\n var lib$rsvp$promise$all$$default = lib$rsvp$promise$all$$all;\n function lib$rsvp$promise$race$$race(entries, label) {\n /*jshint validthis:true */\n var Constructor = this;\n\n var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n\n if (!lib$rsvp$utils$$isArray(entries)) {\n lib$rsvp$$internal$$reject(promise, new TypeError('You must pass an array to race.'));\n return promise;\n }\n\n var length = entries.length;\n\n function onFulfillment(value) {\n lib$rsvp$$internal$$resolve(promise, value);\n }\n\n function onRejection(reason) {\n lib$rsvp$$internal$$reject(promise, reason);\n }\n\n for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n lib$rsvp$$internal$$subscribe(Constructor.resolve(entries[i]), undefined, onFulfillment, onRejection);\n }\n\n return promise;\n }\n var lib$rsvp$promise$race$$default = lib$rsvp$promise$race$$race;\n function lib$rsvp$promise$reject$$reject(reason, label) {\n /*jshint validthis:true */\n var Constructor = this;\n var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n lib$rsvp$$internal$$reject(promise, reason);\n return promise;\n }\n var lib$rsvp$promise$reject$$default = lib$rsvp$promise$reject$$reject;\n\n var lib$rsvp$promise$$guidKey = 'rsvp_' + lib$rsvp$utils$$now() + '-';\n var lib$rsvp$promise$$counter = 0;\n\n function lib$rsvp$promise$$needsResolver() {\n throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n }\n\n function lib$rsvp$promise$$needsNew() {\n throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n }\n\n function lib$rsvp$promise$$Promise(resolver, label) {\n this._id = lib$rsvp$promise$$counter++;\n this._label = label;\n this._state = undefined;\n this._result = undefined;\n this._subscribers = [];\n\n lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('created', this);\n\n if (lib$rsvp$$internal$$noop !== resolver) {\n typeof resolver !== 'function' && lib$rsvp$promise$$needsResolver();\n this instanceof lib$rsvp$promise$$Promise ? lib$rsvp$$internal$$initializePromise(this, resolver) : lib$rsvp$promise$$needsNew();\n }\n }\n\n var lib$rsvp$promise$$default = lib$rsvp$promise$$Promise;\n\n // deprecated\n lib$rsvp$promise$$Promise.cast = lib$rsvp$promise$resolve$$default;\n lib$rsvp$promise$$Promise.all = lib$rsvp$promise$all$$default;\n lib$rsvp$promise$$Promise.race = lib$rsvp$promise$race$$default;\n lib$rsvp$promise$$Promise.resolve = lib$rsvp$promise$resolve$$default;\n lib$rsvp$promise$$Promise.reject = lib$rsvp$promise$reject$$default;\n\n lib$rsvp$promise$$Promise.prototype = {\n constructor: lib$rsvp$promise$$Promise,\n\n _guidKey: lib$rsvp$promise$$guidKey,\n\n _onError: function (reason) {\n var promise = this;\n lib$rsvp$config$$config.after(function() {\n if (promise._onError) {\n lib$rsvp$config$$config['trigger']('error', reason, promise._label);\n }\n });\n },\n\n /**\n The primary way of interacting with a promise is through its `then` method,\n which registers callbacks to receive either a promise's eventual value or the\n reason why the promise cannot be fulfilled.\n\n ```js\n findUser().then(function(user){\n // user is available\n }, function(reason){\n // user is unavailable, and you are given the reason why\n });\n ```\n\n Chaining\n --------\n\n The return value of `then` is itself a promise. This second, 'downstream'\n promise is resolved with the return value of the first promise's fulfillment\n or rejection handler, or rejected if the handler throws an exception.\n\n ```js\n findUser().then(function (user) {\n return user.name;\n }, function (reason) {\n return 'default name';\n }).then(function (userName) {\n // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n // will be `'default name'`\n });\n\n findUser().then(function (user) {\n throw new Error('Found user, but still unhappy');\n }, function (reason) {\n throw new Error('`findUser` rejected and we're unhappy');\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n });\n ```\n If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n\n ```js\n findUser().then(function (user) {\n throw new PedagogicalException('Upstream error');\n }).then(function (value) {\n // never reached\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // The `PedgagocialException` is propagated all the way down to here\n });\n ```\n\n Assimilation\n ------------\n\n Sometimes the value you want to propagate to a downstream promise can only be\n retrieved asynchronously. This can be achieved by returning a promise in the\n fulfillment or rejection handler. The downstream promise will then be pending\n until the returned promise is settled. This is called *assimilation*.\n\n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // The user's comments are now available\n });\n ```\n\n If the assimliated promise rejects, then the downstream promise will also reject.\n\n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // If `findCommentsByAuthor` fulfills, we'll have the value here\n }, function (reason) {\n // If `findCommentsByAuthor` rejects, we'll have the reason here\n });\n ```\n\n Simple Example\n --------------\n\n Synchronous Example\n\n ```javascript\n var result;\n\n try {\n result = findResult();\n // success\n } catch(reason) {\n // failure\n }\n ```\n\n Errback Example\n\n ```js\n findResult(function(result, err){\n if (err) {\n // failure\n } else {\n // success\n }\n });\n ```\n\n Promise Example;\n\n ```javascript\n findResult().then(function(result){\n // success\n }, function(reason){\n // failure\n });\n ```\n\n Advanced Example\n --------------\n\n Synchronous Example\n\n ```javascript\n var author, books;\n\n try {\n author = findAuthor();\n books = findBooksByAuthor(author);\n // success\n } catch(reason) {\n // failure\n }\n ```\n\n Errback Example\n\n ```js\n\n function foundBooks(books) {\n\n }\n\n function failure(reason) {\n\n }\n\n findAuthor(function(author, err){\n if (err) {\n failure(err);\n // failure\n } else {\n try {\n findBoooksByAuthor(author, function(books, err) {\n if (err) {\n failure(err);\n } else {\n try {\n foundBooks(books);\n } catch(reason) {\n failure(reason);\n }\n }\n });\n } catch(error) {\n failure(err);\n }\n // success\n }\n });\n ```\n\n Promise Example;\n\n ```javascript\n findAuthor().\n then(findBooksByAuthor).\n then(function(books){\n // found books\n }).catch(function(reason){\n // something went wrong\n });\n ```\n\n @method then\n @param {Function} onFulfillment\n @param {Function} onRejection\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise}\n */\n then: lib$rsvp$then$$default,\n\n /**\n `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n as the catch block of a try/catch statement.\n\n ```js\n function findAuthor(){\n throw new Error('couldn't find that author');\n }\n\n // synchronous\n try {\n findAuthor();\n } catch(reason) {\n // something went wrong\n }\n\n // async with promises\n findAuthor().catch(function(reason){\n // something went wrong\n });\n ```\n\n @method catch\n @param {Function} onRejection\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise}\n */\n 'catch': function(onRejection, label) {\n return this.then(undefined, onRejection, label);\n },\n\n /**\n `finally` will be invoked regardless of the promise's fate just as native\n try/catch/finally behaves\n\n Synchronous example:\n\n ```js\n findAuthor() {\n if (Math.random() > 0.5) {\n throw new Error();\n }\n return new Author();\n }\n\n try {\n return findAuthor(); // succeed or fail\n } catch(error) {\n return findOtherAuther();\n } finally {\n // always runs\n // doesn't affect the return value\n }\n ```\n\n Asynchronous example:\n\n ```js\n findAuthor().catch(function(reason){\n return findOtherAuther();\n }).finally(function(){\n // author was either found, or not\n });\n ```\n\n @method finally\n @param {Function} callback\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise}\n */\n 'finally': function(callback, label) {\n var promise = this;\n var constructor = promise.constructor;\n\n return promise.then(function(value) {\n return constructor.resolve(callback()).then(function() {\n return value;\n });\n }, function(reason) {\n return constructor.resolve(callback()).then(function() {\n return constructor.reject(reason);\n });\n }, label);\n }\n };\n function lib$rsvp$$internal$$withOwnPromise() {\n return new TypeError('A promises callback cannot return that same promise.');\n }\n\n function lib$rsvp$$internal$$noop() {}\n\n var lib$rsvp$$internal$$PENDING = void 0;\n var lib$rsvp$$internal$$FULFILLED = 1;\n var lib$rsvp$$internal$$REJECTED = 2;\n\n var lib$rsvp$$internal$$GET_THEN_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n function lib$rsvp$$internal$$getThen(promise) {\n try {\n return promise.then;\n } catch(error) {\n lib$rsvp$$internal$$GET_THEN_ERROR.error = error;\n return lib$rsvp$$internal$$GET_THEN_ERROR;\n }\n }\n\n function lib$rsvp$$internal$$tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n try {\n then.call(value, fulfillmentHandler, rejectionHandler);\n } catch(e) {\n return e;\n }\n }\n\n function lib$rsvp$$internal$$handleForeignThenable(promise, thenable, then) {\n lib$rsvp$config$$config.async(function(promise) {\n var sealed = false;\n var error = lib$rsvp$$internal$$tryThen(then, thenable, function(value) {\n if (sealed) { return; }\n sealed = true;\n if (thenable !== value) {\n lib$rsvp$$internal$$resolve(promise, value, undefined);\n } else {\n lib$rsvp$$internal$$fulfill(promise, value);\n }\n }, function(reason) {\n if (sealed) { return; }\n sealed = true;\n\n lib$rsvp$$internal$$reject(promise, reason);\n }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n if (!sealed && error) {\n sealed = true;\n lib$rsvp$$internal$$reject(promise, error);\n }\n }, promise);\n }\n\n function lib$rsvp$$internal$$handleOwnThenable(promise, thenable) {\n if (thenable._state === lib$rsvp$$internal$$FULFILLED) {\n lib$rsvp$$internal$$fulfill(promise, thenable._result);\n } else if (thenable._state === lib$rsvp$$internal$$REJECTED) {\n thenable._onError = null;\n lib$rsvp$$internal$$reject(promise, thenable._result);\n } else {\n lib$rsvp$$internal$$subscribe(thenable, undefined, function(value) {\n if (thenable !== value) {\n lib$rsvp$$internal$$resolve(promise, value, undefined);\n } else {\n lib$rsvp$$internal$$fulfill(promise, value);\n }\n }, function(reason) {\n lib$rsvp$$internal$$reject(promise, reason);\n });\n }\n }\n\n function lib$rsvp$$internal$$handleMaybeThenable(promise, maybeThenable, then) {\n if (maybeThenable.constructor === promise.constructor &&\n then === lib$rsvp$then$$default &&\n constructor.resolve === lib$rsvp$promise$resolve$$default) {\n lib$rsvp$$internal$$handleOwnThenable(promise, maybeThenable);\n } else {\n if (then === lib$rsvp$$internal$$GET_THEN_ERROR) {\n lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$GET_THEN_ERROR.error);\n } else if (then === undefined) {\n lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n } else if (lib$rsvp$utils$$isFunction(then)) {\n lib$rsvp$$internal$$handleForeignThenable(promise, maybeThenable, then);\n } else {\n lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n }\n }\n }\n\n function lib$rsvp$$internal$$resolve(promise, value) {\n if (promise === value) {\n lib$rsvp$$internal$$fulfill(promise, value);\n } else if (lib$rsvp$utils$$objectOrFunction(value)) {\n lib$rsvp$$internal$$handleMaybeThenable(promise, value, lib$rsvp$$internal$$getThen(value));\n } else {\n lib$rsvp$$internal$$fulfill(promise, value);\n }\n }\n\n function lib$rsvp$$internal$$publishRejection(promise) {\n if (promise._onError) {\n promise._onError(promise._result);\n }\n\n lib$rsvp$$internal$$publish(promise);\n }\n\n function lib$rsvp$$internal$$fulfill(promise, value) {\n if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n\n promise._result = value;\n promise._state = lib$rsvp$$internal$$FULFILLED;\n\n if (promise._subscribers.length === 0) {\n if (lib$rsvp$config$$config.instrument) {\n lib$rsvp$instrument$$default('fulfilled', promise);\n }\n } else {\n lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, promise);\n }\n }\n\n function lib$rsvp$$internal$$reject(promise, reason) {\n if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n promise._state = lib$rsvp$$internal$$REJECTED;\n promise._result = reason;\n lib$rsvp$config$$config.async(lib$rsvp$$internal$$publishRejection, promise);\n }\n\n function lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection) {\n var subscribers = parent._subscribers;\n var length = subscribers.length;\n\n parent._onError = null;\n\n subscribers[length] = child;\n subscribers[length + lib$rsvp$$internal$$FULFILLED] = onFulfillment;\n subscribers[length + lib$rsvp$$internal$$REJECTED] = onRejection;\n\n if (length === 0 && parent._state) {\n lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, parent);\n }\n }\n\n function lib$rsvp$$internal$$publish(promise) {\n var subscribers = promise._subscribers;\n var settled = promise._state;\n\n if (lib$rsvp$config$$config.instrument) {\n lib$rsvp$instrument$$default(settled === lib$rsvp$$internal$$FULFILLED ? 'fulfilled' : 'rejected', promise);\n }\n\n if (subscribers.length === 0) { return; }\n\n var child, callback, detail = promise._result;\n\n for (var i = 0; i < subscribers.length; i += 3) {\n child = subscribers[i];\n callback = subscribers[i + settled];\n\n if (child) {\n lib$rsvp$$internal$$invokeCallback(settled, child, callback, detail);\n } else {\n callback(detail);\n }\n }\n\n promise._subscribers.length = 0;\n }\n\n function lib$rsvp$$internal$$ErrorObject() {\n this.error = null;\n }\n\n var lib$rsvp$$internal$$TRY_CATCH_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n function lib$rsvp$$internal$$tryCatch(callback, detail) {\n try {\n return callback(detail);\n } catch(e) {\n lib$rsvp$$internal$$TRY_CATCH_ERROR.error = e;\n return lib$rsvp$$internal$$TRY_CATCH_ERROR;\n }\n }\n\n function lib$rsvp$$internal$$invokeCallback(settled, promise, callback, detail) {\n var hasCallback = lib$rsvp$utils$$isFunction(callback),\n value, error, succeeded, failed;\n\n if (hasCallback) {\n value = lib$rsvp$$internal$$tryCatch(callback, detail);\n\n if (value === lib$rsvp$$internal$$TRY_CATCH_ERROR) {\n failed = true;\n error = value.error;\n value = null;\n } else {\n succeeded = true;\n }\n\n if (promise === value) {\n lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$withOwnPromise());\n return;\n }\n\n } else {\n value = detail;\n succeeded = true;\n }\n\n if (promise._state !== lib$rsvp$$internal$$PENDING) {\n // noop\n } else if (hasCallback && succeeded) {\n lib$rsvp$$internal$$resolve(promise, value);\n } else if (failed) {\n lib$rsvp$$internal$$reject(promise, error);\n } else if (settled === lib$rsvp$$internal$$FULFILLED) {\n lib$rsvp$$internal$$fulfill(promise, value);\n } else if (settled === lib$rsvp$$internal$$REJECTED) {\n lib$rsvp$$internal$$reject(promise, value);\n }\n }\n\n function lib$rsvp$$internal$$initializePromise(promise, resolver) {\n var resolved = false;\n try {\n resolver(function resolvePromise(value){\n if (resolved) { return; }\n resolved = true;\n lib$rsvp$$internal$$resolve(promise, value);\n }, function rejectPromise(reason) {\n if (resolved) { return; }\n resolved = true;\n lib$rsvp$$internal$$reject(promise, reason);\n });\n } catch(e) {\n lib$rsvp$$internal$$reject(promise, e);\n }\n }\n\n function lib$rsvp$all$settled$$AllSettled(Constructor, entries, label) {\n this._superConstructor(Constructor, entries, false /* don't abort on reject */, label);\n }\n\n lib$rsvp$all$settled$$AllSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n lib$rsvp$all$settled$$AllSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n lib$rsvp$all$settled$$AllSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n lib$rsvp$all$settled$$AllSettled.prototype._validationError = function() {\n return new Error('allSettled must be called with an array');\n };\n\n function lib$rsvp$all$settled$$allSettled(entries, label) {\n return new lib$rsvp$all$settled$$AllSettled(lib$rsvp$promise$$default, entries, label).promise;\n }\n var lib$rsvp$all$settled$$default = lib$rsvp$all$settled$$allSettled;\n function lib$rsvp$all$$all(array, label) {\n return lib$rsvp$promise$$default.all(array, label);\n }\n var lib$rsvp$all$$default = lib$rsvp$all$$all;\n var lib$rsvp$asap$$len = 0;\n var lib$rsvp$asap$$toString = {}.toString;\n var lib$rsvp$asap$$vertxNext;\n function lib$rsvp$asap$$asap(callback, arg) {\n lib$rsvp$asap$$queue[lib$rsvp$asap$$len] = callback;\n lib$rsvp$asap$$queue[lib$rsvp$asap$$len + 1] = arg;\n lib$rsvp$asap$$len += 2;\n if (lib$rsvp$asap$$len === 2) {\n // If len is 1, that means that we need to schedule an async flush.\n // If additional callbacks are queued before the queue is flushed, they\n // will be processed by this flush that we are scheduling.\n lib$rsvp$asap$$scheduleFlush();\n }\n }\n\n var lib$rsvp$asap$$default = lib$rsvp$asap$$asap;\n\n var lib$rsvp$asap$$browserWindow = (typeof window !== 'undefined') ? window : undefined;\n var lib$rsvp$asap$$browserGlobal = lib$rsvp$asap$$browserWindow || {};\n var lib$rsvp$asap$$BrowserMutationObserver = lib$rsvp$asap$$browserGlobal.MutationObserver || lib$rsvp$asap$$browserGlobal.WebKitMutationObserver;\n var lib$rsvp$asap$$isNode = typeof self === 'undefined' &&\n typeof process !== 'undefined' && {}.toString.call(process) === '[object process]';\n\n // test for web worker but not in IE10\n var lib$rsvp$asap$$isWorker = typeof Uint8ClampedArray !== 'undefined' &&\n typeof importScripts !== 'undefined' &&\n typeof MessageChannel !== 'undefined';\n\n // node\n function lib$rsvp$asap$$useNextTick() {\n var nextTick = process.nextTick;\n // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n // setImmediate should be used instead instead\n var version = process.versions.node.match(/^(?:(\\d+)\\.)?(?:(\\d+)\\.)?(\\*|\\d+)$/);\n if (Array.isArray(version) && version[1] === '0' && version[2] === '10') {\n nextTick = setImmediate;\n }\n return function() {\n nextTick(lib$rsvp$asap$$flush);\n };\n }\n\n // vertx\n function lib$rsvp$asap$$useVertxTimer() {\n return function() {\n lib$rsvp$asap$$vertxNext(lib$rsvp$asap$$flush);\n };\n }\n\n function lib$rsvp$asap$$useMutationObserver() {\n var iterations = 0;\n var observer = new lib$rsvp$asap$$BrowserMutationObserver(lib$rsvp$asap$$flush);\n var node = document.createTextNode('');\n observer.observe(node, { characterData: true });\n\n return function() {\n node.data = (iterations = ++iterations % 2);\n };\n }\n\n // web worker\n function lib$rsvp$asap$$useMessageChannel() {\n var channel = new MessageChannel();\n channel.port1.onmessage = lib$rsvp$asap$$flush;\n return function () {\n channel.port2.postMessage(0);\n };\n }\n\n function lib$rsvp$asap$$useSetTimeout() {\n return function() {\n setTimeout(lib$rsvp$asap$$flush, 1);\n };\n }\n\n var lib$rsvp$asap$$queue = new Array(1000);\n function lib$rsvp$asap$$flush() {\n for (var i = 0; i < lib$rsvp$asap$$len; i+=2) {\n var callback = lib$rsvp$asap$$queue[i];\n var arg = lib$rsvp$asap$$queue[i+1];\n\n callback(arg);\n\n lib$rsvp$asap$$queue[i] = undefined;\n lib$rsvp$asap$$queue[i+1] = undefined;\n }\n\n lib$rsvp$asap$$len = 0;\n }\n\n function lib$rsvp$asap$$attemptVertex() {\n try {\n var r = require;\n var vertx = r('vertx');\n lib$rsvp$asap$$vertxNext = vertx.runOnLoop || vertx.runOnContext;\n return lib$rsvp$asap$$useVertxTimer();\n } catch(e) {\n return lib$rsvp$asap$$useSetTimeout();\n }\n }\n\n var lib$rsvp$asap$$scheduleFlush;\n // Decide what async method to use to triggering processing of queued callbacks:\n if (lib$rsvp$asap$$isNode) {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useNextTick();\n } else if (lib$rsvp$asap$$BrowserMutationObserver) {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMutationObserver();\n } else if (lib$rsvp$asap$$isWorker) {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMessageChannel();\n } else if (lib$rsvp$asap$$browserWindow === undefined && typeof require === 'function') {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$attemptVertex();\n } else {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useSetTimeout();\n }\n function lib$rsvp$defer$$defer(label) {\n var deferred = {};\n\n deferred['promise'] = new lib$rsvp$promise$$default(function(resolve, reject) {\n deferred['resolve'] = resolve;\n deferred['reject'] = reject;\n }, label);\n\n return deferred;\n }\n var lib$rsvp$defer$$default = lib$rsvp$defer$$defer;\n function lib$rsvp$filter$$filter(promises, filterFn, label) {\n return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n if (!lib$rsvp$utils$$isFunction(filterFn)) {\n throw new TypeError(\"You must pass a function as filter's second argument.\");\n }\n\n var length = values.length;\n var filtered = new Array(length);\n\n for (var i = 0; i < length; i++) {\n filtered[i] = filterFn(values[i]);\n }\n\n return lib$rsvp$promise$$default.all(filtered, label).then(function(filtered) {\n var results = new Array(length);\n var newLength = 0;\n\n for (var i = 0; i < length; i++) {\n if (filtered[i]) {\n results[newLength] = values[i];\n newLength++;\n }\n }\n\n results.length = newLength;\n\n return results;\n });\n });\n }\n var lib$rsvp$filter$$default = lib$rsvp$filter$$filter;\n\n function lib$rsvp$promise$hash$$PromiseHash(Constructor, object, label) {\n this._superConstructor(Constructor, object, true, label);\n }\n\n var lib$rsvp$promise$hash$$default = lib$rsvp$promise$hash$$PromiseHash;\n\n lib$rsvp$promise$hash$$PromiseHash.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n lib$rsvp$promise$hash$$PromiseHash.prototype._superConstructor = lib$rsvp$enumerator$$default;\n lib$rsvp$promise$hash$$PromiseHash.prototype._init = function() {\n this._result = {};\n };\n\n lib$rsvp$promise$hash$$PromiseHash.prototype._validateInput = function(input) {\n return input && typeof input === 'object';\n };\n\n lib$rsvp$promise$hash$$PromiseHash.prototype._validationError = function() {\n return new Error('Promise.hash must be called with an object');\n };\n\n lib$rsvp$promise$hash$$PromiseHash.prototype._enumerate = function() {\n var enumerator = this;\n var promise = enumerator.promise;\n var input = enumerator._input;\n var results = [];\n\n for (var key in input) {\n if (promise._state === lib$rsvp$$internal$$PENDING && Object.prototype.hasOwnProperty.call(input, key)) {\n results.push({\n position: key,\n entry: input[key]\n });\n }\n }\n\n var length = results.length;\n enumerator._remaining = length;\n var result;\n\n for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n result = results[i];\n enumerator._eachEntry(result.entry, result.position);\n }\n };\n\n function lib$rsvp$hash$settled$$HashSettled(Constructor, object, label) {\n this._superConstructor(Constructor, object, false, label);\n }\n\n lib$rsvp$hash$settled$$HashSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$promise$hash$$default.prototype);\n lib$rsvp$hash$settled$$HashSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n lib$rsvp$hash$settled$$HashSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n\n lib$rsvp$hash$settled$$HashSettled.prototype._validationError = function() {\n return new Error('hashSettled must be called with an object');\n };\n\n function lib$rsvp$hash$settled$$hashSettled(object, label) {\n return new lib$rsvp$hash$settled$$HashSettled(lib$rsvp$promise$$default, object, label).promise;\n }\n var lib$rsvp$hash$settled$$default = lib$rsvp$hash$settled$$hashSettled;\n function lib$rsvp$hash$$hash(object, label) {\n return new lib$rsvp$promise$hash$$default(lib$rsvp$promise$$default, object, label).promise;\n }\n var lib$rsvp$hash$$default = lib$rsvp$hash$$hash;\n function lib$rsvp$map$$map(promises, mapFn, label) {\n return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n if (!lib$rsvp$utils$$isFunction(mapFn)) {\n throw new TypeError(\"You must pass a function as map's second argument.\");\n }\n\n var length = values.length;\n var results = new Array(length);\n\n for (var i = 0; i < length; i++) {\n results[i] = mapFn(values[i]);\n }\n\n return lib$rsvp$promise$$default.all(results, label);\n });\n }\n var lib$rsvp$map$$default = lib$rsvp$map$$map;\n\n function lib$rsvp$node$$Result() {\n this.value = undefined;\n }\n\n var lib$rsvp$node$$ERROR = new lib$rsvp$node$$Result();\n var lib$rsvp$node$$GET_THEN_ERROR = new lib$rsvp$node$$Result();\n\n function lib$rsvp$node$$getThen(obj) {\n try {\n return obj.then;\n } catch(error) {\n lib$rsvp$node$$ERROR.value= error;\n return lib$rsvp$node$$ERROR;\n }\n }\n\n\n function lib$rsvp$node$$tryApply(f, s, a) {\n try {\n f.apply(s, a);\n } catch(error) {\n lib$rsvp$node$$ERROR.value = error;\n return lib$rsvp$node$$ERROR;\n }\n }\n\n function lib$rsvp$node$$makeObject(_, argumentNames) {\n var obj = {};\n var name;\n var i;\n var length = _.length;\n var args = new Array(length);\n\n for (var x = 0; x < length; x++) {\n args[x] = _[x];\n }\n\n for (i = 0; i < argumentNames.length; i++) {\n name = argumentNames[i];\n obj[name] = args[i + 1];\n }\n\n return obj;\n }\n\n function lib$rsvp$node$$arrayResult(_) {\n var length = _.length;\n var args = new Array(length - 1);\n\n for (var i = 1; i < length; i++) {\n args[i - 1] = _[i];\n }\n\n return args;\n }\n\n function lib$rsvp$node$$wrapThenable(then, promise) {\n return {\n then: function(onFulFillment, onRejection) {\n return then.call(promise, onFulFillment, onRejection);\n }\n };\n }\n\n function lib$rsvp$node$$denodeify(nodeFunc, options) {\n var fn = function() {\n var self = this;\n var l = arguments.length;\n var args = new Array(l + 1);\n var arg;\n var promiseInput = false;\n\n for (var i = 0; i < l; ++i) {\n arg = arguments[i];\n\n if (!promiseInput) {\n // TODO: clean this up\n promiseInput = lib$rsvp$node$$needsPromiseInput(arg);\n if (promiseInput === lib$rsvp$node$$GET_THEN_ERROR) {\n var p = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n lib$rsvp$$internal$$reject(p, lib$rsvp$node$$GET_THEN_ERROR.value);\n return p;\n } else if (promiseInput && promiseInput !== true) {\n arg = lib$rsvp$node$$wrapThenable(promiseInput, arg);\n }\n }\n args[i] = arg;\n }\n\n var promise = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n\n args[l] = function(err, val) {\n if (err)\n lib$rsvp$$internal$$reject(promise, err);\n else if (options === undefined)\n lib$rsvp$$internal$$resolve(promise, val);\n else if (options === true)\n lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$arrayResult(arguments));\n else if (lib$rsvp$utils$$isArray(options))\n lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$makeObject(arguments, options));\n else\n lib$rsvp$$internal$$resolve(promise, val);\n };\n\n if (promiseInput) {\n return lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self);\n } else {\n return lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self);\n }\n };\n\n fn.__proto__ = nodeFunc;\n\n return fn;\n }\n\n var lib$rsvp$node$$default = lib$rsvp$node$$denodeify;\n\n function lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self) {\n var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n if (result === lib$rsvp$node$$ERROR) {\n lib$rsvp$$internal$$reject(promise, result.value);\n }\n return promise;\n }\n\n function lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self){\n return lib$rsvp$promise$$default.all(args).then(function(args){\n var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n if (result === lib$rsvp$node$$ERROR) {\n lib$rsvp$$internal$$reject(promise, result.value);\n }\n return promise;\n });\n }\n\n function lib$rsvp$node$$needsPromiseInput(arg) {\n if (arg && typeof arg === 'object') {\n if (arg.constructor === lib$rsvp$promise$$default) {\n return true;\n } else {\n return lib$rsvp$node$$getThen(arg);\n }\n } else {\n return false;\n }\n }\n var lib$rsvp$platform$$platform;\n\n /* global self */\n if (typeof self === 'object') {\n lib$rsvp$platform$$platform = self;\n\n /* global global */\n } else if (typeof global === 'object') {\n lib$rsvp$platform$$platform = global;\n } else {\n throw new Error('no global: `self` or `global` found');\n }\n\n var lib$rsvp$platform$$default = lib$rsvp$platform$$platform;\n function lib$rsvp$race$$race(array, label) {\n return lib$rsvp$promise$$default.race(array, label);\n }\n var lib$rsvp$race$$default = lib$rsvp$race$$race;\n function lib$rsvp$reject$$reject(reason, label) {\n return lib$rsvp$promise$$default.reject(reason, label);\n }\n var lib$rsvp$reject$$default = lib$rsvp$reject$$reject;\n function lib$rsvp$resolve$$resolve(value, label) {\n return lib$rsvp$promise$$default.resolve(value, label);\n }\n var lib$rsvp$resolve$$default = lib$rsvp$resolve$$resolve;\n function lib$rsvp$rethrow$$rethrow(reason) {\n setTimeout(function() {\n throw reason;\n });\n throw reason;\n }\n var lib$rsvp$rethrow$$default = lib$rsvp$rethrow$$rethrow;\n\n // defaults\n lib$rsvp$config$$config.async = lib$rsvp$asap$$default;\n lib$rsvp$config$$config.after = function(cb) {\n setTimeout(cb, 0);\n };\n var lib$rsvp$$cast = lib$rsvp$resolve$$default;\n function lib$rsvp$$async(callback, arg) {\n lib$rsvp$config$$config.async(callback, arg);\n }\n\n function lib$rsvp$$on() {\n lib$rsvp$config$$config['on'].apply(lib$rsvp$config$$config, arguments);\n }\n\n function lib$rsvp$$off() {\n lib$rsvp$config$$config['off'].apply(lib$rsvp$config$$config, arguments);\n }\n\n // Set up instrumentation through `window.__PROMISE_INTRUMENTATION__`\n if (typeof window !== 'undefined' && typeof window['__PROMISE_INSTRUMENTATION__'] === 'object') {\n var lib$rsvp$$callbacks = window['__PROMISE_INSTRUMENTATION__'];\n lib$rsvp$config$$configure('instrument', true);\n for (var lib$rsvp$$eventName in lib$rsvp$$callbacks) {\n if (lib$rsvp$$callbacks.hasOwnProperty(lib$rsvp$$eventName)) {\n lib$rsvp$$on(lib$rsvp$$eventName, lib$rsvp$$callbacks[lib$rsvp$$eventName]);\n }\n }\n }\n\n var lib$rsvp$umd$$RSVP = {\n 'race': lib$rsvp$race$$default,\n 'Promise': lib$rsvp$promise$$default,\n 'allSettled': lib$rsvp$all$settled$$default,\n 'hash': lib$rsvp$hash$$default,\n 'hashSettled': lib$rsvp$hash$settled$$default,\n 'denodeify': lib$rsvp$node$$default,\n 'on': lib$rsvp$$on,\n 'off': lib$rsvp$$off,\n 'map': lib$rsvp$map$$default,\n 'filter': lib$rsvp$filter$$default,\n 'resolve': lib$rsvp$resolve$$default,\n 'reject': lib$rsvp$reject$$default,\n 'all': lib$rsvp$all$$default,\n 'rethrow': lib$rsvp$rethrow$$default,\n 'defer': lib$rsvp$defer$$default,\n 'EventTarget': lib$rsvp$events$$default,\n 'configure': lib$rsvp$config$$configure,\n 'async': lib$rsvp$$async\n };\n\n /* global define:true module:true window: true */\n if (typeof define === 'function' && define['amd']) {\n define(function() { return lib$rsvp$umd$$RSVP; });\n } else if (typeof module !== 'undefined' && module['exports']) {\n module['exports'] = lib$rsvp$umd$$RSVP;\n } else if (typeof lib$rsvp$platform$$default !== 'undefined') {\n lib$rsvp$platform$$default['RSVP'] = lib$rsvp$umd$$RSVP;\n }\n}).call(this);\n\n\n}).call(this,require('_process'),typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n\n},{\"_process\":71}]},{},[29])\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","js/app/cache.js","js/app/constructor.js","js/app/index.js","js/dom/add_categories.js","js/dom/add_files.js","js/dom/index.js","js/dom/loading_slider.js","js/dom/module_container.js","js/dom/setup/index.js","js/dom/setup/setup_dividers.js","js/dom/setup/setup_document.js","js/dom/setup/setup_files_bar.js","js/dom/setup/setup_interval.js","js/dom/setup/setup_module_container.js","js/dom/setup/setup_side_menu.js","js/dom/setup/setup_tab_container.js","js/dom/setup/setup_top_menu.js","js/dom/setup/setup_window.js","js/dom/show_algorithm.js","js/dom/show_description.js","js/dom/show_first_algorithm.js","js/dom/show_requested_algorithm.js","js/dom/show_wiki.js","js/dom/toast.js","js/dom/top_menu.js","js/editor/create.js","js/editor/executor.js","js/editor/index.js","js/index.js","js/module/data/array1d.js","js/module/data/array2d.js","js/module/data/coordinate_system.js","js/module/data/directed_graph.js","js/module/data/index.js","js/module/data/integer.js","js/module/data/undirected_graph.js","js/module/data/weighted_directed_graph.js","js/module/data/weighted_undirected_graph.js","js/module/index.js","js/module/tracer/array1d.js","js/module/tracer/array2d.js","js/module/tracer/chart.js","js/module/tracer/coordinate_system.js","js/module/tracer/directed_graph.js","js/module/tracer/index.js","js/module/tracer/log.js","js/module/tracer/tracer.js","js/module/tracer/undirected_graph.js","js/module/tracer/weighted_directed_graph.js","js/module/tracer/weighted_undirected_graph.js","js/server/ajax/get.js","js/server/ajax/get_json.js","js/server/ajax/post_json.js","js/server/ajax/request.js","js/server/helpers.js","js/server/index.js","js/server/load_algorithm.js","js/server/load_categories.js","js/server/load_file.js","js/server/load_scratch_paper.js","js/server/load_wiki.js","js/server/load_wiki_list.js","js/server/share_scratch_paper.js","js/tracer_manager/index.js","js/tracer_manager/manager.js","js/tracer_manager/util/from_json.js","js/tracer_manager/util/index.js","js/tracer_manager/util/refine_by_type.js","js/tracer_manager/util/to_json.js","js/utils/index.js","node_modules/process/browser.js","node_modules/rsvp/dist/rsvp.js"],"names":[],"mappings":"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AGF,IAAM,SAAS,SAAT,MAAS,CAAC,GAAD,EAAS;AACtB,SAAO,UAAU,GAAV,EAAe,UAAC,GAAD,EAAM,KAAN,EAAgB;AACpC,WAAO,UAAU,QAAV,GAAqB,UAArB,GAAkC,KAAzC;AACD,GAFM,CAAP;AAGD,CAJD;;AAMA,OAAO,OAAP,GAAiB,MAAjB;;;ACZA;;AAEA,IAAM,iBAAiB,SAAjB,cAAiB,CAAC,QAAD,EAAW,SAAX,EAAyB;AAC9C,SAAO,YAAY,SAAnB;AACD,CAFD;;AAIA,IAAM,kBAAkB,SAAlB,eAAkB,CAAC,QAAD,EAAW,SAAX,EAAyB;AAC/C,MAAI,eAAe,QAAf,CAAJ,EAA8B,OAAO,4BAAP;AAC9B,0BAAsB,QAAtB,SAAkC,SAAlC;AACD,CAHD;;AAKA,IAAM,aAAa,SAAb,UAAa,CAAC,QAAD,EAAW,SAAX,EAAsB,IAAtB,EAA+B;AAChD,MAAI,eAAe,QAAf,CAAJ,EAA8B,OAAO,4BAAP;AAC9B,0BAAsB,QAAtB,SAAkC,SAAlC,SAA+C,IAA/C;AACD,CAHD;;AAKA,OAAO,OAAP,GAAiB;AACf,gCADe;AAEf,kCAFe;AAGf;AAHe,CAAjB;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC9FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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})","'use strict';\n\nconst {\n  extend\n} = $;\n\nconst cache = {\n  lastFileUsed: '',\n  files: {}\n};\n\nconst assertFileName = (name) => {\n  if (!name) {\n    throw 'Missing file name';\n  }\n};\n\n\n/**\n * Global application cache\n */\nmodule.exports = {\n\n  getCachedFile(name) {\n    assertFileName(name);\n    return cache.files[name];\n  },\n\n  updateCachedFile(name, updates) {\n    assertFileName(name);\n    if (!cache.files[name]) {\n      cache.files[name] = {};\n    }\n    extend(cache.files[name], updates);\n  },\n\n  getLastFileUsed() {\n    return cache.lastFileUsed;\n  },\n\n  setLastFileUsed(file) {\n    cache.lastFileUsed = file;\n  }\n};","'use strict';\n\nconst Editor = require('../editor');\nconst TracerManager = require('../tracer_manager');\nconst DOM = require('../dom/setup');\n\nconst {\n  showLoadingSlider,\n  hideLoadingSlider\n} = require('../dom/loading_slider');\n\nconst Cache = require('./cache');\n\nconst state = {\n  isLoading: null,\n  editor: null,\n  tracerManager: null,\n  categories: null,\n  loadedScratch: null,\n  wikiList: null\n};\n\nconst initState = (tracerManager) => {\n  state.isLoading = false;\n  state.editor = new Editor(tracerManager);\n  state.tracerManager = tracerManager;\n  state.categories = {};\n  state.loadedScratch = null;\n  state.wikiList = [];\n};\n\n/**\n * Global application singleton.\n */\nconst App = function () {\n\n  this.getIsLoading = () => {\n    return state.isLoading;\n  };\n\n  this.setIsLoading = (loading) => {\n    state.isLoading = loading;\n    if (loading) {\n      showLoadingSlider();\n    } else {\n      hideLoadingSlider();\n    }\n  };\n\n  this.getEditor = () => {\n    return state.editor;\n  };\n\n  this.getCategories = () => {\n    return state.categories;\n  };\n\n  this.getCategory = (name) => {\n    return state.categories[name];\n  };\n\n  this.setCategories = (categories) => {\n    state.categories = categories;\n  };\n\n  this.updateCategory = (name, updates) => {\n    $.extend(state.categories[name], updates);\n  };\n\n  this.getTracerManager = () => {\n    return state.tracerManager;\n  };\n\n  this.getLoadedScratch = () => {\n    return state.loadedScratch;\n  };\n\n  this.setLoadedScratch = (loadedScratch) => {\n    state.loadedScratch = loadedScratch;\n  };\n\n  this.getWikiList = () => {\n    return state.wikiList;\n  };\n\n  this.setWikiList = (wikiList) => {\n    state.wikiList = wikiList;\n  };\n\n  this.hasWiki = (wiki) => {\n    return ~state.wikiList.indexOf(wiki);\n  };\n\n  const tracerManager = TracerManager.init();\n\n  initState(tracerManager);\n  DOM.setup(tracerManager);\n\n};\n\nApp.prototype = Cache;\n\nmodule.exports = App;\n","'use strict';\n\n/**\n * This is the main application instance.\n * Gets populated on page load. \n */\nmodule.exports = {};","'use strict';\n\nconst app = require('../app');\nconst Server = require('../server');\nconst showAlgorithm = require('./show_algorithm');\n\nconst {\n  each\n} = $;\n\nconst getAlgorithmDOM = (category, subList, algorithm) => {\n  return $('<button class=\"indent\">')\n    .append(subList[algorithm])\n    .attr('data-algorithm', algorithm)\n    .attr('data-category', category)\n    .click(function () {\n      Server.loadAlgorithm(category, algorithm).then((data) => {\n        showAlgorithm(category, algorithm, data);\n      });\n    });\n\n  $('#list').append($algorithm);\n};\n\nconst addCategoryToDOM = (category) => {\n\n  const {\n    name: categoryName,\n    list: categorySubList\n  } = app.getCategory(category);\n\n  const $category = $('<button class=\"category\">')\n    .append('<i class=\"fa fa-fw fa-caret-right\">')\n    .append(categoryName)\n    .attr('data-category', category);\n\n  $category.click(function () {\n    const $self = $(this);\n    $self.toggleClass('open');\n    $self.next().toggleClass('collapse');\n    $self.find('i.fa').toggleClass('fa-caret-right fa-caret-down');\n  });\n\n  const $algorithms = $('<div class=\"algorithms collapse\">');\n  $('#list').append($category).append($algorithms);\n\n  each(categorySubList, (algorithm) => {\n    const $algorithm = getAlgorithmDOM(category, categorySubList, algorithm);\n    $algorithms.append($algorithm);\n  });\n};\n\nmodule.exports = () => {\n  each(app.getCategories(), addCategoryToDOM);\n};\n","'use strict';\n\nconst Server = require('../server');\n\nconst {\n  each\n} = $;\n\nconst addFileToDOM = (category, algorithm, file, explanation) => {\n  var $file = $('<button>')\n    .append(file)\n    .attr('data-file', file)\n    .click(function () {\n      Server.loadFile(category, algorithm, file, explanation);\n      $('.files_bar > .wrapper > button').removeClass('active');\n      $(this).addClass('active');\n    });\n  $('.files_bar > .wrapper').append($file);\n  return $file;\n};\n\nmodule.exports = (category, algorithm, files, requestedFile) => {\n  $('.files_bar > .wrapper').empty();\n\n  each(files, (file, explanation) => {\n    var $file = addFileToDOM(category, algorithm, file, explanation);\n    if (requestedFile && requestedFile == file) $file.click();\n  });\n\n  if (!requestedFile) $('.files_bar > .wrapper > button').first().click();\n  $('.files_bar > .wrapper').scroll();\n};","'use strict';\n\nconst showAlgorithm = require('./show_algorithm');\nconst addCategories = require('./add_categories');\nconst showDescription = require('./show_description');\nconst addFiles = require('./add_files');\nconst showFirstAlgorithm = require('./show_first_algorithm');\nconst showRequestedAlgorithm = require('./show_requested_algorithm');\nconst showWiki = require('./show_wiki');\n\nmodule.exports = {\n  showAlgorithm,\n  addCategories,\n  showDescription,\n  addFiles,\n  showFirstAlgorithm,\n  showRequestedAlgorithm,\n  showWiki\n};","'use strict';\n\nconst showLoadingSlider = () => {\n  $('#loading-slider').removeClass('loaded');\n};\n\nconst hideLoadingSlider = () => {\n  $('#loading-slider').addClass('loaded');\n};\n\nmodule.exports = {\n  showLoadingSlider,\n  hideLoadingSlider\n};\n","'use strict';\n\nconst create = () => {\n  const $container = $('<section class=\"module_wrapper\">');\n  $('.module_container').append($container);\n  return $container;\n};\n\nmodule.exports = {\n  create\n};\n","'use strict';\n\nconst setupDividers = require('./setup_dividers');\nconst setupDocument = require('./setup_document');\nconst setupFilesBar = require('./setup_files_bar');\nconst setupInterval = require('./setup_interval');\nconst setupModuleContainer = require('./setup_module_container');\nconst setupTabContainer = require('./setup_tab_container');\nconst setupSideMenu = require('./setup_side_menu');\nconst setupTopMenu = require('./setup_top_menu');\nconst setupWindow = require('./setup_window');\n\n/**\n * Initializes elements once the app loads in the DOM.\n */\nconst setup = () => {\n\n  $('.btn input').click((e) => {\n    e.stopPropagation();\n  });\n\n  // dividers\n  setupDividers();\n\n  // document\n  setupDocument();\n\n  // files bar\n  setupFilesBar();\n\n  // interval\n  setupInterval();\n\n  // module container\n  setupModuleContainer();\n\n  // tab container\n  setupTabContainer();\n\n  // side menu\n  setupSideMenu();\n\n  // top menu\n  setupTopMenu();\n\n  // window\n  setupWindow();\n\n};\n\nmodule.exports = {\n  setup\n};\n","'use strict';\n\nconst app = require('../../app');\n\nconst addDividerToDom = (divider) => {\n  const [vertical, $first, $second] = divider;\n  const $parent = $first.parent();\n  const thickness = 5;\n\n  const $divider = $('<div class=\"divider\">');\n\n  let dragging = false;\n  if (vertical) {\n    $divider.addClass('vertical');\n\n    let _left = -thickness / 2;\n    $divider.css({\n      top: 0,\n      bottom: 0,\n      left: _left,\n      width: thickness\n    });\n\n    let x;\n    $divider.mousedown(({\n      pageX\n    }) => {\n      x = pageX;\n      dragging = true;\n    });\n\n    $(document).mousemove(({\n      pageX\n    }) => {\n      if (dragging) {\n        const new_left = $second.position().left + pageX - x;\n        let percent = new_left / $parent.width() * 100;\n        percent = Math.min(90, Math.max(10, percent));\n        $first.css('right', (100 - percent) + '%');\n        $second.css('left', percent + '%');\n        x = pageX;\n        app.getTracerManager().resize();\n        $('.files_bar > .wrapper').scroll();\n      }\n    });\n\n    $(document).mouseup(function(e) {\n      dragging = false;\n    });\n\n  } else {\n\n    $divider.addClass('horizontal');\n    const _top = -thickness / 2;\n    $divider.css({\n      top: _top,\n      height: thickness,\n      left: 0,\n      right: 0\n    });\n\n    let y;\n    $divider.mousedown(function({\n      pageY\n    }) {\n      y = pageY;\n      dragging = true;\n    });\n\n    $(document).mousemove(function({\n      pageY\n    }) {\n      if (dragging) {\n        const new_top = $second.position().top + pageY - y;\n        let percent = new_top / $parent.height() * 100;\n        percent = Math.min(90, Math.max(10, percent));\n        $first.css('bottom', (100 - percent) + '%');\n        $second.css('top', percent + '%');\n        y = pageY;\n        app.getTracerManager().resize();\n      }\n    });\n\n    $(document).mouseup(function(e) {\n      dragging = false;\n    });\n  }\n\n  $second.append($divider);\n};\n\nmodule.exports = () => {\n  const dividers = [\n    ['v', $('.sidemenu'), $('.workspace')],\n    ['v', $('.viewer_container'), $('.editor_container')],\n    ['h', $('.data_container'), $('.code_container')]\n  ];\n  for (let i = 0; i < dividers.length; i++) {\n    addDividerToDom(dividers[i]);\n  }\n};","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = () => {\n  $(document).on('click', 'a', function (e) {\n    const href = $(this).attr('href');\n    if (/^(https?:\\/\\/).+/.test(href)) {\n      e.preventDefault();\n      if (!window.open(href, '_blank')) {\n        alert('Please allow popups for this site');\n      }\n    }\n  });\n\n  $(document).mouseup(function (e) {\n    app.getTracerManager().command('mouseup', e);\n  });\n};\n","'use strict';\n\nconst definitelyBigger = (x, y) => x > (y + 2);\n\nmodule.exports = () => {\n\n  $('.files_bar > .btn-left').click(() => {\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const scrollLeft = $wrapper.scrollLeft();\n\n    $($wrapper.children('button').get().reverse()).each(function() {\n      const left = $(this).position().left;\n      const right = left + $(this).outerWidth();\n      if (0 > left) {\n        $wrapper.scrollLeft(scrollLeft + right - clipWidth);\n        return false;\n      }\n    });\n  });\n\n  $('.files_bar > .btn-right').click(() => {\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const scrollLeft = $wrapper.scrollLeft();\n\n    $wrapper.children('button').each(function() {\n      const left = $(this).position().left;\n      const right = left + $(this).outerWidth();\n      if (clipWidth < right) {\n        $wrapper.scrollLeft(scrollLeft + left);\n        return false;\n      }\n    });\n  });\n\n  $('.files_bar > .wrapper').scroll(function() {\n\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const $left = $wrapper.children('button:first-child');\n    const $right = $wrapper.children('button:last-child');\n    const left = $left.position().left;\n    const right = $right.position().left + $right.outerWidth();\n\n    if (definitelyBigger(0, left) && definitelyBigger(clipWidth, right)) {\n      const scrollLeft = $wrapper.scrollLeft();\n      $wrapper.scrollLeft(scrollLeft + clipWidth - right);\n      return;\n    }\n\n    const lefter = definitelyBigger(0, left);\n    const righter = definitelyBigger(right, clipWidth);\n    $wrapper.toggleClass('shadow-left', lefter);\n    $wrapper.toggleClass('shadow-right', righter);\n    $('.files_bar > .btn-left').attr('disabled', !lefter);\n    $('.files_bar > .btn-right').attr('disabled', !righter);\n  });\n}\n","'use strict';\n\nconst app = require('../../app');\nconst Toast = require('../toast');\n\nconst {\n  parseFloat\n} = Number;\n\nconst minInterval = 0.1;\nconst maxInterval = 10;\nconst startInterval = 0.5;\nconst stepInterval = 0.1;\n\nconst normalize = (sec) => {\n\n\n  let interval;\n  let message;\n  if (sec < minInterval) {\n    interval = minInterval;\n    message = `Interval of ${sec} seconds is too low. Setting to min allowed interval of ${minInterval} second(s).`;\n  } else if (sec > maxInterval) {\n    interval = maxInterval;\n    message = `Interval of ${sec} seconds is too high. Setting to max allowed interval of ${maxInterval} second(s).`;\n  } else {\n    interval = sec;\n    message = `Interval has been set to ${sec} second(s).`\n  }\n\n  return [interval, message];\n};\n\nmodule.exports = () => {\n\n  const $interval = $('#interval');\n  $interval.val(startInterval);\n  $interval.attr({\n    max: maxInterval,\n    min: minInterval,\n    step: stepInterval\n  });\n\n  $('#interval').on('change', function() {\n    const tracerManager = app.getTracerManager();\n    const [seconds, message] = normalize(parseFloat($(this).val()));\n\n    $(this).val(seconds);\n    tracerManager.interval = seconds * 1000;\n    Toast.showInfoToast(message);\n  });\n};\n","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = () => {\n\n  const $module_container = $('.module_container');\n\n  $module_container.on('mousedown', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousedown(e);\n  });\n\n  $module_container.on('mousemove', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousemove(e);\n  });\n\n  $module_container.on('DOMMouseScroll mousewheel', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousewheel(e);\n  });\n}\n","'use strict';\n\nconst app = require('../../app');\nconst Server = require('../../server');\nconst showAlgorithm = require('../show_algorithm');\n\nlet sidemenu_percent;\n\nmodule.exports = () => {\n  $('#navigation').click(() => {\n    const $sidemenu = $('.sidemenu');\n    const $workspace = $('.workspace');\n\n    $sidemenu.toggleClass('active');\n    $('.nav-dropdown').toggleClass('fa-caret-down fa-caret-up');\n\n    if ($sidemenu.hasClass('active')) {\n      $sidemenu.css('right', (100 - sidemenu_percent) + '%');\n      $workspace.css('left', sidemenu_percent + '%');\n\n    } else {\n      sidemenu_percent = $workspace.position().left / $('body').width() * 100;\n      $sidemenu.css('right', 0);\n      $workspace.css('left', 0);\n    }\n\n    app.getTracerManager().resize();\n  });\n\n  $('#documentation').click(function () {\n    $('#btn_doc').click();\n  });\n\n  $('#powered-by').click(() => {\n    $('#powered-by-list button').toggleClass('collapse');\n  });\n\n  $('#scratch-paper').click(() => {\n    const category = 'scratch';\n    const algorithm = app.getLoadedScratch();\n    Server.loadAlgorithm(category, algorithm).then((data) => {\n      showAlgorithm(category, algorithm, data);\n    });\n  });\n};","'use strict';\n\nmodule.exports = () => {\n  $('.tab_bar > button').click(function () {\n    $('.tab_bar > button').removeClass('active');\n    $('.tab_container > .tab').removeClass('active');\n    $(this).addClass('active');\n    $($(this).attr('data-target')).addClass('active');\n  });\n};","'use strict';\n\nconst app = require('../../app');\nconst Server = require('../../server');\nconst Toast = require('../toast');\nconst TopMenu = require('../top_menu');\n\nmodule.exports = () => {\n\n  // shared\n  $('#shared').mouseup(function () {\n    $(this).select();\n  });\n\n  $('#btn_share').click(function () {\n\n    const $icon = $(this).find('.fa-share');\n    $icon.addClass('fa-spin fa-spin-faster');\n\n    Server.shareScratchPaper().then((url) => {\n      $icon.removeClass('fa-spin fa-spin-faster');\n      $('#shared').removeClass('collapse');\n      $('#shared').val(url);\n      Toast.showInfoToast('Shareable link is created.');\n    });\n  });\n\n  // control\n\n  const $btnRun = $('#btn_run');\n  const $btnTrace = $('#btn_trace');\n  const $btnPause = $('#btn_pause');\n  const $btnPrev = $('#btn_prev');\n  const $btnNext = $('#btn_next');\n\n  // initially, control buttons are disabled\n  TopMenu.disableFlowControl();\n\n  $btnRun.click(() => {\n    $btnTrace.click();\n    $btnPause.removeClass('active');\n    $btnRun.addClass('active');\n    TopMenu.enableFlowControl();\n    var err = app.getEditor().execute();\n    if (err) {\n      console.error(err);\n      Toast.showErrorToast(err);\n      TopMenu.resetTopMenuButtons();\n    }\n  });\n\n  $btnPause.click(() => {\n    $btnRun.toggleClass('active');\n    $btnPause.toggleClass('active');\n    if (app.getTracerManager().isPause()) {\n      app.getTracerManager().resumeStep();\n    } else {\n      app.getTracerManager().pauseStep();\n    }\n  });\n\n  $btnPrev.click(() => {\n    $btnRun.removeClass('active');\n    $btnPause.addClass('active');\n    app.getTracerManager().pauseStep();\n    app.getTracerManager().prevStep();\n  });\n\n  $btnNext.click(() => {\n    $btnRun.removeClass('active');\n    $btnPause.addClass('active');\n    app.getTracerManager().pauseStep();\n    app.getTracerManager().nextStep();\n  });\n\n};\n","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = function() {\n  $(window).resize(function() {\n    app.getTracerManager().resize();\n  });\n};\n","'use strict';\n\nconst app = require('../app');\n\nconst {\n  isScratchPaper\n} = require('../utils');\n\nconst showDescription = require('./show_description');\nconst addFiles = require('./add_files');\n\nmodule.exports = (category, algorithm, data, requestedFile) => {\n  let $menu;\n  let category_name;\n  let algorithm_name;\n\n  if (isScratchPaper(category)) {\n    $menu = $('#scratch-paper');\n    category_name = 'Scratch Paper';\n    algorithm_name = algorithm ? 'Shared' : 'Temporary';\n  } else {\n    $menu = $(`[data-category=\"${category}\"][data-algorithm=\"${algorithm}\"]`);\n    const categoryObj = app.getCategory(category);\n    category_name = categoryObj.name;\n    algorithm_name = categoryObj.list[algorithm];\n  }\n\n  $('.sidemenu button').removeClass('active');\n  $menu.addClass('active');\n\n  $('#category').html(category_name);\n  $('#algorithm').html(algorithm_name);\n  $('#tab_desc > .wrapper').empty();\n  $('.files_bar > .wrapper').empty();\n  $('#explanation').html('');\n\n  app.setLastFileUsed(null);\n  app.getEditor().clearContent();\n\n  const {\n    files\n  } = data;\n\n  delete data.files;\n\n  showDescription(data);\n  addFiles(category, algorithm, files, requestedFile);\n};","'use strict';\n\nconst {\n  isArray\n} = Array;\n\nconst {\n  each\n} = $;\n\nmodule.exports = (data) => {\n  const $container = $('#tab_desc > .wrapper');\n  $container.empty();\n\n  each(data, (key, value) => {\n\n    if (key) {\n      $container.append($('<h3>').html(key));\n    }\n\n    if (typeof value === 'string') {\n      $container.append($('<p>').html(value));\n\n    } else if (isArray(value)) {\n\n      const $ul = $('<ul class=\"applications\">');\n      $container.append($ul);\n\n      value.forEach((li) => {\n        $ul.append($('<li>').html(li));\n      });\n\n    } else if (typeof value === 'object') {\n\n      const $ul = $('<ul class=\"complexities\">');\n      $container.append($ul);\n\n      each(value, (prop) => {\n        const $wrapper = $('<div class=\"complexity\">');\n        const $type = $('<span class=\"complexity-type\">').html(`${prop}: `);\n        const $value = $('<span class=\"complexity-value\">').html(`${value[prop]}`);\n\n        $wrapper.append($type).append($value);\n\n        $ul.append($('<li>').append($wrapper));\n      });\n    }\n  });\n};\n","'use strict';\n\n// click the first algorithm in the first category\nmodule.exports = () => {\n  $('#list .category').first().click();\n  $('#list .category + .algorithms > .indent').first().click();\n};\n","'use strict';\n\nconst Server = require('../server');\nconst showAlgorithm = require('./show_algorithm');\n\nmodule.exports = (category, algorithm, file) => {\n  $(`.category[data-category=\"${category}\"]`).click();\n  Server.loadAlgorithm(category, algorithm).then((data) => {\n    showAlgorithm(category, algorithm, data, file);\n  });\n};\n","'use strict';\n\nconst app = require('../app');\nconst Server = require('../server');\nconst converter = new showdown.Converter({tables: true});\n\nmodule.exports = (wiki) => {\n  Server.loadWiki(wiki).then((data) => {\n    $('#tab_doc > .wrapper').html(converter.makeHtml(`#${wiki}\\n${data}`));\n    $('#tab_doc').scrollTop(0);\n    $('#tab_doc > .wrapper a').click(function (e) {\n      const href = $(this).attr('href');\n      if (app.hasWiki(href)) {\n        e.preventDefault();\n        module.exports(href);\n      }\n    });\n  });\n};","'use strict';\n\nconst showToast = (data, type) => {\n  const $toast = $(`<div class=\"toast ${type}\">`).append(data);\n\n  $('.toast_container').append($toast);\n  setTimeout(() => {\n    $toast.fadeOut(() => {\n      $toast.remove();\n    });\n  }, 3000);\n};\n\nconst showErrorToast = (err) => {\n  showToast(err, 'error');\n};\n\nconst showInfoToast = (err) => {\n  showToast(err, 'info');\n};\n\nmodule.exports = {\n  showErrorToast,\n  showInfoToast\n};","'use strict';\n\nconst app = require('../app');\n\nconst flowControlBtns = [ $('#btn_pause'), $('#btn_prev'), $('#btn_next') ];\nconst setFlowControlState = (isDisabled) => {\n  flowControlBtns.forEach($btn => $btn.attr('disabled', isDisabled));\n};\n\nconst enableFlowControl = () => {\n  setFlowControlState(false);\n};\n\nconst disableFlowControl = () => {\n  setFlowControlState(true);\n};\n\nconst resetTopMenuButtons = () => {\n  $('.top-menu-buttons button').removeClass('active');\n  disableFlowControl();\n  app.getEditor().unhighlightLine();\n};\n\nconst setInterval = (val) => {\n  $('#interval').val(interval);\n};\n\nconst activateBtnPause = () => {\n  $('#btn_pause').addClass('active');\n};\n\nconst deactivateBtnPause = () => {\n  $('#btn_pause').removeClass('active');\n};\n\nmodule.exports = {\n  enableFlowControl,\n  disableFlowControl,\n  resetTopMenuButtons,\n  setInterval,\n  activateBtnPause,\n  deactivateBtnPause\n};\n","'use strict';\n\nmodule.exports = function(id) {\n  const editor = ace.edit(id);\n\n  editor.setOptions({\n    enableBasicAutocompletion: true,\n    enableSnippets: true,\n    enableLiveAutocompletion: true\n  });\n\n  editor.setTheme('ace/theme/tomorrow_night_eighties');\n  editor.session.setMode('ace/mode/javascript');\n  editor.$blockScrolling = Infinity;\n\n  return editor;\n};","'use strict';\n\nconst execute = (tracerManager, code, dataLines) => {\n  // all modules available to eval are obtained from window\n  try {\n    tracerManager.deallocateAll();\n    const lines = code.split('\\n');\n    const newLines = [];\n    lines.forEach((line, i) => {\n      newLines.push(line.replace(/(.+\\. *_wait *)(\\( *\\))/g, `$1(${i - dataLines})`));\n    });\n    eval(newLines.join('\\n'));\n    tracerManager.visualize();\n  } catch (err) {\n    return err;\n  } finally {\n    tracerManager.removeUnallocated();\n  }\n};\n\nconst executeData = (tracerManager, algoData) => {\n  return execute(tracerManager, algoData);\n};\n\nconst executeDataAndCode = (tracerManager, algoData, algoCode) => {\n  const dataLines = algoData.split('\\n').length;\n  return execute(tracerManager, `${algoData}\\n${algoCode}`, dataLines);\n};\n\nmodule.exports = {\n  executeData,\n  executeDataAndCode\n};","'use strict';\n\nconst app = require('../app');\nconst createEditor = require('./create');\nconst Executor = require('./executor');\nconst TopMenu = require('../dom/top_menu');\n\nfunction Editor(tracerManager) {\n  if (!tracerManager) {\n    throw 'Cannot create Editor. Missing the tracerManager';\n  }\n\n  ace.require('ace/ext/language_tools');\n  const Range = ace.require(\"ace/range\").Range;\n\n  this.dataEditor = createEditor('data');\n  this.codeEditor = createEditor('code');\n\n  // Setting data\n\n  this.setData = (data) => {\n    this.dataEditor.setValue(data, -1);\n  };\n\n  this.setCode = (code) => {\n    this.codeEditor.setValue(code, -1);\n  };\n\n  this.setContent = (({\n    data,\n    code\n  }) => {\n    this.setData(data);\n    this.setCode(code);\n  });\n\n  // Clearing data\n\n  this.clearData = () => {\n    this.dataEditor.setValue('');\n  };\n\n  this.clearCode = () => {\n    this.codeEditor.setValue('');\n  };\n\n  this.clearContent = () => {\n    this.clearData();\n    this.clearCode();\n  };\n\n  this.execute = () => {\n    const data = this.dataEditor.getValue();\n    const code = this.codeEditor.getValue();\n    return Executor.executeDataAndCode(tracerManager, data, code);\n  };\n\n  this.highlightLine = (lineNumber) => {\n    const session = this.codeEditor.getSession();\n    if (this.marker) session.removeMarker(this.marker);\n    this.marker = session.addMarker(new Range(lineNumber, 0, lineNumber, Infinity), \"executing\", \"line\", true);\n  };\n\n  this.unhighlightLine = () => {\n    const session = this.codeEditor.getSession();\n    if (this.marker) session.removeMarker(this.marker);\n  };\n\n  // listeners\n\n  this.dataEditor.on('change', () => {\n    const data = this.dataEditor.getValue();\n    const lastFileUsed = app.getLastFileUsed();\n    if (lastFileUsed) {\n      app.updateCachedFile(lastFileUsed, {\n        data\n      });\n    }\n    Executor.executeData(tracerManager, data);\n    TopMenu.resetTopMenuButtons();\n  });\n\n  this.codeEditor.on('change', () => {\n    const code = this.codeEditor.getValue();\n    const lastFileUsed = app.getLastFileUsed();\n    if (lastFileUsed) {\n      app.updateCachedFile(lastFileUsed, {\n        code\n      });\n    }\n    tracerManager.reset();\n    TopMenu.resetTopMenuButtons();\n  });\n}\n\nmodule.exports = Editor;","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('./app');\nconst AppConstructor = require('./app/constructor');\nconst DOM = require('./dom');\nconst Server = require('./server');\n\nconst modules = require('./module');\n\nconst {\n  extend\n} = $;\n\n$.ajaxSetup({\n  cache: false,\n  dataType: 'text'\n});\n\nconst {\n  isScratchPaper\n} = require('./utils');\n\nconst {\n  getHashValue,\n  getParameterByName,\n  getPath\n} = require('./server/helpers');\n\n// set global promise error handler\nRSVP.on('error', function (reason) {\n  console.assert(false, reason);\n});\n\n$(() => {\n\n  // initialize the application and attach in to the instance module\n  const appConstructor = new AppConstructor();\n  extend(true, app, appConstructor);\n\n  // load modules to the global scope so they can be evaled\n  extend(true, window, modules);\n\n  Server.loadCategories().then((data) => {\n    app.setCategories(data);\n    DOM.addCategories();\n\n    // determine if the app is loading a pre-existing scratch-pad\n    // or the home page\n    const {\n      category,\n      algorithm,\n      file\n    } = getPath();\n    if (isScratchPaper(category)) {\n      if (algorithm) {\n        Server.loadScratchPaper(algorithm).then(({category, algorithm, data}) => {\n          DOM.showAlgorithm(category, algorithm, data);\n        });\n      } else {\n        Server.loadAlgorithm(category).then((data) => {\n          DOM.showAlgorithm(category, null, data);\n        });\n      }\n    } else if (category && algorithm) {\n      DOM.showRequestedAlgorithm(category, algorithm, file);\n    } else {\n      DOM.showFirstAlgorithm();\n    }\n  });\n\n  Server.loadWikiList().then((data) => {\n    app.setWikiList(data.wikis);\n\n    DOM.showWiki('Tracer');\n  });\n\n  var v1LoadedScratch = getHashValue('scratch-paper');\n  var v2LoadedScratch = getParameterByName('scratch-paper');\n  var vLoadedScratch = v1LoadedScratch || v2LoadedScratch;\n  if (vLoadedScratch) {\n    window.location.href = window.location.protocol + '//' + window.location.host + window.location.pathname + '#path=scratch/' + vLoadedScratch;\n  }\n\n});","'use strict';\n\nconst Array2D = require('./array2d');\n\nconst random = (N, min, max) => {\n  return Array2D.random(1, N, min, max)[0];\n};\n\nconst randomSorted = (N, min, max)=> {\n  return Array2D.randomSorted(1, N, min, max)[0];\n};\n\nmodule.exports = {\n  random,\n  randomSorted\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, M, min, max) => {\n  if (!N) N = 10;\n  if (!M) M = 10;\n  if (min === undefined) min = 1;\n  if (max === undefined) max = 9;\n  var D = [];\n  for (var i = 0; i < N; i++) {\n    D.push([]);\n    for (var j = 0; j < M; j++) {\n      D[i].push(Integer.random(min, max));\n    }\n  }\n  return D;\n};\n\nconst randomSorted = (N, M, min, max) => {\n  return random(N, M, min, max).map(function (arr) {\n    return arr.sort(function (a, b) {\n      return a - b;\n    });\n  });\n};\n\nmodule.exports = {\n  random,\n  randomSorted\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, min, max) => {\n  if (!N) N = 7;\n  if (!min) min = 1;\n  if (!max) max = 10;\n  var C = new Array(N);\n  for (var i = 0; i < N; i++) C[i] = new Array(2);\n  for (var i = 0; i < N; i++)\n    for (var j = 0; j < C[i].length; j++)\n      C[i][j] = Integer.random(min, max);\n  return C;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst random = (N, ratio) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) {\n    G[i] = new Array(N);\n    for (var j = 0; j < N; j++) {\n      if (i != j) {\n        G[i][j] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\nconst Array1D = require('./array1d');\nconst Array2D = require('./array2d');\nconst CoordinateSystem = require('./coordinate_system');\nconst DirectedGraph = require('./directed_graph');\nconst UndirectedGraph = require('./undirected_graph');\nconst WeightedDirectedGraph = require('./weighted_directed_graph');\nconst WeightedUndirectedGraph = require('./weighted_undirected_graph');\n\nmodule.exports = {\n  Integer,\n  Array1D,\n  Array2D,\n  CoordinateSystem,\n  DirectedGraph,\n  UndirectedGraph,\n  WeightedDirectedGraph,\n  WeightedUndirectedGraph\n};","'use strict';\n\nconst random = (min, max) => {\n  return (Math.random() * (max - min + 1) | 0) + min;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst random = (N, ratio) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) G[i] = new Array(N);\n  for (var i = 0; i < N; i++) {\n    for (var j = 0; j < N; j++) {\n      if (i > j) {\n        G[i][j] = G[j][i] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, ratio, min, max) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  if (!min) min = 1;\n  if (!max) max = 5;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) {\n    G[i] = new Array(N);\n    for (var j = 0; j < N; j++) {\n      if (i != j && (Math.random() * (1 / ratio) | 0) == 0) {\n        G[i][j] = Integer.random(min, max);\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, ratio, min, max) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  if (!min) min = 1;\n  if (!max) max = 5;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) G[i] = new Array(N);\n  for (var i = 0; i < N; i++) {\n    for (var j = 0; j < N; j++) {\n      if (i > j && (Math.random() * (1 / ratio) | 0) == 0) {\n        G[i][j] = G[j][i] = Integer.random(min, max);\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nvar tracers = require('./tracer');\nvar datas = require('./data');\n\nconst {\n  extend\n} = $;\n\nmodule.exports = extend(true, {}, tracers, datas);","'use strict';\n\nconst Array2DTracer = require('./array2d');\n\nclass Array1DTracer extends Array2DTracer {\n  static getClassName() {\n    return 'Array1DTracer';\n  }\n\n  constructor(name) {\n    super(name);\n  }\n\n  _notify(idx, v) {\n    super._notify(0, idx, v);\n    return this;\n  }\n\n  _denotify(idx) {\n    super._denotify(0, idx);\n    return this;\n  }\n\n  _select(s, e) {\n    if (e === undefined) {\n      super._select(0, s);\n    } else {\n      super._selectRow(0, s, e);\n    }\n    return this;\n  }\n\n  _deselect(s, e) {\n    if (e === undefined) {\n      super._deselect(0, s);\n    } else {\n      super._deselectRow(0, s, e);\n    }\n    return this;\n  }\n\n  processStep(step, options) {\n    super.processStep(step, options);\n    if (this.chartTracer) {\n      const newStep = $.extend(true, {}, step);\n      newStep.capsule = this.chartTracer.capsule;\n      newStep.s = newStep.sy;\n      newStep.e = newStep.ey;\n      if (newStep.s === undefined) newStep.s = newStep.y;\n      delete newStep.x;\n      delete newStep.y;\n      delete newStep.sx;\n      delete newStep.sy;\n      delete newStep.ex;\n      delete newStep.ey;\n      this.chartTracer.processStep(newStep, options);\n    }\n  }\n\n  setData(D) {\n    return super.setData([D]);\n  }\n}\n\nmodule.exports = Array1DTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass Array2DTracer extends Tracer {\n  static getClassName() {\n    return 'Array2DTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.colorClass = {\n      selected: 'selected',\n      notified: 'notified'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  _notify(x, y, v) {\n    this.manager.pushStep(this.capsule, {\n      type: 'notify',\n      x: x,\n      y: y,\n      v: v\n    });\n    return this;\n  }\n\n  _denotify(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'denotify',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _select(sx, sy, ex, ey) {\n    this.pushSelectingStep('select', null, arguments);\n    return this;\n  }\n\n  _selectRow(x, sy, ey) {\n    this.pushSelectingStep('select', 'row', arguments);\n    return this;\n  }\n\n  _selectCol(y, sx, ex) {\n    this.pushSelectingStep('select', 'col', arguments);\n    return this;\n  }\n\n  _deselect(sx, sy, ex, ey) {\n    this.pushSelectingStep('deselect', null, arguments);\n    return this;\n  }\n\n  _deselectRow(x, sy, ey) {\n    this.pushSelectingStep('deselect', 'row', arguments);\n    return this;\n  }\n\n  _deselectCol(y, sx, ex) {\n    this.pushSelectingStep('deselect', 'col', arguments);\n    return this;\n  }\n\n  _separate(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'separate',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _separateRow(x) {\n    this._separate(x, -1);\n    return this;\n  }\n\n  _separateCol(y) {\n    this._separate(-1, y);\n    return this;\n  }\n\n  _deseparate(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'deseparate',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _deseparateRow(x) {\n    this._deseparate(x, -1);\n    return this;\n  }\n\n  _deseparateCol(y) {\n    this._deseparate(-1, y);\n    return this;\n  }\n\n  pushSelectingStep() {\n    var args = Array.prototype.slice.call(arguments);\n    var type = args.shift();\n    var mode = args.shift();\n    args = Array.prototype.slice.call(args.shift());\n    var coord;\n    switch (mode) {\n      case 'row':\n        coord = {\n          x: args[0],\n          sy: args[1],\n          ey: args[2]\n        };\n        break;\n      case 'col':\n        coord = {\n          y: args[0],\n          sx: args[1],\n          ex: args[2]\n        };\n        break;\n      default:\n        if (args[2] === undefined && args[3] === undefined) {\n          coord = {\n            x: args[0],\n            y: args[1]\n          };\n        } else {\n          coord = {\n            sx: args[0],\n            sy: args[1],\n            ex: args[2],\n            ey: args[3]\n          };\n        }\n    }\n    var step = {\n      type: type\n    };\n    $.extend(step, coord);\n    this.manager.pushStep(this.capsule, step);\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'notify':\n        if (step.v !== undefined) {\n          var $row = this.$table.find('.mtbl-row').eq(step.x);\n          var $col = $row.find('.mtbl-col').eq(step.y);\n          $col.text(refineByType(step.v));\n        }\n      case 'denotify':\n      case 'select':\n      case 'deselect':\n        var colorClass = step.type == 'select' || step.type == 'deselect' ? this.colorClass.selected : this.colorClass.notified;\n        var addClass = step.type == 'select' || step.type == 'notify';\n        var sx = step.sx;\n        var sy = step.sy;\n        var ex = step.ex;\n        var ey = step.ey;\n        if (sx === undefined) sx = step.x;\n        if (sy === undefined) sy = step.y;\n        if (ex === undefined) ex = step.x;\n        if (ey === undefined) ey = step.y;\n        this.paintColor(sx, sy, ex, ey, colorClass, addClass);\n        break;\n      case 'separate':\n        this.deseparate(step.x, step.y);\n        this.separate(step.x, step.y);\n        break;\n      case 'deseparate':\n        this.deseparate(step.x, step.y);\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  setData(D) {\n    this.viewX = this.viewY = 0;\n    this.paddingH = 6;\n    this.paddingV = 3;\n    this.fontSize = 16;\n\n    if (super.setData.apply(this, arguments)) {\n      this.$table.find('.mtbl-row').each(function (i) {\n        $(this).find('.mtbl-col').each(function (j) {\n          $(this).text(refineByType(D[i][j]));\n        });\n      });\n      return true;\n    }\n\n    this.$table.empty();\n    for (var i = 0; i < D.length; i++) {\n      var $row = $('<div class=\"mtbl-row\">');\n      this.$table.append($row);\n      for (var j = 0; j < D[i].length; j++) {\n        var $col = $('<div class=\"mtbl-col\">')\n          .css(this.getCellCss())\n          .text(refineByType(D[i][j]));\n        $row.append($col);\n      }\n    }\n    this.resize();\n\n    return false;\n  }\n\n  resize() {\n    super.resize();\n\n    this.refresh();\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearColor();\n    this.deseparateAll();\n  }\n\n  getCellCss() {\n    return {\n      padding: this.paddingV.toFixed(1) + 'px ' + this.paddingH.toFixed(1) + 'px',\n      'font-size': this.fontSize.toFixed(1) + 'px'\n    };\n  }\n\n  refresh() {\n    super.refresh();\n\n    var $parent = this.$table.parent();\n    var top = $parent.height() / 2 - this.$table.height() / 2 + this.viewY;\n    var left = $parent.width() / 2 - this.$table.width() / 2 + this.viewX;\n    this.$table.css('margin-top', top);\n    this.$table.css('margin-left', left);\n  }\n\n  mousedown(e) {\n    super.mousedown(e);\n\n    this.dragX = e.pageX;\n    this.dragY = e.pageY;\n    this.dragging = true;\n  }\n\n  mousemove(e) {\n    super.mousemove(e);\n\n    if (this.dragging) {\n      this.viewX += e.pageX - this.dragX;\n      this.viewY += e.pageY - this.dragY;\n      this.dragX = e.pageX;\n      this.dragY = e.pageY;\n      this.refresh();\n    }\n  }\n\n  mouseup(e) {\n    super.mouseup(e);\n\n    this.dragging = false;\n  }\n\n  mousewheel(e) {\n    super.mousewheel(e);\n\n    e.preventDefault();\n    e = e.originalEvent;\n    var delta = (e.wheelDelta !== undefined && e.wheelDelta) ||\n      (e.detail !== undefined && -e.detail);\n    var weight = 1.01;\n    var ratio = delta > 0 ? 1 / weight : weight;\n    if (this.fontSize < 4 && ratio < 1) return;\n    if (this.fontSize > 40 && ratio > 1) return;\n    this.paddingV *= ratio;\n    this.paddingH *= ratio;\n    this.fontSize *= ratio;\n    this.$table.find('.mtbl-col').css(this.getCellCss());\n    this.refresh();\n  }\n\n  paintColor(sx, sy, ex, ey, colorClass, addClass) {\n    for (var i = sx; i <= ex; i++) {\n      var $row = this.$table.find('.mtbl-row').eq(i);\n      for (var j = sy; j <= ey; j++) {\n        var $col = $row.find('.mtbl-col').eq(j);\n        if (addClass) $col.addClass(colorClass);\n        else $col.removeClass(colorClass);\n      }\n    }\n  }\n\n  clearColor() {\n    this.$table.find('.mtbl-col').removeClass(Object.keys(this.colorClass).join(' '));\n  }\n\n  separate(x, y) {\n    this.$table.find('.mtbl-row').each(function (i) {\n      var $row = $(this);\n      if (i == x) {\n        $row.after($('<div class=\"mtbl-empty-row\">').attr('data-row', i))\n      }\n      $row.find('.mtbl-col').each(function (j) {\n        var $col = $(this);\n        if (j == y) {\n          $col.after($('<div class=\"mtbl-empty-col\">').attr('data-col', j));\n        }\n      });\n    });\n  }\n\n  deseparate(x, y) {\n    this.$table.find('[data-row=' + x + ']').remove();\n    this.$table.find('[data-col=' + y + ']').remove();\n  }\n\n  deseparateAll() {\n    this.$table.find('.mtbl-empty-row, .mtbl-empty-col').remove();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$table = tracer.capsule.$table = $('<div class=\"mtbl-table\">');\n  tracer.$container.append(tracer.$table);\n};\n\nmodule.exports = Array2DTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nclass ChartTracer extends Tracer {\n  static getClassName() {\n    return 'ChartTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.color = {\n      selected: 'rgb(0, 0, 255)',\n      notified: 'rgb(255, 0, 0)',\n      default: 'rgb(136, 136, 136)'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (super.setData.apply(this, arguments)) {\n      this.chart.config.data.datasets[0].data = C;\n      this.chart.update();\n      return true;\n    }\n\n    var color = [];\n    for (var i = 0; i < C.length; i++) color.push(this.color.default);\n    this.chart.config.data = {\n      labels: C.map(String),\n      datasets: [{\n        backgroundColor: color,\n        data: C\n      }]\n    };\n    this.chart.update();\n  }\n\n  _notify(s, v) {\n    this.manager.pushStep(this.capsule, {\n      type: 'notify',\n      s: s,\n      v: v\n    });\n    return this;\n  }\n\n  _denotify(s) {\n    this.manager.pushStep(this.capsule, {\n      type: 'denotify',\n      s: s\n    });\n    return this;\n  }\n\n  _select(s, e) {\n    this.manager.pushStep(this.capsule, {\n      type: 'select',\n      s: s,\n      e: e\n    });\n    return this;\n  }\n\n  _deselect(s, e) {\n    this.manager.pushStep(this.capsule, {\n      type: 'deselect',\n      s: s,\n      e: e\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'notify':\n        if (step.v !== undefined) {\n          this.chart.config.data.datasets[0].data[step.s] = step.v;\n          this.chart.config.data.labels[step.s] = step.v.toString();\n        }\n      case 'denotify':\n      case 'select':\n      case 'deselect':\n        let color = step.type == 'notify' ? this.color.notified : step.type == 'select' ? this.color.selected : this.color.default;\n        if (step.e !== undefined)\n          for (var i = step.s; i <= step.e; i++)\n            this.chart.config.data.datasets[0].backgroundColor[i] = color;\n        else\n          this.chart.config.data.datasets[0].backgroundColor[step.s] = color;\n        this.chart.update();\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  resize() {\n    super.resize();\n\n    this.chart.resize();\n  }\n\n  clear() {\n    super.clear();\n\n    const data = this.chart.config.data;\n    if (data.datasets.length) {\n      const backgroundColor = data.datasets[0].backgroundColor;\n      for (let i = 0; i < backgroundColor.length; i++) {\n        backgroundColor[i] = this.color.default;\n      }\n      this.chart.update();\n    }\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$wrapper = tracer.capsule.$wrapper = $('<canvas class=\"mchrt-chart\">');\n  tracer.$container.append(tracer.$wrapper);\n  tracer.chart = tracer.capsule.chart = new Chart(tracer.$wrapper, {\n    type: 'bar',\n    data: {\n      labels: [],\n      datasets: []\n    },\n    options: {\n      scales: {\n        yAxes: [{\n          ticks: {\n            beginAtZero: true\n          }\n        }]\n      },\n      animation: false,\n      legend: false,\n      responsive: true,\n      maintainAspectRatio: false\n    }\n  });\n};\n\nmodule.exports = ChartTracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nclass CoordinateSystemTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'CoordinateSystemTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (Tracer.prototype.setData.apply(this, arguments)) return true;\n\n    this.graph.clear();\n    var nodes = [];\n    var edges = [];\n    for (var i = 0; i < C.length; i++)\n      nodes.push({\n        id: this.n(i),\n        x: C[i][0],\n        y: C[i][1],\n        label: '' + i,\n        size: 1,\n        color: this.color.default\n      });\n    this.graph.read({\n      nodes: nodes,\n      edges: edges\n    });\n    this.s.camera.goTo({\n      x: 0,\n      y: 0,\n      angle: 0,\n      ratio: 1\n    });\n    this.refresh();\n\n    return false;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          if (this.graph.edges(edgeId)) {\n            var edge = this.graph.edges(edgeId);\n            edge.color = color;\n            this.graph.dropEdge(edgeId).addEdge(edge);\n          } else {\n            this.graph.addEdge({\n              id: this.e(step.target, step.source),\n              source: this.n(step.source),\n              target: this.n(step.target),\n              color: color,\n              size: 1\n            });\n          }\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  e(v1, v2) {\n    if (v1 > v2) {\n      var temp = v1;\n      v1 = v2;\n      v2 = temp;\n    }\n    return 'e' + v1 + '_' + v2;\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#0ff';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n\n  drawEdge(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(\n      source[prefix + 'x'],\n      source[prefix + 'y']\n    );\n    context.lineTo(\n      target[prefix + 'x'],\n      target[prefix + 'y']\n    );\n    context.stroke();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = CoordinateSystemTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass DirectedGraphTracer extends Tracer {\n  static getClassName() {\n    return 'DirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.color = {\n      selected: '#0f0',\n      visited: '#f00',\n      left: '#000',\n      default: '#888'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  _setTreeData(G, root) {\n    this.manager.pushStep(this.capsule, {\n      type: 'setTreeData',\n      arguments: arguments\n    });\n    return this;\n  }\n\n  _visit(target, source) {\n    this.manager.pushStep(this.capsule, {\n      type: 'visit',\n      target: target,\n      source: source\n    });\n    return this;\n  }\n\n  _leave(target, source) {\n    this.manager.pushStep(this.capsule, {\n      type: 'leave',\n      target: target,\n      source: source\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'setTreeData':\n        this.setTreeData.apply(this, step.arguments);\n        break;\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          var edge = this.graph.edges(edgeId);\n          edge.color = color;\n          this.graph.dropEdge(edgeId).addEdge(edge);\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  setTreeData(G, root, undirected) {\n    var tracer = this;\n\n    root = root || 0;\n    var maxDepth = -1;\n\n    var chk = new Array(G.length);\n    var getDepth = function (node, depth) {\n      if (chk[node]) throw \"the given graph is not a tree because it forms a circuit\";\n      chk[node] = true;\n      if (maxDepth < depth) maxDepth = depth;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) getDepth(i, depth + 1);\n      }\n    };\n    getDepth(root, 1);\n\n    if (this.setData(G, undirected)) return true;\n\n    var place = function (node, x, y) {\n      var temp = tracer.graph.nodes(tracer.n(node));\n      temp.x = x;\n      temp.y = y;\n    };\n\n    var wgap = 1 / (maxDepth - 1);\n    var dfs = function (node, depth, top, bottom) {\n      place(node, top + bottom, depth * wgap);\n      var children = 0;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) children++;\n      }\n      var vgap = (bottom - top) / children;\n      var cnt = 0;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) dfs(i, depth + 1, top + vgap * cnt, top + vgap * ++cnt);\n      }\n    };\n    dfs(root, 0, 0, 1);\n\n    this.refresh();\n  }\n\n  setData(G, undirected) {\n    if (super.setData.apply(this, arguments)) return true;\n\n    this.graph.clear();\n    const nodes = [];\n    const edges = [];\n    const unitAngle = 2 * Math.PI / G.length;\n    let currentAngle = 0;\n    for (let i = 0; i < G.length; i++) {\n      currentAngle += unitAngle;\n      nodes.push({\n        id: this.n(i),\n        label: '' + i,\n        x: .5 + Math.sin(currentAngle) / 2,\n        y: .5 + Math.cos(currentAngle) / 2,\n        size: 1,\n        color: this.color.default,\n        weight: 0\n      });\n\n      if (undirected) {\n        for (let j = 0; j <= i; j++) {\n          const value = G[i][j] || G[j][i];\n          if (value) {\n            edges.push({\n              id: this.e(i, j),\n              source: this.n(i),\n              target: this.n(j),\n              color: this.color.default,\n              size: 1,\n              weight: refineByType(value)\n            });\n          }\n        }\n      } else {\n        for (let j = 0; j < G[i].length; j++) {\n          if (G[i][j]) {\n            edges.push({\n              id: this.e(i, j),\n              source: this.n(i),\n              target: this.n(j),\n              color: this.color.default,\n              size: 1,\n              weight: refineByType(G[i][j])\n            });\n          }\n        }\n      }\n    }\n\n    this.graph.read({\n      nodes: nodes,\n      edges: edges\n    });\n    this.s.camera.goTo({\n      x: 0,\n      y: 0,\n      angle: 0,\n      ratio: 1\n    });\n    this.refresh();\n\n    return false;\n  }\n\n  resize() {\n    super.resize();\n\n    this.s.renderers[0].resize();\n    this.refresh();\n  }\n\n  refresh() {\n    super.refresh();\n\n    this.s.refresh();\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearGraphColor();\n    this.refresh();\n  }\n\n  clearGraphColor() {\n    var tracer = this;\n\n    this.graph.nodes().forEach(function (node) {\n      node.color = tracer.color.default;\n    });\n    this.graph.edges().forEach(function (edge) {\n      edge.color = tracer.color.default;\n    });\n  }\n\n  n(v) {\n    return 'n' + v;\n  }\n\n  e(v1, v2) {\n    return 'e' + v1 + '_' + v2;\n  }\n\n  getColor(edge, source, target, settings) {\n    var color = edge.color,\n      edgeColor = settings('edgeColor'),\n      defaultNodeColor = settings('defaultNodeColor'),\n      defaultEdgeColor = settings('defaultEdgeColor');\n    if (!color)\n      switch (edgeColor) {\n        case 'source':\n          color = source.color || defaultNodeColor;\n          break;\n        case 'target':\n          color = target.color || defaultNodeColor;\n          break;\n        default:\n          color = defaultEdgeColor;\n          break;\n      }\n\n    return color;\n  }\n\n  drawLabel(node, context, settings) {\n    var fontSize,\n      prefix = settings('prefix') || '',\n      size = node[prefix + 'size'];\n\n    if (size < settings('labelThreshold'))\n      return;\n\n    if (!node.label || typeof node.label !== 'string')\n      return;\n\n    fontSize = (settings('labelSize') === 'fixed') ?\n      settings('defaultLabelSize') :\n    settings('labelSizeRatio') * size;\n\n    context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') +\n      fontSize + 'px ' + settings('font');\n    context.fillStyle = (settings('labelColor') === 'node') ?\n      (node.color || settings('defaultNodeColor')) :\n      settings('defaultLabelColor');\n\n    context.textAlign = 'center';\n    context.fillText(\n      node.label,\n      Math.round(node[prefix + 'x']),\n      Math.round(node[prefix + 'y'] + fontSize / 3)\n    );\n  }\n\n  drawArrow(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1,\n      tSize = target[prefix + 'size'],\n      sX = source[prefix + 'x'],\n      sY = source[prefix + 'y'],\n      tX = target[prefix + 'x'],\n      tY = target[prefix + 'y'],\n      angle = Math.atan2(tY - sY, tX - sX),\n      dist = 3;\n    sX += Math.sin(angle) * dist;\n    tX += Math.sin(angle) * dist;\n    sY += -Math.cos(angle) * dist;\n    tY += -Math.cos(angle) * dist;\n    var aSize = Math.max(size * 2.5, settings('minArrowSize')),\n      d = Math.sqrt(Math.pow(tX - sX, 2) + Math.pow(tY - sY, 2)),\n      aX = sX + (tX - sX) * (d - aSize - tSize) / d,\n      aY = sY + (tY - sY) * (d - aSize - tSize) / d,\n      vX = (tX - sX) * aSize / d,\n      vY = (tY - sY) * aSize / d;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(sX, sY);\n    context.lineTo(\n      aX,\n      aY\n    );\n    context.stroke();\n\n    context.fillStyle = color;\n    context.beginPath();\n    context.moveTo(aX + vX, aY + vY);\n    context.lineTo(aX + vY * 0.6, aY - vX * 0.6);\n    context.lineTo(aX - vY * 0.6, aY + vX * 0.6);\n    context.lineTo(aX + vX, aY + vY);\n    context.closePath();\n    context.fill();\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawArrow(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#ff0';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawArrow(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s = tracer.capsule.s = new sigma({\n    renderer: {\n      container: tracer.$container[0],\n      type: 'canvas'\n    },\n    settings: {\n      minArrowSize: 8,\n      defaultEdgeType: 'arrow',\n      maxEdgeSize: 2.5,\n      labelThreshold: 4,\n      font: 'Roboto',\n      defaultLabelColor: '#fff',\n      zoomMin: 0.6,\n      zoomMax: 1.2,\n      skipErrors: true,\n      minNodeSize: .5,\n      maxNodeSize: 12,\n      labelSize: 'proportional',\n      labelSizeRatio: 1.3,\n      funcLabelsDef(node, context, settings) {\n        tracer.drawLabel(node, context, settings);\n      },\n      funcHoversDef(node, context, settings, next) {\n        tracer.drawOnHover(node, context, settings, next);\n      },\n      funcEdgesArrow(edge, source, target, context, settings) {\n        var color = tracer.getColor(edge, source, target, settings);\n        tracer.drawArrow(edge, source, target, color, context, settings);\n      }\n    }\n  });\n  sigma.plugins.dragNodes(tracer.s, tracer.s.renderers[0]);\n  tracer.graph = tracer.capsule.graph = tracer.s.graph;\n};\n\nsigma.canvas.labels.def = function (node, context, settings) {\n  var func = settings('funcLabelsDef');\n  if (func) {\n    func(node, context, settings);\n  }\n};\nsigma.canvas.hovers.def = function (node, context, settings) {\n  var func = settings('funcHoversDef');\n  if (func) {\n    func(node, context, settings);\n  }\n};\nsigma.canvas.edges.def = function (edge, source, target, context, settings) {\n  var func = settings('funcEdgesDef');\n  if (func) {\n    func(edge, source, target, context, settings);\n  }\n};\nsigma.canvas.edges.arrow = function (edge, source, target, context, settings) {\n  var func = settings('funcEdgesArrow');\n  if (func) {\n    func(edge, source, target, context, settings);\n  }\n};\n\nmodule.exports = DirectedGraphTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\nconst LogTracer = require('./log');\nconst Array1DTracer = require('./array1d');\nconst Array2DTracer = require('./array2d');\nconst ChartTracer = require('./chart');\nconst CoordinateSystemTracer = require('./coordinate_system');\nconst DirectedGraphTracer = require('./directed_graph');\nconst UndirectedGraphTracer = require('./undirected_graph');\nconst WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nconst WeightedUndirectedGraphTracer = require('./weighted_undirected_graph');\n\nmodule.exports = {\n  Tracer,\n  LogTracer,\n  Array1DTracer,\n  Array2DTracer,\n  ChartTracer,\n  CoordinateSystemTracer,\n  DirectedGraphTracer,\n  UndirectedGraphTracer,\n  WeightedDirectedGraphTracer,\n  WeightedUndirectedGraphTracer\n};","'use strict';\n\nconst Tracer = require('./tracer');\n\nclass LogTracer extends Tracer {\n  static getClassName() {\n    return 'LogTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  _print(msg) {\n    this.manager.pushStep(this.capsule, {\n      type: 'print',\n      msg: msg\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'print':\n        this.print(step.msg);\n        break;\n    }\n  }\n\n  refresh() {\n    this.scrollToEnd(Math.min(50, this.interval));\n  }\n\n  clear() {\n    super.clear();\n\n    this.$wrapper.empty();\n  }\n\n  print(message) {\n    this.$wrapper.append($('<span>').append(message + '<br/>'));\n  }\n\n  scrollToEnd(duration) {\n    this.$container.animate({\n      scrollTop: this.$container[0].scrollHeight\n    }, duration);\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$wrapper = tracer.capsule.$wrapper = $('<div class=\"wrapper\">');\n  tracer.$container.append(tracer.$wrapper);\n};\n\nmodule.exports = LogTracer;\n","'use strict';\n\nconst app = require('../../app');\n\nconst {\n  toJSON,\n  fromJSON\n} = require('../../tracer_manager/util/index');\n\nclass Tracer {\n  static getClassName() {\n    return 'Tracer';\n  }\n\n  constructor(name) {\n    this.module = this.constructor;\n\n    this.manager = app.getTracerManager();\n    this.capsule = this.manager.allocate(this);\n    $.extend(this, this.capsule);\n\n    this.setName(name);\n  }\n\n  _setData(...args) {\n    this.manager.pushStep(this.capsule, {\n      type: 'setData',\n      args: toJSON(args)\n    });\n    return this;\n  }\n\n  _clear() {\n    this.manager.pushStep(this.capsule, {\n      type: 'clear'\n    });\n    return this;\n  }\n\n  _wait(line) {\n    this.manager.newStep(line);\n    return this;\n  }\n\n  processStep(step, options) {\n    const {\n      type,\n      args\n    } = step;\n\n    switch (type) {\n      case 'setData':\n        this.setData(...fromJSON(args));\n        break;\n      case 'clear':\n        this.clear();\n        break;\n    }\n  }\n\n  setName(name) {\n    let $name;\n    if (this.isNew) {\n      $name = $('<span class=\"name\">');\n      this.$container.append($name);\n    } else {\n      $name = this.$container.find('span.name');\n    }\n    $name.text(name || this.defaultName);\n  }\n\n  setData() {\n    const data = toJSON(arguments);\n    if (!this.isNew && this.lastData === data) {\n      return true;\n    }\n    this.lastData = this.capsule.lastData = data;\n    return false;\n  }\n\n  resize() {\n  }\n\n  refresh() {\n  }\n\n  clear() {\n  }\n\n  attach(tracer) {\n    switch (tracer.module) {\n      case LogTracer:\n        this.logTracer = tracer;\n        break;\n      case ChartTracer:\n        this.chartTracer = tracer;\n        break;\n    }\n    return this;\n  }\n\n  mousedown(e) {\n  }\n\n  mousemove(e) {\n  }\n\n  mouseup(e) {\n  }\n\n  mousewheel(e) {\n  }\n}\n\nmodule.exports = Tracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nclass UndirectedGraphTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'UndirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  setTreeData(G, root) {\n    return super.setTreeData(G, root, true);\n  }\n\n  setData(G) {\n    return super.setData(G, true);\n  }\n\n  e(v1, v2) {\n    if (v1 > v2) {\n      var temp = v1;\n      v1 = v2;\n      v2 = temp;\n    }\n    return 'e' + v1 + '_' + v2;\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#0ff';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n\n  drawEdge(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(\n      source[prefix + 'x'],\n      source[prefix + 'y']\n    );\n    context.lineTo(\n      target[prefix + 'x'],\n      target[prefix + 'y']\n    );\n    context.stroke();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = UndirectedGraphTracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass WeightedDirectedGraphTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'WeightedDirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  _weight(target, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'weight',\n      target: target,\n      weight: weight\n    });\n    return this;\n  }\n\n  _visit(target, source, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'visit',\n      target: target,\n      source: source,\n      weight: weight\n    });\n    return this;\n  }\n\n  _leave(target, source, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'leave',\n      target: target,\n      source: source,\n      weight: weight\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'weight':\n        var targetNode = this.graph.nodes(this.n(step.target));\n        if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n        break;\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? step.weight === undefined ? this.color.selected : this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          var edge = this.graph.edges(edgeId);\n          edge.color = color;\n          this.graph.dropEdge(edgeId).addEdge(edge);\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearWeights();\n  }\n\n  clearWeights() {\n    this.graph.nodes().forEach(function (node) {\n      node.weight = 0;\n    });\n  }\n\n  drawEdgeWeight(edge, source, target, color, context, settings) {\n    if (source == target)\n      return;\n\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    if (size < settings('edgeLabelThreshold'))\n      return;\n\n    if (0 === settings('edgeLabelSizePowRatio'))\n      throw '\"edgeLabelSizePowRatio\" must not be 0.';\n\n    var fontSize,\n      x = (source[prefix + 'x'] + target[prefix + 'x']) / 2,\n      y = (source[prefix + 'y'] + target[prefix + 'y']) / 2,\n      dX = target[prefix + 'x'] - source[prefix + 'x'],\n      dY = target[prefix + 'y'] - source[prefix + 'y'],\n      angle = Math.atan2(dY, dX);\n\n    fontSize = (settings('edgeLabelSize') === 'fixed') ?\n      settings('defaultEdgeLabelSize') :\n    settings('defaultEdgeLabelSize') *\n    size *\n    Math.pow(size, -1 / settings('edgeLabelSizePowRatio'));\n\n    context.save();\n\n    if (edge.active) {\n      context.font = [\n        settings('activeFontStyle'),\n        fontSize + 'px',\n        settings('activeFont') || settings('font')\n      ].join(' ');\n\n      context.fillStyle = color;\n    } else {\n      context.font = [\n        settings('fontStyle'),\n        fontSize + 'px',\n        settings('font')\n      ].join(' ');\n\n      context.fillStyle = color;\n    }\n\n    context.textAlign = 'center';\n    context.textBaseline = 'alphabetic';\n\n    context.translate(x, y);\n    context.rotate(angle);\n    context.fillText(\n      edge.weight,\n      0,\n      (-size / 2) - 3\n    );\n\n    context.restore();\n  }\n\n  drawNodeWeight(node, context, settings) {\n    var fontSize,\n      prefix = settings('prefix') || '',\n      size = node[prefix + 'size'];\n\n    if (size < settings('labelThreshold'))\n      return;\n\n    fontSize = (settings('labelSize') === 'fixed') ?\n      settings('defaultLabelSize') :\n    settings('labelSizeRatio') * size;\n\n    context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') +\n      fontSize + 'px ' + settings('font');\n    context.fillStyle = (settings('labelColor') === 'node') ?\n      (node.color || settings('defaultNodeColor')) :\n      settings('defaultLabelColor');\n\n    context.textAlign = 'left';\n    context.fillText(\n      node.weight,\n      Math.round(node[prefix + 'x'] + size * 1.5),\n      Math.round(node[prefix + 'y'] + fontSize / 3)\n    );\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    edgeLabelSize: 'proportional',\n    defaultEdgeLabelSize: 20,\n    edgeLabelSizePowRatio: 0.8,\n    funcLabelsDef(node, context, settings) {\n      tracer.drawNodeWeight(node, context, settings);\n      tracer.drawLabel(node, context, settings);\n    },\n    funcHoversDef(node, context, settings) {\n      tracer.drawOnHover(node, context, settings, tracer.drawEdgeWeight);\n    },\n    funcEdgesArrow(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawArrow(edge, source, target, color, context, settings);\n      tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = WeightedDirectedGraphTracer;\n","'use strict';\n\nconst WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nconst UndirectedGraphTracer = require('./undirected_graph');\n\nclass WeightedUndirectedGraphTracer extends WeightedDirectedGraphTracer {\n  static getClassName() {\n    return 'WeightedUndirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.e = UndirectedGraphTracer.prototype.e;\n    this.drawOnHover = UndirectedGraphTracer.prototype.drawOnHover;\n    this.drawEdge = UndirectedGraphTracer.prototype.drawEdge;\n\n    if (this.isNew) initView(this);\n  }\n\n  setTreeData(G, root) {\n    return super.setTreeData(G, root, true);\n  }\n\n  setData(G) {\n    return super.setData(G, true);\n  }\n\n  drawEdgeWeight(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '';\n    if (source[prefix + 'x'] > target[prefix + 'x']) {\n      var temp = source;\n      source = target;\n      target = temp;\n    }\n    WeightedDirectedGraphTracer.prototype.drawEdgeWeight.call(this, edge, source, target, color, context, settings);\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n      tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = WeightedUndirectedGraphTracer;\n","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = (url) => {\n  return request(url, {\n    type: 'GET'\n  });\n};","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = function(url) {\n  return request(url, {\n    dataType: 'json',\n    type: 'GET'\n  });\n};","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = function(url, data) {\n  return request(url, {\n    dataType: 'json',\n    type: 'POST',\n    data: JSON.stringify(data),\n  });\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../../app');\n\nconst {\n  ajax,\n  extend\n} = $;\n\nconst defaults = {\n\n};\n\nmodule.exports = function(url, options = {}) {\n  app.setIsLoading(true);\n\n  return new RSVP.Promise((resolve, reject) => {\n    const callbacks = {\n      success(response) {\n        app.setIsLoading(false);\n        resolve(response);\n      },\n      error(reason) {\n        app.setIsLoading(false);\n        reject(reason);\n      }\n    };\n\n    const opts = extend({}, defaults, options, callbacks, {\n      url\n    });\n\n    ajax(opts);\n  });\n};","'use strict';\n\nconst app = require('../app');\nconst Toast = require('../dom/toast');\n\nconst checkLoading = () => {\n  if (app.getIsLoading()) {\n    Toast.showErrorToast('Wait until it completes loading of previous file.');\n    return true;\n  }\n  return false;\n};\n\nconst getParameterByName = (name) => {\n  const url = window.location.href;\n  const regex = new RegExp(`[?&]${name}(=([^&#]*)|&|#|$)`);\n\n  const results = regex.exec(url);\n\n  if (!results || results.length !== 3) {\n    return null;\n  }\n\n  const [, , id] = results;\n\n  return id;\n};\n\nconst getHashValue = (key)=> {\n  if (!key) return null;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n  for (let i = 0; i < params.length; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      return pair[1];\n    }\n  }\n  return null;\n};\n\nconst setHashValue = (key, value)=> {\n  if (!key || !value) return;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n\n  let found = false;\n  for (let i = 0; i < params.length && !found; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      pair[1] = value;\n      params[i] = pair.join('=');\n      found = true;\n    }\n  }\n  if (!found) {\n    params.push([key, value].join('='));\n  }\n\n  const newHash = params.join('&');\n  window.location.hash = `#${newHash}`;\n};\n\nconst removeHashValue = (key) => {\n  if (!key) return;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n\n  for (let i = 0; i < params.length; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      params.splice(i, 1);\n      break;\n    }\n  }\n\n  const newHash = params.join('&');\n  window.location.hash = `#${newHash}`;\n};\n\nconst setPath = (category, algorithm, file) => {\n  const path = category ? category + (algorithm ? `/${algorithm}` + (file ? `/${file}` : '') : '') : '';\n  setHashValue('path', path);\n};\n\nconst getPath = () => {\n  const hash = getHashValue('path');\n  if (hash) {\n    const [ category, algorithm, file ] = hash.split('/');\n    return { category, algorithm, file };\n  } else {\n    return false;\n  }\n};\n\nmodule.exports = {\n  checkLoading,\n  getParameterByName,\n  getHashValue,\n  setHashValue,\n  removeHashValue,\n  setPath,\n  getPath\n};\n","'use strict';\n\nconst loadAlgorithm = require('./load_algorithm');\nconst loadCategories = require('./load_categories');\nconst loadFile = require('./load_file');\nconst loadScratchPaper = require('./load_scratch_paper');\nconst shareScratchPaper = require('./share_scratch_paper');\nconst loadWikiList = require('./load_wiki_list');\nconst loadWiki = require('./load_wiki');\n\nmodule.exports = {\n  loadAlgorithm,\n  loadCategories,\n  loadFile,\n  loadScratchPaper,\n  shareScratchPaper,\n  loadWikiList,\n  loadWiki\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nconst {\n  getAlgorithmDir\n} = require('../utils');\n\nmodule.exports = (category, algorithm) => {\n  const dir = getAlgorithmDir(category, algorithm);\n  return getJSON(`${dir}desc.json`);\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nmodule.exports = () => {\n  return getJSON('./algorithm/category.json');\n};","'use strict';\n\nconst RSVP = require('rsvp');\n\nconst app = require('../app');\n\nconst {\n  getFileDir,\n  isScratchPaper\n} = require('../utils');\n\nconst {\n  checkLoading,\n  setPath\n} = require('./helpers');\n\nconst get = require('./ajax/get');\n\nconst loadDataAndCode = (dir) => {\n  return RSVP.hash({\n    data: get(`${dir}data.js`),\n    code: get(`${dir}code.js`)\n  });\n};\n\nconst loadFileAndUpdateContent = (dir) => {\n  app.getEditor().clearContent();\n\n  return loadDataAndCode(dir).then((content) => {\n    app.updateCachedFile(dir, content);\n    app.getEditor().setContent(content);\n  });\n};\n\nconst cachedContentExists = (cachedFile) => {\n  return cachedFile &&\n    cachedFile.data !== undefined &&\n    cachedFile.code !== undefined;\n};\n\nmodule.exports = (category, algorithm, file, explanation) => {\n  return new RSVP.Promise((resolve, reject) => {\n    if (checkLoading()) {\n      reject();\n    } else {\n      if (isScratchPaper(category)) {\n        setPath(category, app.getLoadedScratch());\n      } else {\n        setPath(category, algorithm, file);\n      }\n      $('#explanation').html(explanation);\n\n      let dir = getFileDir(category, algorithm, file);\n      app.setLastFileUsed(dir);\n      const cachedFile = app.getCachedFile(dir);\n\n      if (cachedContentExists(cachedFile)) {\n        app.getEditor().setContent(cachedFile);\n        resolve();\n      } else {\n        loadFileAndUpdateContent(dir).then(resolve, reject);\n      }\n    }\n  });\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../app');\n\nconst {\n  getFileDir\n} = require('../utils');\n\nconst getJSON = require('./ajax/get_json');\nconst loadAlgorithm = require('./load_algorithm');\n\nconst extractGistCode = (files, name) => files[`${name}.js`].content;\n\nmodule.exports = (gistID) => {\n  return new RSVP.Promise((resolve, reject) => {\n    app.setLoadedScratch(gistID);\n\n    getJSON(`https://api.github.com/gists/${gistID}`).then(({\n      files\n    }) => {\n\n      const category = 'scratch';\n      const algorithm = gistID;\n\n      loadAlgorithm(category, algorithm).then((data) => {\n\n        const algoData = extractGistCode(files, 'data');\n        const algoCode = extractGistCode(files, 'code');\n\n        // update scratch paper algo code with the loaded gist code\n        const dir = getFileDir(category, algorithm, 'scratch_paper');\n        app.updateCachedFile(dir, {\n          data: algoData,\n          code: algoCode,\n          'CREDIT.md': 'Shared by an anonymous user from http://parkjs814.github.io/AlgorithmVisualizer'\n        });\n\n        resolve({\n          category,\n          algorithm,\n          data\n        });\n      });\n    });\n  });\n\n};","'use strict';\n\nconst get = require('./ajax/get');\n\nmodule.exports = (wiki) => {\n  return get(`./AlgorithmVisualizer.wiki/${wiki}.md`);\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nmodule.exports = () => {\n  return getJSON('./wiki.json');\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../app');\n\nconst postJSON = require('./ajax/post_json');\n\nconst {\n  setPath\n} = require('./helpers');\n\nmodule.exports = () => {\n  return new RSVP.Promise((resolve, reject) => {\n\n    const {\n      dataEditor,\n      codeEditor\n    } = app.getEditor();\n\n    const gist = {\n      'description': 'temp',\n      'public': true,\n      'files': {\n        'data.js': {\n          'content': dataEditor.getValue()\n        },\n        'code.js': {\n          'content': codeEditor.getValue()\n        }\n      }\n    };\n\n    postJSON('https://api.github.com/gists', gist).then(({\n      id\n    }) => {\n      app.setLoadedScratch(id);\n      setPath('scratch', id);\n      const {\n        href\n      } = location;\n      $('#algorithm').html('Shared');\n      resolve(href);\n    });\n  });\n};","'use strict';\n\nconst TracerManager = require('./manager');\nconst Tracer = require('../module/tracer/tracer');\n\nmodule.exports = {\n\n  init() {\n    const tm = new TracerManager();\n    Tracer.prototype.manager = tm;\n    return tm;\n  }\n\n};","'use strict';\n\nconst app = require('../app');\nconst ModuleContainer = require('../dom/module_container');\nconst TopMenu = require('../dom/top_menu');\n\nconst {\n  each,\n  extend,\n  grep\n} = $;\n\nconst stepLimit = 1e6;\n\nconst TracerManager = function () {\n  this.timer = null;\n  this.pause = false;\n  this.capsules = [];\n  this.interval = 500;\n};\n\nTracerManager.prototype = {\n\n  add(tracer) {\n\n    const $container = ModuleContainer.create();\n\n    const capsule = {\n      module: tracer.module,\n      tracer,\n      allocated: true,\n      defaultName: null,\n      $container,\n      isNew: true\n    };\n\n    this.capsules.push(capsule);\n    return capsule;\n  },\n\n  allocate(newTracer) {\n    let selectedCapsule = null;\n    let count = 0;\n\n    each(this.capsules, (i, capsule) => {\n      if (capsule.module === newTracer.module) {\n        count++;\n        if (!capsule.allocated) {\n          capsule.tracer = newTracer;\n          capsule.allocated = true;\n          capsule.isNew = false;\n          selectedCapsule = capsule;\n          return false;\n        }\n      }\n    });\n\n    if (selectedCapsule === null) {\n      count++;\n      selectedCapsule = this.add(newTracer);\n    }\n\n    const className = newTracer.module.getClassName();\n    selectedCapsule.defaultName = `${className} ${count}`;\n    selectedCapsule.order = this.order++;\n    return selectedCapsule;\n  },\n\n  deallocateAll() {\n    this.order = 0;\n    this.reset();\n    each(this.capsules, (i, capsule) => {\n      capsule.allocated = false;\n    });\n  },\n\n  removeUnallocated() {\n    let changed = false;\n\n    this.capsules = grep(this.capsules, (capsule) => {\n      let removed = !capsule.allocated;\n\n      if (capsule.isNew || removed) {\n        changed = true;\n      }\n      if (removed) {\n        capsule.$container.remove();\n      }\n\n      return !removed;\n    });\n\n    if (changed) {\n      this.place();\n    }\n  },\n\n  place() {\n    const {\n      capsules\n    } = this;\n\n    each(capsules, (i, capsule) => {\n      let width = 100;\n      let height = (100 / capsules.length);\n      let top = height * capsule.order;\n\n      capsule.$container.css({\n        top: `${top}%`,\n        width: `${width}%`,\n        height: `${height}%`\n      });\n\n      capsule.tracer.resize();\n    });\n  },\n\n  resize() {\n    this.command('resize');\n  },\n\n  isPause() {\n    return this.pause;\n  },\n\n  setInterval(interval) {\n    TopMenu.setInterval(interval);\n  },\n\n  reset() {\n    this.traces = [];\n    this.traceIndex = -1;\n    this.stepCnt = 0;\n    if (this.timer) {\n      clearTimeout(this.timer);\n    }\n    this.command('clear');\n  },\n\n  pushStep(capsule, step) {\n    if (this.stepCnt++ > stepLimit) throw \"Tracer's stack overflow\";\n    let len = this.traces.length;\n    if (len == 0) len += this.newStep();\n    const last = this.traces[len - 1];\n    last.push(extend(step, {\n      capsule\n    }));\n  },\n\n  newStep(line = -1) {\n    let len = this.traces.length;\n    if (len > 0 && ~line) {\n      this.traces[len - 1].push(line);\n    }\n    return this.traces.push([]);\n  },\n\n  pauseStep() {\n    if (this.traceIndex < 0) return;\n    this.pause = true;\n    if (this.timer) {\n      clearTimeout(this.timer);\n    }\n    TopMenu.activateBtnPause();\n  },\n\n  resumeStep() {\n    this.pause = false;\n    this.step(this.traceIndex + 1);\n    TopMenu.deactivateBtnPause();\n  },\n\n  step(i, options = {}) {\n    const tracer = this;\n\n    if (isNaN(i) || i >= this.traces.length || i < 0) return;\n\n    this.traceIndex = i;\n    const trace = this.traces[i];\n    trace.forEach((step) => {\n      if (typeof step === 'number') {\n        app.getEditor().highlightLine(step);\n        return;\n      }\n      step.capsule.tracer.processStep(step, options);\n    });\n\n    if (!options.virtual) {\n      this.command('refresh');\n    }\n\n    if (this.pause) return;\n\n    this.timer = setTimeout(() => {\n      if (!tracer.nextStep(options)) {\n        TopMenu.resetTopMenuButtons();\n      }\n    }, this.interval);\n  },\n\n  prevStep(options = {}) {\n    this.command('clear');\n\n    const finalIndex = this.traceIndex - 1;\n    if (finalIndex < 0) {\n      this.traceIndex = -1;\n      this.command('refresh');\n      return false;\n    }\n\n    for (let i = 0; i < finalIndex; i++) {\n      this.step(i, extend(options, {\n        virtual: true\n      }));\n    }\n\n    this.step(finalIndex);\n    return true;\n  },\n\n  nextStep(options = {}) {\n    const finalIndex = this.traceIndex + 1;\n    if (finalIndex >= this.traces.length) {\n      this.traceIndex = this.traces.length - 1;\n      return false;\n    }\n\n    this.step(finalIndex, options);\n    return true;\n  },\n\n  visualize() {\n    this.traceIndex = -1;\n    this.resumeStep();\n  },\n\n  command(...args) {\n    const functionName = args.shift();\n    each(this.capsules, (i, capsule) => {\n      if (capsule.allocated) {\n        capsule.tracer.module.prototype[functionName].apply(capsule.tracer, args);\n      }\n    });\n  },\n\n  findOwner(container) {\n    let selectedCapsule = null;\n    each(this.capsules, (i, capsule) => {\n      if (capsule.$container[0] === container) {\n        selectedCapsule = capsule;\n        return false;\n      }\n    });\n    return selectedCapsule.tracer;\n  }\n};\n\nmodule.exports = TracerManager;\n","'use strict';\n\nconst {\n  parse\n} = JSON;\n\nconst fromJSON = (obj) => {\n  return parse(obj, (key, value) => {\n    return value === 'Infinity' ? Infinity : value;\n  });\n};\n\nmodule.exports = fromJSON;\n","'use strict';\n\nconst toJSON = require('./to_json');\nconst fromJSON = require('./from_json');\nconst refineByType = require('./refine_by_type');\n\nmodule.exports = {\n  toJSON,\n  fromJSON,\n  refineByType\n};\n","'use strict';\n\nconst refineByType = (item) => {\n  switch (typeof(item)) {\n    case 'number':\n      return refineNumber(item);\n    case 'boolean':\n      return refineBoolean(item);\n    default:\n      return refineString(item);\n  }\n};\n\nconst refineString = (str) => {\n  return str === '' ? ' ' : str;\n};\n\nconst refineNumber = (num) => {\n  return num === Infinity ? '∞' : num;\n};\n\nconst refineBoolean = (bool) => {\n  return bool ? 'T' : 'F';\n};\n\nmodule.exports = refineByType;\n","'use strict';\n\nconst {\n  stringify\n} = JSON;\n\nconst toJSON = (obj) => {\n  return stringify(obj, (key, value) => {\n    return value === Infinity ? 'Infinity' : value;\n  });\n};\n\nmodule.exports = toJSON;\n","'use strict';\n\nconst isScratchPaper = (category, algorithm) => {\n  return category == 'scratch';\n};\n\nconst getAlgorithmDir = (category, algorithm) => {\n  if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n  return `./algorithm/${category}/${algorithm}/`;\n};\n\nconst getFileDir = (category, algorithm, file) => {\n  if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n  return `./algorithm/${category}/${algorithm}/${file}/`;\n};\n\nmodule.exports = {\n  isScratchPaper,\n  getAlgorithmDir,\n  getFileDir\n};","// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = setTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    clearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        setTimeout(drainQueue, 0);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\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\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","/*!\n * @overview RSVP - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors\n * @license   Licensed under MIT license\n *            See https://raw.githubusercontent.com/tildeio/rsvp.js/master/LICENSE\n * @version   3.2.1\n */\n\n(function() {\n    \"use strict\";\n    function lib$rsvp$utils$$objectOrFunction(x) {\n      return typeof x === 'function' || (typeof x === 'object' && x !== null);\n    }\n\n    function lib$rsvp$utils$$isFunction(x) {\n      return typeof x === 'function';\n    }\n\n    function lib$rsvp$utils$$isMaybeThenable(x) {\n      return typeof x === 'object' && x !== null;\n    }\n\n    var lib$rsvp$utils$$_isArray;\n    if (!Array.isArray) {\n      lib$rsvp$utils$$_isArray = function (x) {\n        return Object.prototype.toString.call(x) === '[object Array]';\n      };\n    } else {\n      lib$rsvp$utils$$_isArray = Array.isArray;\n    }\n\n    var lib$rsvp$utils$$isArray = lib$rsvp$utils$$_isArray;\n\n    var lib$rsvp$utils$$now = Date.now || function() { return new Date().getTime(); };\n\n    function lib$rsvp$utils$$F() { }\n\n    var lib$rsvp$utils$$o_create = (Object.create || function (o) {\n      if (arguments.length > 1) {\n        throw new Error('Second argument not supported');\n      }\n      if (typeof o !== 'object') {\n        throw new TypeError('Argument must be an object');\n      }\n      lib$rsvp$utils$$F.prototype = o;\n      return new lib$rsvp$utils$$F();\n    });\n    function lib$rsvp$events$$indexOf(callbacks, callback) {\n      for (var i=0, l=callbacks.length; i<l; i++) {\n        if (callbacks[i] === callback) { return i; }\n      }\n\n      return -1;\n    }\n\n    function lib$rsvp$events$$callbacksFor(object) {\n      var callbacks = object._promiseCallbacks;\n\n      if (!callbacks) {\n        callbacks = object._promiseCallbacks = {};\n      }\n\n      return callbacks;\n    }\n\n    var lib$rsvp$events$$default = {\n\n      /**\n        `RSVP.EventTarget.mixin` extends an object with EventTarget methods. For\n        Example:\n\n        ```javascript\n        var object = {};\n\n        RSVP.EventTarget.mixin(object);\n\n        object.on('finished', function(event) {\n          // handle event\n        });\n\n        object.trigger('finished', { detail: value });\n        ```\n\n        `EventTarget.mixin` also works with prototypes:\n\n        ```javascript\n        var Person = function() {};\n        RSVP.EventTarget.mixin(Person.prototype);\n\n        var yehuda = new Person();\n        var tom = new Person();\n\n        yehuda.on('poke', function(event) {\n          console.log('Yehuda says OW');\n        });\n\n        tom.on('poke', function(event) {\n          console.log('Tom says OW');\n        });\n\n        yehuda.trigger('poke');\n        tom.trigger('poke');\n        ```\n\n        @method mixin\n        @for RSVP.EventTarget\n        @private\n        @param {Object} object object to extend with EventTarget methods\n      */\n      'mixin': function(object) {\n        object['on']      = this['on'];\n        object['off']     = this['off'];\n        object['trigger'] = this['trigger'];\n        object._promiseCallbacks = undefined;\n        return object;\n      },\n\n      /**\n        Registers a callback to be executed when `eventName` is triggered\n\n        ```javascript\n        object.on('event', function(eventInfo){\n          // handle the event\n        });\n\n        object.trigger('event');\n        ```\n\n        @method on\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName name of the event to listen for\n        @param {Function} callback function to be called when the event is triggered.\n      */\n      'on': function(eventName, callback) {\n        if (typeof callback !== 'function') {\n          throw new TypeError('Callback must be a function');\n        }\n\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks;\n\n        callbacks = allCallbacks[eventName];\n\n        if (!callbacks) {\n          callbacks = allCallbacks[eventName] = [];\n        }\n\n        if (lib$rsvp$events$$indexOf(callbacks, callback) === -1) {\n          callbacks.push(callback);\n        }\n      },\n\n      /**\n        You can use `off` to stop firing a particular callback for an event:\n\n        ```javascript\n        function doStuff() { // do stuff! }\n        object.on('stuff', doStuff);\n\n        object.trigger('stuff'); // doStuff will be called\n\n        // Unregister ONLY the doStuff callback\n        object.off('stuff', doStuff);\n        object.trigger('stuff'); // doStuff will NOT be called\n        ```\n\n        If you don't pass a `callback` argument to `off`, ALL callbacks for the\n        event will not be executed when the event fires. For example:\n\n        ```javascript\n        var callback1 = function(){};\n        var callback2 = function(){};\n\n        object.on('stuff', callback1);\n        object.on('stuff', callback2);\n\n        object.trigger('stuff'); // callback1 and callback2 will be executed.\n\n        object.off('stuff');\n        object.trigger('stuff'); // callback1 and callback2 will not be executed!\n        ```\n\n        @method off\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName event to stop listening to\n        @param {Function} callback optional argument. If given, only the function\n        given will be removed from the event's callback queue. If no `callback`\n        argument is given, all callbacks will be removed from the event's callback\n        queue.\n      */\n      'off': function(eventName, callback) {\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, index;\n\n        if (!callback) {\n          allCallbacks[eventName] = [];\n          return;\n        }\n\n        callbacks = allCallbacks[eventName];\n\n        index = lib$rsvp$events$$indexOf(callbacks, callback);\n\n        if (index !== -1) { callbacks.splice(index, 1); }\n      },\n\n      /**\n        Use `trigger` to fire custom events. For example:\n\n        ```javascript\n        object.on('foo', function(){\n          console.log('foo event happened!');\n        });\n        object.trigger('foo');\n        // 'foo event happened!' logged to the console\n        ```\n\n        You can also pass a value as a second argument to `trigger` that will be\n        passed as an argument to all event listeners for the event:\n\n        ```javascript\n        object.on('foo', function(value){\n          console.log(value.name);\n        });\n\n        object.trigger('foo', { name: 'bar' });\n        // 'bar' logged to the console\n        ```\n\n        @method trigger\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName name of the event to be triggered\n        @param {*} options optional value to be passed to any event handlers for\n        the given `eventName`\n      */\n      'trigger': function(eventName, options, label) {\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, callback;\n\n        if (callbacks = allCallbacks[eventName]) {\n          // Don't cache the callbacks.length since it may grow\n          for (var i=0; i<callbacks.length; i++) {\n            callback = callbacks[i];\n\n            callback(options, label);\n          }\n        }\n      }\n    };\n\n    var lib$rsvp$config$$config = {\n      instrument: false\n    };\n\n    lib$rsvp$events$$default['mixin'](lib$rsvp$config$$config);\n\n    function lib$rsvp$config$$configure(name, value) {\n      if (name === 'onerror') {\n        // handle for legacy users that expect the actual\n        // error to be passed to their function added via\n        // `RSVP.configure('onerror', someFunctionHere);`\n        lib$rsvp$config$$config['on']('error', value);\n        return;\n      }\n\n      if (arguments.length === 2) {\n        lib$rsvp$config$$config[name] = value;\n      } else {\n        return lib$rsvp$config$$config[name];\n      }\n    }\n\n    var lib$rsvp$instrument$$queue = [];\n\n    function lib$rsvp$instrument$$scheduleFlush() {\n      setTimeout(function() {\n        var entry;\n        for (var i = 0; i < lib$rsvp$instrument$$queue.length; i++) {\n          entry = lib$rsvp$instrument$$queue[i];\n\n          var payload = entry.payload;\n\n          payload.guid = payload.key + payload.id;\n          payload.childGuid = payload.key + payload.childId;\n          if (payload.error) {\n            payload.stack = payload.error.stack;\n          }\n\n          lib$rsvp$config$$config['trigger'](entry.name, entry.payload);\n        }\n        lib$rsvp$instrument$$queue.length = 0;\n      }, 50);\n    }\n\n    function lib$rsvp$instrument$$instrument(eventName, promise, child) {\n      if (1 === lib$rsvp$instrument$$queue.push({\n        name: eventName,\n        payload: {\n          key: promise._guidKey,\n          id:  promise._id,\n          eventName: eventName,\n          detail: promise._result,\n          childId: child && child._id,\n          label: promise._label,\n          timeStamp: lib$rsvp$utils$$now(),\n          error: lib$rsvp$config$$config[\"instrument-with-stack\"] ? new Error(promise._label) : null\n        }})) {\n          lib$rsvp$instrument$$scheduleFlush();\n        }\n      }\n    var lib$rsvp$instrument$$default = lib$rsvp$instrument$$instrument;\n    function lib$rsvp$then$$then(onFulfillment, onRejection, label) {\n      var parent = this;\n      var state = parent._state;\n\n      if (state === lib$rsvp$$internal$$FULFILLED && !onFulfillment || state === lib$rsvp$$internal$$REJECTED && !onRejection) {\n        lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, parent);\n        return parent;\n      }\n\n      parent._onError = null;\n\n      var child = new parent.constructor(lib$rsvp$$internal$$noop, label);\n      var result = parent._result;\n\n      lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, child);\n\n      if (state) {\n        var callback = arguments[state - 1];\n        lib$rsvp$config$$config.async(function(){\n          lib$rsvp$$internal$$invokeCallback(state, child, callback, result);\n        });\n      } else {\n        lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection);\n      }\n\n      return child;\n    }\n    var lib$rsvp$then$$default = lib$rsvp$then$$then;\n    function lib$rsvp$promise$resolve$$resolve(object, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n\n      if (object && typeof object === 'object' && object.constructor === Constructor) {\n        return object;\n      }\n\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      lib$rsvp$$internal$$resolve(promise, object);\n      return promise;\n    }\n    var lib$rsvp$promise$resolve$$default = lib$rsvp$promise$resolve$$resolve;\n    function lib$rsvp$enumerator$$makeSettledResult(state, position, value) {\n      if (state === lib$rsvp$$internal$$FULFILLED) {\n        return {\n          state: 'fulfilled',\n          value: value\n        };\n      } else {\n         return {\n          state: 'rejected',\n          reason: value\n        };\n      }\n    }\n\n    function lib$rsvp$enumerator$$Enumerator(Constructor, input, abortOnReject, label) {\n      this._instanceConstructor = Constructor;\n      this.promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      this._abortOnReject = abortOnReject;\n\n      if (this._validateInput(input)) {\n        this._input     = input;\n        this.length     = input.length;\n        this._remaining = input.length;\n\n        this._init();\n\n        if (this.length === 0) {\n          lib$rsvp$$internal$$fulfill(this.promise, this._result);\n        } else {\n          this.length = this.length || 0;\n          this._enumerate();\n          if (this._remaining === 0) {\n            lib$rsvp$$internal$$fulfill(this.promise, this._result);\n          }\n        }\n      } else {\n        lib$rsvp$$internal$$reject(this.promise, this._validationError());\n      }\n    }\n\n    var lib$rsvp$enumerator$$default = lib$rsvp$enumerator$$Enumerator;\n\n    lib$rsvp$enumerator$$Enumerator.prototype._validateInput = function(input) {\n      return lib$rsvp$utils$$isArray(input);\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._validationError = function() {\n      return new Error('Array Methods must be provided an Array');\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._init = function() {\n      this._result = new Array(this.length);\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._enumerate = function() {\n      var length     = this.length;\n      var promise    = this.promise;\n      var input      = this._input;\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        this._eachEntry(input[i], i);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._settleMaybeThenable = function(entry, i) {\n      var c = this._instanceConstructor;\n      var resolve = c.resolve;\n\n      if (resolve === lib$rsvp$promise$resolve$$default) {\n        var then = lib$rsvp$$internal$$getThen(entry);\n\n        if (then === lib$rsvp$then$$default &&\n            entry._state !== lib$rsvp$$internal$$PENDING) {\n          entry._onError = null;\n          this._settledAt(entry._state, i, entry._result);\n        } else if (typeof then !== 'function') {\n          this._remaining--;\n          this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n        } else if (c === lib$rsvp$promise$$default) {\n          var promise = new c(lib$rsvp$$internal$$noop);\n          lib$rsvp$$internal$$handleMaybeThenable(promise, entry, then);\n          this._willSettleAt(promise, i);\n        } else {\n          this._willSettleAt(new c(function(resolve) { resolve(entry); }), i);\n        }\n      } else {\n        this._willSettleAt(resolve(entry), i);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._eachEntry = function(entry, i) {\n      if (lib$rsvp$utils$$isMaybeThenable(entry)) {\n        this._settleMaybeThenable(entry, i);\n      } else {\n        this._remaining--;\n        this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._settledAt = function(state, i, value) {\n      var promise = this.promise;\n\n      if (promise._state === lib$rsvp$$internal$$PENDING) {\n        this._remaining--;\n\n        if (this._abortOnReject && state === lib$rsvp$$internal$$REJECTED) {\n          lib$rsvp$$internal$$reject(promise, value);\n        } else {\n          this._result[i] = this._makeResult(state, i, value);\n        }\n      }\n\n      if (this._remaining === 0) {\n        lib$rsvp$$internal$$fulfill(promise, this._result);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._makeResult = function(state, i, value) {\n      return value;\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._willSettleAt = function(promise, i) {\n      var enumerator = this;\n\n      lib$rsvp$$internal$$subscribe(promise, undefined, function(value) {\n        enumerator._settledAt(lib$rsvp$$internal$$FULFILLED, i, value);\n      }, function(reason) {\n        enumerator._settledAt(lib$rsvp$$internal$$REJECTED, i, reason);\n      });\n    };\n    function lib$rsvp$promise$all$$all(entries, label) {\n      return new lib$rsvp$enumerator$$default(this, entries, true /* abort on reject */, label).promise;\n    }\n    var lib$rsvp$promise$all$$default = lib$rsvp$promise$all$$all;\n    function lib$rsvp$promise$race$$race(entries, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n\n      if (!lib$rsvp$utils$$isArray(entries)) {\n        lib$rsvp$$internal$$reject(promise, new TypeError('You must pass an array to race.'));\n        return promise;\n      }\n\n      var length = entries.length;\n\n      function onFulfillment(value) {\n        lib$rsvp$$internal$$resolve(promise, value);\n      }\n\n      function onRejection(reason) {\n        lib$rsvp$$internal$$reject(promise, reason);\n      }\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        lib$rsvp$$internal$$subscribe(Constructor.resolve(entries[i]), undefined, onFulfillment, onRejection);\n      }\n\n      return promise;\n    }\n    var lib$rsvp$promise$race$$default = lib$rsvp$promise$race$$race;\n    function lib$rsvp$promise$reject$$reject(reason, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      lib$rsvp$$internal$$reject(promise, reason);\n      return promise;\n    }\n    var lib$rsvp$promise$reject$$default = lib$rsvp$promise$reject$$reject;\n\n    var lib$rsvp$promise$$guidKey = 'rsvp_' + lib$rsvp$utils$$now() + '-';\n    var lib$rsvp$promise$$counter = 0;\n\n    function lib$rsvp$promise$$needsResolver() {\n      throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n    }\n\n    function lib$rsvp$promise$$needsNew() {\n      throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n    }\n\n    function lib$rsvp$promise$$Promise(resolver, label) {\n      this._id = lib$rsvp$promise$$counter++;\n      this._label = label;\n      this._state = undefined;\n      this._result = undefined;\n      this._subscribers = [];\n\n      lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('created', this);\n\n      if (lib$rsvp$$internal$$noop !== resolver) {\n        typeof resolver !== 'function' && lib$rsvp$promise$$needsResolver();\n        this instanceof lib$rsvp$promise$$Promise ? lib$rsvp$$internal$$initializePromise(this, resolver) : lib$rsvp$promise$$needsNew();\n      }\n    }\n\n    var lib$rsvp$promise$$default = lib$rsvp$promise$$Promise;\n\n    // deprecated\n    lib$rsvp$promise$$Promise.cast = lib$rsvp$promise$resolve$$default;\n    lib$rsvp$promise$$Promise.all = lib$rsvp$promise$all$$default;\n    lib$rsvp$promise$$Promise.race = lib$rsvp$promise$race$$default;\n    lib$rsvp$promise$$Promise.resolve = lib$rsvp$promise$resolve$$default;\n    lib$rsvp$promise$$Promise.reject = lib$rsvp$promise$reject$$default;\n\n    lib$rsvp$promise$$Promise.prototype = {\n      constructor: lib$rsvp$promise$$Promise,\n\n      _guidKey: lib$rsvp$promise$$guidKey,\n\n      _onError: function (reason) {\n        var promise = this;\n        lib$rsvp$config$$config.after(function() {\n          if (promise._onError) {\n            lib$rsvp$config$$config['trigger']('error', reason, promise._label);\n          }\n        });\n      },\n\n    /**\n      The primary way of interacting with a promise is through its `then` method,\n      which registers callbacks to receive either a promise's eventual value or the\n      reason why the promise cannot be fulfilled.\n\n      ```js\n      findUser().then(function(user){\n        // user is available\n      }, function(reason){\n        // user is unavailable, and you are given the reason why\n      });\n      ```\n\n      Chaining\n      --------\n\n      The return value of `then` is itself a promise.  This second, 'downstream'\n      promise is resolved with the return value of the first promise's fulfillment\n      or rejection handler, or rejected if the handler throws an exception.\n\n      ```js\n      findUser().then(function (user) {\n        return user.name;\n      }, function (reason) {\n        return 'default name';\n      }).then(function (userName) {\n        // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n        // will be `'default name'`\n      });\n\n      findUser().then(function (user) {\n        throw new Error('Found user, but still unhappy');\n      }, function (reason) {\n        throw new Error('`findUser` rejected and we're unhappy');\n      }).then(function (value) {\n        // never reached\n      }, function (reason) {\n        // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n        // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n      });\n      ```\n      If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n\n      ```js\n      findUser().then(function (user) {\n        throw new PedagogicalException('Upstream error');\n      }).then(function (value) {\n        // never reached\n      }).then(function (value) {\n        // never reached\n      }, function (reason) {\n        // The `PedgagocialException` is propagated all the way down to here\n      });\n      ```\n\n      Assimilation\n      ------------\n\n      Sometimes the value you want to propagate to a downstream promise can only be\n      retrieved asynchronously. This can be achieved by returning a promise in the\n      fulfillment or rejection handler. The downstream promise will then be pending\n      until the returned promise is settled. This is called *assimilation*.\n\n      ```js\n      findUser().then(function (user) {\n        return findCommentsByAuthor(user);\n      }).then(function (comments) {\n        // The user's comments are now available\n      });\n      ```\n\n      If the assimliated promise rejects, then the downstream promise will also reject.\n\n      ```js\n      findUser().then(function (user) {\n        return findCommentsByAuthor(user);\n      }).then(function (comments) {\n        // If `findCommentsByAuthor` fulfills, we'll have the value here\n      }, function (reason) {\n        // If `findCommentsByAuthor` rejects, we'll have the reason here\n      });\n      ```\n\n      Simple Example\n      --------------\n\n      Synchronous Example\n\n      ```javascript\n      var result;\n\n      try {\n        result = findResult();\n        // success\n      } catch(reason) {\n        // failure\n      }\n      ```\n\n      Errback Example\n\n      ```js\n      findResult(function(result, err){\n        if (err) {\n          // failure\n        } else {\n          // success\n        }\n      });\n      ```\n\n      Promise Example;\n\n      ```javascript\n      findResult().then(function(result){\n        // success\n      }, function(reason){\n        // failure\n      });\n      ```\n\n      Advanced Example\n      --------------\n\n      Synchronous Example\n\n      ```javascript\n      var author, books;\n\n      try {\n        author = findAuthor();\n        books  = findBooksByAuthor(author);\n        // success\n      } catch(reason) {\n        // failure\n      }\n      ```\n\n      Errback Example\n\n      ```js\n\n      function foundBooks(books) {\n\n      }\n\n      function failure(reason) {\n\n      }\n\n      findAuthor(function(author, err){\n        if (err) {\n          failure(err);\n          // failure\n        } else {\n          try {\n            findBoooksByAuthor(author, function(books, err) {\n              if (err) {\n                failure(err);\n              } else {\n                try {\n                  foundBooks(books);\n                } catch(reason) {\n                  failure(reason);\n                }\n              }\n            });\n          } catch(error) {\n            failure(err);\n          }\n          // success\n        }\n      });\n      ```\n\n      Promise Example;\n\n      ```javascript\n      findAuthor().\n        then(findBooksByAuthor).\n        then(function(books){\n          // found books\n      }).catch(function(reason){\n        // something went wrong\n      });\n      ```\n\n      @method then\n      @param {Function} onFulfillment\n      @param {Function} onRejection\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      then: lib$rsvp$then$$default,\n\n    /**\n      `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n      as the catch block of a try/catch statement.\n\n      ```js\n      function findAuthor(){\n        throw new Error('couldn't find that author');\n      }\n\n      // synchronous\n      try {\n        findAuthor();\n      } catch(reason) {\n        // something went wrong\n      }\n\n      // async with promises\n      findAuthor().catch(function(reason){\n        // something went wrong\n      });\n      ```\n\n      @method catch\n      @param {Function} onRejection\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      'catch': function(onRejection, label) {\n        return this.then(undefined, onRejection, label);\n      },\n\n    /**\n      `finally` will be invoked regardless of the promise's fate just as native\n      try/catch/finally behaves\n\n      Synchronous example:\n\n      ```js\n      findAuthor() {\n        if (Math.random() > 0.5) {\n          throw new Error();\n        }\n        return new Author();\n      }\n\n      try {\n        return findAuthor(); // succeed or fail\n      } catch(error) {\n        return findOtherAuther();\n      } finally {\n        // always runs\n        // doesn't affect the return value\n      }\n      ```\n\n      Asynchronous example:\n\n      ```js\n      findAuthor().catch(function(reason){\n        return findOtherAuther();\n      }).finally(function(){\n        // author was either found, or not\n      });\n      ```\n\n      @method finally\n      @param {Function} callback\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      'finally': function(callback, label) {\n        var promise = this;\n        var constructor = promise.constructor;\n\n        return promise.then(function(value) {\n          return constructor.resolve(callback()).then(function() {\n            return value;\n          });\n        }, function(reason) {\n          return constructor.resolve(callback()).then(function() {\n            return constructor.reject(reason);\n          });\n        }, label);\n      }\n    };\n    function  lib$rsvp$$internal$$withOwnPromise() {\n      return new TypeError('A promises callback cannot return that same promise.');\n    }\n\n    function lib$rsvp$$internal$$noop() {}\n\n    var lib$rsvp$$internal$$PENDING   = void 0;\n    var lib$rsvp$$internal$$FULFILLED = 1;\n    var lib$rsvp$$internal$$REJECTED  = 2;\n\n    var lib$rsvp$$internal$$GET_THEN_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n    function lib$rsvp$$internal$$getThen(promise) {\n      try {\n        return promise.then;\n      } catch(error) {\n        lib$rsvp$$internal$$GET_THEN_ERROR.error = error;\n        return lib$rsvp$$internal$$GET_THEN_ERROR;\n      }\n    }\n\n    function lib$rsvp$$internal$$tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n      try {\n        then.call(value, fulfillmentHandler, rejectionHandler);\n      } catch(e) {\n        return e;\n      }\n    }\n\n    function lib$rsvp$$internal$$handleForeignThenable(promise, thenable, then) {\n      lib$rsvp$config$$config.async(function(promise) {\n        var sealed = false;\n        var error = lib$rsvp$$internal$$tryThen(then, thenable, function(value) {\n          if (sealed) { return; }\n          sealed = true;\n          if (thenable !== value) {\n            lib$rsvp$$internal$$resolve(promise, value, undefined);\n          } else {\n            lib$rsvp$$internal$$fulfill(promise, value);\n          }\n        }, function(reason) {\n          if (sealed) { return; }\n          sealed = true;\n\n          lib$rsvp$$internal$$reject(promise, reason);\n        }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n        if (!sealed && error) {\n          sealed = true;\n          lib$rsvp$$internal$$reject(promise, error);\n        }\n      }, promise);\n    }\n\n    function lib$rsvp$$internal$$handleOwnThenable(promise, thenable) {\n      if (thenable._state === lib$rsvp$$internal$$FULFILLED) {\n        lib$rsvp$$internal$$fulfill(promise, thenable._result);\n      } else if (thenable._state === lib$rsvp$$internal$$REJECTED) {\n        thenable._onError = null;\n        lib$rsvp$$internal$$reject(promise, thenable._result);\n      } else {\n        lib$rsvp$$internal$$subscribe(thenable, undefined, function(value) {\n          if (thenable !== value) {\n            lib$rsvp$$internal$$resolve(promise, value, undefined);\n          } else {\n            lib$rsvp$$internal$$fulfill(promise, value);\n          }\n        }, function(reason) {\n          lib$rsvp$$internal$$reject(promise, reason);\n        });\n      }\n    }\n\n    function lib$rsvp$$internal$$handleMaybeThenable(promise, maybeThenable, then) {\n      if (maybeThenable.constructor === promise.constructor &&\n          then === lib$rsvp$then$$default &&\n          constructor.resolve === lib$rsvp$promise$resolve$$default) {\n        lib$rsvp$$internal$$handleOwnThenable(promise, maybeThenable);\n      } else {\n        if (then === lib$rsvp$$internal$$GET_THEN_ERROR) {\n          lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$GET_THEN_ERROR.error);\n        } else if (then === undefined) {\n          lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n        } else if (lib$rsvp$utils$$isFunction(then)) {\n          lib$rsvp$$internal$$handleForeignThenable(promise, maybeThenable, then);\n        } else {\n          lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n        }\n      }\n    }\n\n    function lib$rsvp$$internal$$resolve(promise, value) {\n      if (promise === value) {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      } else if (lib$rsvp$utils$$objectOrFunction(value)) {\n        lib$rsvp$$internal$$handleMaybeThenable(promise, value, lib$rsvp$$internal$$getThen(value));\n      } else {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      }\n    }\n\n    function lib$rsvp$$internal$$publishRejection(promise) {\n      if (promise._onError) {\n        promise._onError(promise._result);\n      }\n\n      lib$rsvp$$internal$$publish(promise);\n    }\n\n    function lib$rsvp$$internal$$fulfill(promise, value) {\n      if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n\n      promise._result = value;\n      promise._state = lib$rsvp$$internal$$FULFILLED;\n\n      if (promise._subscribers.length === 0) {\n        if (lib$rsvp$config$$config.instrument) {\n          lib$rsvp$instrument$$default('fulfilled', promise);\n        }\n      } else {\n        lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, promise);\n      }\n    }\n\n    function lib$rsvp$$internal$$reject(promise, reason) {\n      if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n      promise._state = lib$rsvp$$internal$$REJECTED;\n      promise._result = reason;\n      lib$rsvp$config$$config.async(lib$rsvp$$internal$$publishRejection, promise);\n    }\n\n    function lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection) {\n      var subscribers = parent._subscribers;\n      var length = subscribers.length;\n\n      parent._onError = null;\n\n      subscribers[length] = child;\n      subscribers[length + lib$rsvp$$internal$$FULFILLED] = onFulfillment;\n      subscribers[length + lib$rsvp$$internal$$REJECTED]  = onRejection;\n\n      if (length === 0 && parent._state) {\n        lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, parent);\n      }\n    }\n\n    function lib$rsvp$$internal$$publish(promise) {\n      var subscribers = promise._subscribers;\n      var settled = promise._state;\n\n      if (lib$rsvp$config$$config.instrument) {\n        lib$rsvp$instrument$$default(settled === lib$rsvp$$internal$$FULFILLED ? 'fulfilled' : 'rejected', promise);\n      }\n\n      if (subscribers.length === 0) { return; }\n\n      var child, callback, detail = promise._result;\n\n      for (var i = 0; i < subscribers.length; i += 3) {\n        child = subscribers[i];\n        callback = subscribers[i + settled];\n\n        if (child) {\n          lib$rsvp$$internal$$invokeCallback(settled, child, callback, detail);\n        } else {\n          callback(detail);\n        }\n      }\n\n      promise._subscribers.length = 0;\n    }\n\n    function lib$rsvp$$internal$$ErrorObject() {\n      this.error = null;\n    }\n\n    var lib$rsvp$$internal$$TRY_CATCH_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n    function lib$rsvp$$internal$$tryCatch(callback, detail) {\n      try {\n        return callback(detail);\n      } catch(e) {\n        lib$rsvp$$internal$$TRY_CATCH_ERROR.error = e;\n        return lib$rsvp$$internal$$TRY_CATCH_ERROR;\n      }\n    }\n\n    function lib$rsvp$$internal$$invokeCallback(settled, promise, callback, detail) {\n      var hasCallback = lib$rsvp$utils$$isFunction(callback),\n          value, error, succeeded, failed;\n\n      if (hasCallback) {\n        value = lib$rsvp$$internal$$tryCatch(callback, detail);\n\n        if (value === lib$rsvp$$internal$$TRY_CATCH_ERROR) {\n          failed = true;\n          error = value.error;\n          value = null;\n        } else {\n          succeeded = true;\n        }\n\n        if (promise === value) {\n          lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$withOwnPromise());\n          return;\n        }\n\n      } else {\n        value = detail;\n        succeeded = true;\n      }\n\n      if (promise._state !== lib$rsvp$$internal$$PENDING) {\n        // noop\n      } else if (hasCallback && succeeded) {\n        lib$rsvp$$internal$$resolve(promise, value);\n      } else if (failed) {\n        lib$rsvp$$internal$$reject(promise, error);\n      } else if (settled === lib$rsvp$$internal$$FULFILLED) {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      } else if (settled === lib$rsvp$$internal$$REJECTED) {\n        lib$rsvp$$internal$$reject(promise, value);\n      }\n    }\n\n    function lib$rsvp$$internal$$initializePromise(promise, resolver) {\n      var resolved = false;\n      try {\n        resolver(function resolvePromise(value){\n          if (resolved) { return; }\n          resolved = true;\n          lib$rsvp$$internal$$resolve(promise, value);\n        }, function rejectPromise(reason) {\n          if (resolved) { return; }\n          resolved = true;\n          lib$rsvp$$internal$$reject(promise, reason);\n        });\n      } catch(e) {\n        lib$rsvp$$internal$$reject(promise, e);\n      }\n    }\n\n    function lib$rsvp$all$settled$$AllSettled(Constructor, entries, label) {\n      this._superConstructor(Constructor, entries, false /* don't abort on reject */, label);\n    }\n\n    lib$rsvp$all$settled$$AllSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n    lib$rsvp$all$settled$$AllSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$all$settled$$AllSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n    lib$rsvp$all$settled$$AllSettled.prototype._validationError = function() {\n      return new Error('allSettled must be called with an array');\n    };\n\n    function lib$rsvp$all$settled$$allSettled(entries, label) {\n      return new lib$rsvp$all$settled$$AllSettled(lib$rsvp$promise$$default, entries, label).promise;\n    }\n    var lib$rsvp$all$settled$$default = lib$rsvp$all$settled$$allSettled;\n    function lib$rsvp$all$$all(array, label) {\n      return lib$rsvp$promise$$default.all(array, label);\n    }\n    var lib$rsvp$all$$default = lib$rsvp$all$$all;\n    var lib$rsvp$asap$$len = 0;\n    var lib$rsvp$asap$$toString = {}.toString;\n    var lib$rsvp$asap$$vertxNext;\n    function lib$rsvp$asap$$asap(callback, arg) {\n      lib$rsvp$asap$$queue[lib$rsvp$asap$$len] = callback;\n      lib$rsvp$asap$$queue[lib$rsvp$asap$$len + 1] = arg;\n      lib$rsvp$asap$$len += 2;\n      if (lib$rsvp$asap$$len === 2) {\n        // If len is 1, that means that we need to schedule an async flush.\n        // If additional callbacks are queued before the queue is flushed, they\n        // will be processed by this flush that we are scheduling.\n        lib$rsvp$asap$$scheduleFlush();\n      }\n    }\n\n    var lib$rsvp$asap$$default = lib$rsvp$asap$$asap;\n\n    var lib$rsvp$asap$$browserWindow = (typeof window !== 'undefined') ? window : undefined;\n    var lib$rsvp$asap$$browserGlobal = lib$rsvp$asap$$browserWindow || {};\n    var lib$rsvp$asap$$BrowserMutationObserver = lib$rsvp$asap$$browserGlobal.MutationObserver || lib$rsvp$asap$$browserGlobal.WebKitMutationObserver;\n    var lib$rsvp$asap$$isNode = typeof self === 'undefined' &&\n      typeof process !== 'undefined' && {}.toString.call(process) === '[object process]';\n\n    // test for web worker but not in IE10\n    var lib$rsvp$asap$$isWorker = typeof Uint8ClampedArray !== 'undefined' &&\n      typeof importScripts !== 'undefined' &&\n      typeof MessageChannel !== 'undefined';\n\n    // node\n    function lib$rsvp$asap$$useNextTick() {\n      var nextTick = process.nextTick;\n      // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n      // setImmediate should be used instead instead\n      var version = process.versions.node.match(/^(?:(\\d+)\\.)?(?:(\\d+)\\.)?(\\*|\\d+)$/);\n      if (Array.isArray(version) && version[1] === '0' && version[2] === '10') {\n        nextTick = setImmediate;\n      }\n      return function() {\n        nextTick(lib$rsvp$asap$$flush);\n      };\n    }\n\n    // vertx\n    function lib$rsvp$asap$$useVertxTimer() {\n      return function() {\n        lib$rsvp$asap$$vertxNext(lib$rsvp$asap$$flush);\n      };\n    }\n\n    function lib$rsvp$asap$$useMutationObserver() {\n      var iterations = 0;\n      var observer = new lib$rsvp$asap$$BrowserMutationObserver(lib$rsvp$asap$$flush);\n      var node = document.createTextNode('');\n      observer.observe(node, { characterData: true });\n\n      return function() {\n        node.data = (iterations = ++iterations % 2);\n      };\n    }\n\n    // web worker\n    function lib$rsvp$asap$$useMessageChannel() {\n      var channel = new MessageChannel();\n      channel.port1.onmessage = lib$rsvp$asap$$flush;\n      return function () {\n        channel.port2.postMessage(0);\n      };\n    }\n\n    function lib$rsvp$asap$$useSetTimeout() {\n      return function() {\n        setTimeout(lib$rsvp$asap$$flush, 1);\n      };\n    }\n\n    var lib$rsvp$asap$$queue = new Array(1000);\n    function lib$rsvp$asap$$flush() {\n      for (var i = 0; i < lib$rsvp$asap$$len; i+=2) {\n        var callback = lib$rsvp$asap$$queue[i];\n        var arg = lib$rsvp$asap$$queue[i+1];\n\n        callback(arg);\n\n        lib$rsvp$asap$$queue[i] = undefined;\n        lib$rsvp$asap$$queue[i+1] = undefined;\n      }\n\n      lib$rsvp$asap$$len = 0;\n    }\n\n    function lib$rsvp$asap$$attemptVertex() {\n      try {\n        var r = require;\n        var vertx = r('vertx');\n        lib$rsvp$asap$$vertxNext = vertx.runOnLoop || vertx.runOnContext;\n        return lib$rsvp$asap$$useVertxTimer();\n      } catch(e) {\n        return lib$rsvp$asap$$useSetTimeout();\n      }\n    }\n\n    var lib$rsvp$asap$$scheduleFlush;\n    // Decide what async method to use to triggering processing of queued callbacks:\n    if (lib$rsvp$asap$$isNode) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useNextTick();\n    } else if (lib$rsvp$asap$$BrowserMutationObserver) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMutationObserver();\n    } else if (lib$rsvp$asap$$isWorker) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMessageChannel();\n    } else if (lib$rsvp$asap$$browserWindow === undefined && typeof require === 'function') {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$attemptVertex();\n    } else {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useSetTimeout();\n    }\n    function lib$rsvp$defer$$defer(label) {\n      var deferred = {};\n\n      deferred['promise'] = new lib$rsvp$promise$$default(function(resolve, reject) {\n        deferred['resolve'] = resolve;\n        deferred['reject'] = reject;\n      }, label);\n\n      return deferred;\n    }\n    var lib$rsvp$defer$$default = lib$rsvp$defer$$defer;\n    function lib$rsvp$filter$$filter(promises, filterFn, label) {\n      return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n        if (!lib$rsvp$utils$$isFunction(filterFn)) {\n          throw new TypeError(\"You must pass a function as filter's second argument.\");\n        }\n\n        var length = values.length;\n        var filtered = new Array(length);\n\n        for (var i = 0; i < length; i++) {\n          filtered[i] = filterFn(values[i]);\n        }\n\n        return lib$rsvp$promise$$default.all(filtered, label).then(function(filtered) {\n          var results = new Array(length);\n          var newLength = 0;\n\n          for (var i = 0; i < length; i++) {\n            if (filtered[i]) {\n              results[newLength] = values[i];\n              newLength++;\n            }\n          }\n\n          results.length = newLength;\n\n          return results;\n        });\n      });\n    }\n    var lib$rsvp$filter$$default = lib$rsvp$filter$$filter;\n\n    function lib$rsvp$promise$hash$$PromiseHash(Constructor, object, label) {\n      this._superConstructor(Constructor, object, true, label);\n    }\n\n    var lib$rsvp$promise$hash$$default = lib$rsvp$promise$hash$$PromiseHash;\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n    lib$rsvp$promise$hash$$PromiseHash.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$promise$hash$$PromiseHash.prototype._init = function() {\n      this._result = {};\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._validateInput = function(input) {\n      return input && typeof input === 'object';\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._validationError = function() {\n      return new Error('Promise.hash must be called with an object');\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._enumerate = function() {\n      var enumerator = this;\n      var promise    = enumerator.promise;\n      var input      = enumerator._input;\n      var results    = [];\n\n      for (var key in input) {\n        if (promise._state === lib$rsvp$$internal$$PENDING && Object.prototype.hasOwnProperty.call(input, key)) {\n          results.push({\n            position: key,\n            entry: input[key]\n          });\n        }\n      }\n\n      var length = results.length;\n      enumerator._remaining = length;\n      var result;\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        result = results[i];\n        enumerator._eachEntry(result.entry, result.position);\n      }\n    };\n\n    function lib$rsvp$hash$settled$$HashSettled(Constructor, object, label) {\n      this._superConstructor(Constructor, object, false, label);\n    }\n\n    lib$rsvp$hash$settled$$HashSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$promise$hash$$default.prototype);\n    lib$rsvp$hash$settled$$HashSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$hash$settled$$HashSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n\n    lib$rsvp$hash$settled$$HashSettled.prototype._validationError = function() {\n      return new Error('hashSettled must be called with an object');\n    };\n\n    function lib$rsvp$hash$settled$$hashSettled(object, label) {\n      return new lib$rsvp$hash$settled$$HashSettled(lib$rsvp$promise$$default, object, label).promise;\n    }\n    var lib$rsvp$hash$settled$$default = lib$rsvp$hash$settled$$hashSettled;\n    function lib$rsvp$hash$$hash(object, label) {\n      return new lib$rsvp$promise$hash$$default(lib$rsvp$promise$$default, object, label).promise;\n    }\n    var lib$rsvp$hash$$default = lib$rsvp$hash$$hash;\n    function lib$rsvp$map$$map(promises, mapFn, label) {\n      return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n        if (!lib$rsvp$utils$$isFunction(mapFn)) {\n          throw new TypeError(\"You must pass a function as map's second argument.\");\n        }\n\n        var length = values.length;\n        var results = new Array(length);\n\n        for (var i = 0; i < length; i++) {\n          results[i] = mapFn(values[i]);\n        }\n\n        return lib$rsvp$promise$$default.all(results, label);\n      });\n    }\n    var lib$rsvp$map$$default = lib$rsvp$map$$map;\n\n    function lib$rsvp$node$$Result() {\n      this.value = undefined;\n    }\n\n    var lib$rsvp$node$$ERROR = new lib$rsvp$node$$Result();\n    var lib$rsvp$node$$GET_THEN_ERROR = new lib$rsvp$node$$Result();\n\n    function lib$rsvp$node$$getThen(obj) {\n      try {\n       return obj.then;\n      } catch(error) {\n        lib$rsvp$node$$ERROR.value= error;\n        return lib$rsvp$node$$ERROR;\n      }\n    }\n\n\n    function lib$rsvp$node$$tryApply(f, s, a) {\n      try {\n        f.apply(s, a);\n      } catch(error) {\n        lib$rsvp$node$$ERROR.value = error;\n        return lib$rsvp$node$$ERROR;\n      }\n    }\n\n    function lib$rsvp$node$$makeObject(_, argumentNames) {\n      var obj = {};\n      var name;\n      var i;\n      var length = _.length;\n      var args = new Array(length);\n\n      for (var x = 0; x < length; x++) {\n        args[x] = _[x];\n      }\n\n      for (i = 0; i < argumentNames.length; i++) {\n        name = argumentNames[i];\n        obj[name] = args[i + 1];\n      }\n\n      return obj;\n    }\n\n    function lib$rsvp$node$$arrayResult(_) {\n      var length = _.length;\n      var args = new Array(length - 1);\n\n      for (var i = 1; i < length; i++) {\n        args[i - 1] = _[i];\n      }\n\n      return args;\n    }\n\n    function lib$rsvp$node$$wrapThenable(then, promise) {\n      return {\n        then: function(onFulFillment, onRejection) {\n          return then.call(promise, onFulFillment, onRejection);\n        }\n      };\n    }\n\n    function lib$rsvp$node$$denodeify(nodeFunc, options) {\n      var fn = function() {\n        var self = this;\n        var l = arguments.length;\n        var args = new Array(l + 1);\n        var arg;\n        var promiseInput = false;\n\n        for (var i = 0; i < l; ++i) {\n          arg = arguments[i];\n\n          if (!promiseInput) {\n            // TODO: clean this up\n            promiseInput = lib$rsvp$node$$needsPromiseInput(arg);\n            if (promiseInput === lib$rsvp$node$$GET_THEN_ERROR) {\n              var p = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n              lib$rsvp$$internal$$reject(p, lib$rsvp$node$$GET_THEN_ERROR.value);\n              return p;\n            } else if (promiseInput && promiseInput !== true) {\n              arg = lib$rsvp$node$$wrapThenable(promiseInput, arg);\n            }\n          }\n          args[i] = arg;\n        }\n\n        var promise = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n\n        args[l] = function(err, val) {\n          if (err)\n            lib$rsvp$$internal$$reject(promise, err);\n          else if (options === undefined)\n            lib$rsvp$$internal$$resolve(promise, val);\n          else if (options === true)\n            lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$arrayResult(arguments));\n          else if (lib$rsvp$utils$$isArray(options))\n            lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$makeObject(arguments, options));\n          else\n            lib$rsvp$$internal$$resolve(promise, val);\n        };\n\n        if (promiseInput) {\n          return lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self);\n        } else {\n          return lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self);\n        }\n      };\n\n      fn.__proto__ = nodeFunc;\n\n      return fn;\n    }\n\n    var lib$rsvp$node$$default = lib$rsvp$node$$denodeify;\n\n    function lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self) {\n      var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n      if (result === lib$rsvp$node$$ERROR) {\n        lib$rsvp$$internal$$reject(promise, result.value);\n      }\n      return promise;\n    }\n\n    function lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self){\n      return lib$rsvp$promise$$default.all(args).then(function(args){\n        var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n        if (result === lib$rsvp$node$$ERROR) {\n          lib$rsvp$$internal$$reject(promise, result.value);\n        }\n        return promise;\n      });\n    }\n\n    function lib$rsvp$node$$needsPromiseInput(arg) {\n      if (arg && typeof arg === 'object') {\n        if (arg.constructor === lib$rsvp$promise$$default) {\n          return true;\n        } else {\n          return lib$rsvp$node$$getThen(arg);\n        }\n      } else {\n        return false;\n      }\n    }\n    var lib$rsvp$platform$$platform;\n\n    /* global self */\n    if (typeof self === 'object') {\n      lib$rsvp$platform$$platform = self;\n\n    /* global global */\n    } else if (typeof global === 'object') {\n      lib$rsvp$platform$$platform = global;\n    } else {\n      throw new Error('no global: `self` or `global` found');\n    }\n\n    var lib$rsvp$platform$$default = lib$rsvp$platform$$platform;\n    function lib$rsvp$race$$race(array, label) {\n      return lib$rsvp$promise$$default.race(array, label);\n    }\n    var lib$rsvp$race$$default = lib$rsvp$race$$race;\n    function lib$rsvp$reject$$reject(reason, label) {\n      return lib$rsvp$promise$$default.reject(reason, label);\n    }\n    var lib$rsvp$reject$$default = lib$rsvp$reject$$reject;\n    function lib$rsvp$resolve$$resolve(value, label) {\n      return lib$rsvp$promise$$default.resolve(value, label);\n    }\n    var lib$rsvp$resolve$$default = lib$rsvp$resolve$$resolve;\n    function lib$rsvp$rethrow$$rethrow(reason) {\n      setTimeout(function() {\n        throw reason;\n      });\n      throw reason;\n    }\n    var lib$rsvp$rethrow$$default = lib$rsvp$rethrow$$rethrow;\n\n    // defaults\n    lib$rsvp$config$$config.async = lib$rsvp$asap$$default;\n    lib$rsvp$config$$config.after = function(cb) {\n      setTimeout(cb, 0);\n    };\n    var lib$rsvp$$cast = lib$rsvp$resolve$$default;\n    function lib$rsvp$$async(callback, arg) {\n      lib$rsvp$config$$config.async(callback, arg);\n    }\n\n    function lib$rsvp$$on() {\n      lib$rsvp$config$$config['on'].apply(lib$rsvp$config$$config, arguments);\n    }\n\n    function lib$rsvp$$off() {\n      lib$rsvp$config$$config['off'].apply(lib$rsvp$config$$config, arguments);\n    }\n\n    // Set up instrumentation through `window.__PROMISE_INTRUMENTATION__`\n    if (typeof window !== 'undefined' && typeof window['__PROMISE_INSTRUMENTATION__'] === 'object') {\n      var lib$rsvp$$callbacks = window['__PROMISE_INSTRUMENTATION__'];\n      lib$rsvp$config$$configure('instrument', true);\n      for (var lib$rsvp$$eventName in lib$rsvp$$callbacks) {\n        if (lib$rsvp$$callbacks.hasOwnProperty(lib$rsvp$$eventName)) {\n          lib$rsvp$$on(lib$rsvp$$eventName, lib$rsvp$$callbacks[lib$rsvp$$eventName]);\n        }\n      }\n    }\n\n    var lib$rsvp$umd$$RSVP = {\n      'race': lib$rsvp$race$$default,\n      'Promise': lib$rsvp$promise$$default,\n      'allSettled': lib$rsvp$all$settled$$default,\n      'hash': lib$rsvp$hash$$default,\n      'hashSettled': lib$rsvp$hash$settled$$default,\n      'denodeify': lib$rsvp$node$$default,\n      'on': lib$rsvp$$on,\n      'off': lib$rsvp$$off,\n      'map': lib$rsvp$map$$default,\n      'filter': lib$rsvp$filter$$default,\n      'resolve': lib$rsvp$resolve$$default,\n      'reject': lib$rsvp$reject$$default,\n      'all': lib$rsvp$all$$default,\n      'rethrow': lib$rsvp$rethrow$$default,\n      'defer': lib$rsvp$defer$$default,\n      'EventTarget': lib$rsvp$events$$default,\n      'configure': lib$rsvp$config$$configure,\n      'async': lib$rsvp$$async\n    };\n\n    /* global define:true module:true window: true */\n    if (typeof define === 'function' && define['amd']) {\n      define(function() { return lib$rsvp$umd$$RSVP; });\n    } else if (typeof module !== 'undefined' && module['exports']) {\n      module['exports'] = lib$rsvp$umd$$RSVP;\n    } else if (typeof lib$rsvp$platform$$default !== 'undefined') {\n      lib$rsvp$platform$$default['RSVP'] = lib$rsvp$umd$$RSVP;\n    }\n}).call(this);\n\n"]}\n"],"file":"algorithm_visualizer.js","sourceRoot":"/source/"} \ No newline at end of file diff --git a/public/algorithm_visualizer.min.js b/public/algorithm_visualizer.min.js index 4617281..129fe1a 100644 --- a/public/algorithm_visualizer.min.js +++ b/public/algorithm_visualizer.min.js @@ -1,4 +1,4 @@ -!function t(e,r,n){function o(a,s){if(!r[a]){if(!e[a]){var c="function"==typeof require&&require;if(!s&&c)return c(a,!0);if(i)return i(a,!0);var u=new Error("Cannot find module '"+a+"'");throw u.code="MODULE_NOT_FOUND",u}var l=r[a]={exports:{}};e[a][0].call(l.exports,function(t){var r=e[a][1][t];return o(r?r:t)},l,l.exports,t,e,r,n)}return r[a].exports}for(var i="function"==typeof require&&require,a=0;a<n.length;a++)o(n[a]);return o}({1:[function(t,e,r){"use strict";var n=$,o=n.extend,i={lastFileUsed:"",files:{}},a=function(t){if(!t)throw"Missing file name"};e.exports={getCachedFile:function(t){return a(t),i.files[t]},updateCachedFile:function(t,e){a(t),i.files[t]||(i.files[t]={}),o(i.files[t],e)},getLastFileUsed:function(){return i.lastFileUsed},setLastFileUsed:function(t){i.lastFileUsed=t}}},{}],2:[function(t,e,r){"use strict";var n=t("../editor"),o=t("../tracer_manager"),i=t("../dom/setup"),a=t("../dom/loading_slider"),s=a.showLoadingSlider,c=a.hideLoadingSlider,u=t("./cache"),l={isLoading:null,editor:null,tracerManager:null,categories:null,loadedScratch:null,wikiList:null},f=function(t){l.isLoading=!1,l.editor=new n(t),l.tracerManager=t,l.categories={},l.loadedScratch=null,l.wikiList=[]},p=function(){this.getIsLoading=function(){return l.isLoading},this.setIsLoading=function(t){l.isLoading=t,t?s():c()},this.getEditor=function(){return l.editor},this.getCategories=function(){return l.categories},this.getCategory=function(t){return l.categories[t]},this.setCategories=function(t){l.categories=t},this.updateCategory=function(t,e){$.extend(l.categories[t],e)},this.getTracerManager=function(){return l.tracerManager},this.getLoadedScratch=function(){return l.loadedScratch},this.setLoadedScratch=function(t){l.loadedScratch=t},this.getWikiList=function(){return l.wikiList},this.setWikiList=function(t){l.wikiList=t},this.hasWiki=function(t){return~l.wikiList.indexOf(t)};var t=o.init();f(t),i.setup(t)};p.prototype=u,e.exports=p},{"../dom/loading_slider":7,"../dom/setup":9,"../editor":28,"../tracer_manager":64,"./cache":1}],3:[function(t,e,r){"use strict";e.exports={}},{}],4:[function(t,e,r){"use strict";var n=t("../app"),o=t("../server"),i=t("./show_algorithm"),a=$,s=a.each,c=function(t,e,r){return $('<button class="indent">').append(e[r]).attr("data-algorithm",r).attr("data-category",t).click(function(){o.loadAlgorithm(t,r).then(function(e){i(t,r,e)})})},u=function(t){var e=n.getCategory(t),r=e.name,o=e.list,i=$('<button class="category">').append('<i class="fa fa-fw fa-caret-right">').append(r).attr("data-category",t);i.click(function(){var t=$(this);t.toggleClass("open"),t.next().toggleClass("collapse"),t.find("i.fa").toggleClass("fa-caret-right fa-caret-down")});var a=$('<div class="algorithms collapse">');$("#list").append(i).append(a),s(o,function(e){var r=c(t,o,e);a.append(r)})};e.exports=function(){s(n.getCategories(),u)}},{"../app":3,"../server":56,"./show_algorithm":19}],5:[function(t,e,r){"use strict";var n=t("../server"),o=$,i=o.each,a=function(t,e,r,o){var i=$("<button>").append(r).attr("data-file",r).click(function(){n.loadFile(t,e,r,o),$(".files_bar > .wrapper > button").removeClass("active"),$(this).addClass("active")});return $(".files_bar > .wrapper").append(i),i};e.exports=function(t,e,r,n){$(".files_bar > .wrapper").empty(),i(r,function(r,o){var i=a(t,e,r,o);n&&n==r&&i.click()}),n||$(".files_bar > .wrapper > button").first().click(),$(".files_bar > .wrapper").scroll()}},{"../server":56}],6:[function(t,e,r){"use strict";var n=t("./show_algorithm"),o=t("./add_categories"),i=t("./show_description"),a=t("./add_files"),s=t("./show_first_algorithm"),c=t("./show_requested_algorithm"),u=t("./show_wiki");e.exports={showAlgorithm:n,addCategories:o,showDescription:i,addFiles:a,showFirstAlgorithm:s,showRequestedAlgorithm:c,showWiki:u}},{"./add_categories":4,"./add_files":5,"./show_algorithm":19,"./show_description":20,"./show_first_algorithm":21,"./show_requested_algorithm":22,"./show_wiki":23}],7:[function(t,e,r){"use strict";var n=function(){$("#loading-slider").removeClass("loaded")},o=function(){$("#loading-slider").addClass("loaded")};e.exports={showLoadingSlider:n,hideLoadingSlider:o}},{}],8:[function(t,e,r){"use strict";var n=function(){var t=$('<section class="module_wrapper">');return $(".module_container").append(t),t};e.exports={create:n}},{}],9:[function(t,e,r){"use strict";var n=t("./setup_dividers"),o=t("./setup_document"),i=t("./setup_files_bar"),a=t("./setup_interval"),s=t("./setup_module_container"),c=t("./setup_tab_container"),u=t("./setup_side_menu"),l=t("./setup_top_menu"),f=t("./setup_window"),p=function(){$(".btn input").click(function(t){t.stopPropagation()}),n(),o(),i(),a(),s(),c(),u(),l(),f()};e.exports={setup:p}},{"./setup_dividers":10,"./setup_document":11,"./setup_files_bar":12,"./setup_interval":13,"./setup_module_container":14,"./setup_side_menu":15,"./setup_tab_container":16,"./setup_top_menu":17,"./setup_window":18}],10:[function(t,e,r){"use strict";var n=function(){function t(t,e){var r=[],n=!0,o=!1,i=void 0;try{for(var a,s=t[Symbol.iterator]();!(n=(a=s.next()).done)&&(r.push(a.value),!e||r.length!==e);n=!0);}catch(c){o=!0,i=c}finally{try{!n&&s["return"]&&s["return"]()}finally{if(o)throw i}}return r}return function(e,r){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e))return t(e,r);throw new TypeError("Invalid attempt to destructure non-iterable instance")}}(),o=t("../../app"),i=function(t){var e=n(t,3),r=e[0],i=e[1],a=e[2],s=i.parent(),c=5,u=$('<div class="divider">'),l=!1;r?!function(){u.addClass("vertical");var t=-c/2;u.css({top:0,bottom:0,left:t,width:c});var e=void 0;u.mousedown(function(t){var r=t.pageX;e=r,l=!0}),$(document).mousemove(function(t){var r=t.pageX;if(l){var n=a.position().left+r-e,c=n/s.width()*100;c=Math.min(90,Math.max(10,c)),i.css("right",100-c+"%"),a.css("left",c+"%"),e=r,o.getTracerManager().resize(),$(".files_bar > .wrapper").scroll()}}),$(document).mouseup(function(t){l=!1})}():!function(){u.addClass("horizontal");var t=-c/2;u.css({top:t,height:c,left:0,right:0});var e=void 0;u.mousedown(function(t){var r=t.pageY;e=r,l=!0}),$(document).mousemove(function(t){var r=t.pageY;if(l){var n=a.position().top+r-e,c=n/s.height()*100;c=Math.min(90,Math.max(10,c)),i.css("bottom",100-c+"%"),a.css("top",c+"%"),e=r,o.getTracerManager().resize()}}),$(document).mouseup(function(t){l=!1})}(),a.append(u)};e.exports=function(){for(var t=[["v",$(".sidemenu"),$(".workspace")],["v",$(".viewer_container"),$(".editor_container")],["h",$(".data_container"),$(".code_container")]],e=0;e<t.length;e++)i(t[e])}},{"../../app":3}],11:[function(t,e,r){"use strict";var n=t("../../app");e.exports=function(){$(document).on("click","a",function(t){var e=$(this).attr("href");/^(https?:\/\/).+/.test(e)&&(t.preventDefault(),window.open(e,"_blank")||alert("Please allow popups for this site"))}),$(document).mouseup(function(t){n.getTracerManager().command("mouseup",t)})}},{"../../app":3}],12:[function(t,e,r){"use strict";var n=function(t,e){return t>e+2};e.exports=function(){$(".files_bar > .btn-left").click(function(){var t=$(".files_bar > .wrapper"),e=t.width(),r=t.scrollLeft();$(t.children("button").get().reverse()).each(function(){var n=$(this).position().left,o=n+$(this).outerWidth();return 0>n?(t.scrollLeft(r+o-e),!1):void 0})}),$(".files_bar > .btn-right").click(function(){var t=$(".files_bar > .wrapper"),e=t.width(),r=t.scrollLeft();t.children("button").each(function(){var n=$(this).position().left,o=n+$(this).outerWidth();return o>e?(t.scrollLeft(r+n),!1):void 0})}),$(".files_bar > .wrapper").scroll(function(){var t=$(".files_bar > .wrapper"),e=t.width(),r=t.children("button:first-child"),o=t.children("button:last-child"),i=r.position().left,a=o.position().left+o.outerWidth();if(n(0,i)&&n(e,a)){var s=t.scrollLeft();return void t.scrollLeft(s+e-a)}var c=n(0,i),u=n(a,e);t.toggleClass("shadow-left",c),t.toggleClass("shadow-right",u),$(".files_bar > .btn-left").attr("disabled",!c),$(".files_bar > .btn-right").attr("disabled",!u)})}},{}],13:[function(t,e,r){"use strict";var n=function(){function t(t,e){var r=[],n=!0,o=!1,i=void 0;try{for(var a,s=t[Symbol.iterator]();!(n=(a=s.next()).done)&&(r.push(a.value),!e||r.length!==e);n=!0);}catch(c){o=!0,i=c}finally{try{!n&&s["return"]&&s["return"]()}finally{if(o)throw i}}return r}return function(e,r){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e))return t(e,r);throw new TypeError("Invalid attempt to destructure non-iterable instance")}}(),o=t("../../app"),i=t("../toast"),a=Number.parseFloat,s=.1,c=10,u=.5,l=.1,f=function(t){var e=void 0,r=void 0;return s>t?(e=s,r="Interval of "+t+" seconds is too low. Setting to min allowed interval of "+s+" second(s)."):t>c?(e=c,r="Interval of "+t+" seconds is too high. Setting to max allowed interval of "+c+" second(s)."):(e=t,r="Interval has been set to "+t+" second(s)."),[e,r]};e.exports=function(){var t=$("#interval");t.val(u),t.attr({max:c,min:s,step:l}),$("#interval").on("change",function(){var t=o.getTracerManager(),e=f(a($(this).val())),r=n(e,2),s=r[0],c=r[1];$(this).val(s),t.interval=1e3*s,i.showInfoToast(c)})}},{"../../app":3,"../toast":24}],14:[function(t,e,r){"use strict";var n=t("../../app");e.exports=function(){var t=$(".module_container");t.on("mousedown",".module_wrapper",function(t){n.getTracerManager().findOwner(this).mousedown(t)}),t.on("mousemove",".module_wrapper",function(t){n.getTracerManager().findOwner(this).mousemove(t)}),t.on("DOMMouseScroll mousewheel",".module_wrapper",function(t){n.getTracerManager().findOwner(this).mousewheel(t)})}},{"../../app":3}],15:[function(t,e,r){"use strict";var n=t("../../app"),o=t("../../server"),i=t("../show_algorithm"),a=void 0;e.exports=function(){$("#navigation").click(function(){var t=$(".sidemenu"),e=$(".workspace");t.toggleClass("active"),$(".nav-dropdown").toggleClass("fa-caret-down fa-caret-up"),t.hasClass("active")?(t.css("right",100-a+"%"),e.css("left",a+"%")):(a=e.position().left/$("body").width()*100,t.css("right",0),e.css("left",0)),n.getTracerManager().resize()}),$("#documentation").click(function(){$("#btn_doc").click()}),$("#powered-by").click(function(){$("#powered-by-list button").toggleClass("collapse")}),$("#scratch-paper").click(function(){var t="scratch",e=n.getLoadedScratch();o.loadAlgorithm(t,e).then(function(r){i(t,e,r)})})}},{"../../app":3,"../../server":56,"../show_algorithm":19}],16:[function(t,e,r){"use strict";e.exports=function(){$(".tab_bar > button").click(function(){$(".tab_bar > button").removeClass("active"),$(".tab_container > .tab").removeClass("active"),$(this).addClass("active"),$($(this).attr("data-target")).addClass("active")})}},{}],17:[function(t,e,r){"use strict";var n=t("../../app"),o=t("../../server"),i=t("../toast"),a=t("../top_menu");e.exports=function(){$("#shared").mouseup(function(){$(this).select()}),$("#btn_share").click(function(){var t=$(this).find(".fa-share");t.addClass("fa-spin fa-spin-faster"),o.shareScratchPaper().then(function(e){t.removeClass("fa-spin fa-spin-faster"),$("#shared").removeClass("collapse"),$("#shared").val(e),i.showInfoToast("Shareable link is created.")})});var t=$("#btn_run"),e=$("#btn_trace"),r=$("#btn_pause"),s=$("#btn_prev"),c=$("#btn_next");a.disableFlowControl(),t.click(function(){e.click(),r.removeClass("active"),t.addClass("active"),a.enableFlowControl();var o=n.getEditor().execute();o&&(console.error(o),i.showErrorToast(o),a.resetTopMenuButtons())}),r.click(function(){t.toggleClass("active"),r.toggleClass("active"),n.getTracerManager().isPause()?n.getTracerManager().resumeStep():n.getTracerManager().pauseStep()}),s.click(function(){t.removeClass("active"),r.addClass("active"),n.getTracerManager().pauseStep(),n.getTracerManager().prevStep()}),c.click(function(){t.removeClass("active"),r.addClass("active"),n.getTracerManager().pauseStep(),n.getTracerManager().nextStep()})}},{"../../app":3,"../../server":56,"../toast":24,"../top_menu":25}],18:[function(t,e,r){"use strict";var n=t("../../app");e.exports=function(){$(window).resize(function(){n.getTracerManager().resize()})}},{"../../app":3}],19:[function(t,e,r){"use strict";var n=t("../app"),o=t("../utils"),i=o.isScratchPaper,a=t("./show_description"),s=t("./add_files");e.exports=function(t,e,r,o){var c=void 0,u=void 0,l=void 0;if(i(t))c=$("#scratch-paper"),u="Scratch Paper",l=e?"Shared":"Temporary";else{c=$('[data-category="'+t+'"][data-algorithm="'+e+'"]');var f=n.getCategory(t);u=f.name,l=f.list[e]}$(".sidemenu button").removeClass("active"),c.addClass("active"),$("#category").html(u),$("#algorithm").html(l),$("#tab_desc > .wrapper").empty(),$(".files_bar > .wrapper").empty(),$("#explanation").html(""),n.setLastFileUsed(null),n.getEditor().clearContent();var p=r.files;delete r.files,a(r),s(t,e,p,o)}},{"../app":3,"../utils":70,"./add_files":5,"./show_description":20}],20:[function(t,e,r){"use strict";var n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol?"symbol":typeof t},o=Array.isArray,i=$,a=i.each;e.exports=function(t){var e=$("#tab_desc > .wrapper");e.empty(),a(t,function(t,r){t&&e.append($("<h3>").html(t)),"string"==typeof r?e.append($("<p>").html(r)):o(r)?!function(){var t=$('<ul class="applications">');e.append(t),r.forEach(function(e){t.append($("<li>").html(e))})}():"object"===("undefined"==typeof r?"undefined":n(r))&&!function(){var t=$('<ul class="complexities">');e.append(t),a(r,function(e){var n=$('<div class="complexity">'),o=$('<span class="complexity-type">').html(e+": "),i=$('<span class="complexity-value">').html(""+r[e]);n.append(o).append(i),t.append($("<li>").append(n))})}()})}},{}],21:[function(t,e,r){"use strict";e.exports=function(){$("#list .category").first().click(),$("#list .category + .algorithms > .indent").first().click()}},{}],22:[function(t,e,r){"use strict";var n=t("../server"),o=t("./show_algorithm");e.exports=function(t,e,r){$('.category[data-category="'+t+'"]').click(),n.loadAlgorithm(t,e).then(function(n){o(t,e,n,r)})}},{"../server":56,"./show_algorithm":19}],23:[function(t,e,r){"use strict";var n=t("../app"),o=t("../server"),i=new showdown.Converter({tables:!0});e.exports=function(t){o.loadWiki(t).then(function(r){$("#tab_doc > .wrapper").html(i.makeHtml("#"+t+"\n"+r)),$("#tab_doc").scrollTop(0),$("#tab_doc > .wrapper a").click(function(t){var r=$(this).attr("href");n.hasWiki(r)&&(t.preventDefault(),e.exports(r))})})}},{"../app":3,"../server":56}],24:[function(t,e,r){"use strict";var n=function(t,e){var r=$('<div class="toast '+e+'">').append(t);$(".toast_container").append(r),setTimeout(function(){r.fadeOut(function(){r.remove()})},3e3)},o=function(t){n(t,"error")},i=function(t){n(t,"info")};e.exports={showErrorToast:o,showInfoToast:i}},{}],25:[function(t,e,r){"use strict";var n=t("../app"),o=[$("#btn_pause"),$("#btn_prev"),$("#btn_next")],i=function(t){o.forEach(function(e){return e.attr("disabled",t)})},a=function(){i(!1)},s=function(){i(!0)},c=function(){$(".top-menu-buttons button").removeClass("active"),s(),n.getEditor().unhighlightLine()},u=function(t){$("#interval").val(interval)},l=function(){$("#btn_pause").addClass("active")},f=function(){$("#btn_pause").removeClass("active")};e.exports={enableFlowControl:a,disableFlowControl:s,resetTopMenuButtons:c,setInterval:u,activateBtnPause:l,deactivateBtnPause:f}},{"../app":3}],26:[function(t,e,r){"use strict";e.exports=function(t){var e=ace.edit(t);return e.setOptions({enableBasicAutocompletion:!0,enableSnippets:!0,enableLiveAutocompletion:!0}),e.setTheme("ace/theme/tomorrow_night_eighties"),e.session.setMode("ace/mode/javascript"),e.$blockScrolling=1/0,e}},{}],27:[function(require,module,exports){"use strict";var execute=function execute(tracerManager,code,dataLines){try{!function(){tracerManager.deallocateAll();var lines=code.split("\n"),newLines=[];lines.forEach(function(t,e){newLines.push(t.replace(/(.+\. *_wait *)(\( *\))/g,"$1("+(e-dataLines)+")"))}),eval(newLines.join("\n")),tracerManager.visualize()}()}catch(err){return err}finally{tracerManager.removeUnallocated()}},executeData=function(t,e){return execute(t,e)},executeDataAndCode=function(t,e,r){var n=e.split("\n").length;return execute(t,e+"\n"+r,n)};module.exports={executeData:executeData,executeDataAndCode:executeDataAndCode}},{}],28:[function(t,e,r){"use strict";function n(t){var e=this;if(!t)throw"Cannot create Editor. Missing the tracerManager";ace.require("ace/ext/language_tools");var r=ace.require("ace/range").Range;this.dataEditor=i("data"),this.codeEditor=i("code"),this.setData=function(t){e.dataEditor.setValue(t,-1)},this.setCode=function(t){e.codeEditor.setValue(t,-1)},this.setContent=function(t){var r=t.data,n=t.code;e.setData(r),e.setCode(n)},this.clearData=function(){e.dataEditor.setValue("")},this.clearCode=function(){e.codeEditor.setValue("")},this.clearContent=function(){e.clearData(),e.clearCode()},this.execute=function(){var r=e.dataEditor.getValue(),n=e.codeEditor.getValue();return a.executeDataAndCode(t,r,n)},this.highlightLine=function(t){var n=e.codeEditor.getSession();e.marker&&n.removeMarker(e.marker),e.marker=n.addMarker(new r(t,0,t,1/0),"executing","line",!0)},this.unhighlightLine=function(){var t=e.codeEditor.getSession();e.marker&&t.removeMarker(e.marker)},this.dataEditor.on("change",function(){var r=e.dataEditor.getValue(),n=o.getLastFileUsed();n&&o.updateCachedFile(n,{data:r}),a.executeData(t,r),s.resetTopMenuButtons()}),this.codeEditor.on("change",function(){var r=e.codeEditor.getValue(),n=o.getLastFileUsed();n&&o.updateCachedFile(n,{code:r}),t.reset(),s.resetTopMenuButtons()})}var o=t("../app"),i=t("./create"),a=t("./executor"),s=t("../dom/top_menu");e.exports=n},{"../app":3,"../dom/top_menu":25,"./create":26,"./executor":27}],29:[function(t,e,r){"use strict";var n=t("rsvp"),o=t("./app"),i=t("./app/constructor"),a=t("./dom"),s=t("./server"),c=t("./module"),u=$,l=u.extend;$.ajaxSetup({cache:!1,dataType:"text"});var f=t("./utils"),p=f.isScratchPaper,h=t("./server/helpers"),d=h.getPath;n.on("error",function(t){console.assert(!1,t)}),$(function(){var t=new i;l(!0,o,t),l(!0,window,c),s.loadCategories().then(function(t){o.setCategories(t),a.addCategories();var e=d(),r=e.category,n=e.algorithm,i=e.file;p(r)?n?s.loadScratchPaper(n).then(function(t){var e=t.category,r=t.algorithm,n=t.data;a.showAlgorithm(e,r,n)}):s.loadAlgorithm(r).then(function(t){a.showAlgorithm(r,null,t)}):r&&n?a.showRequestedAlgorithm(r,n,i):a.showFirstAlgorithm()}),s.loadWikiList().then(function(t){o.setWikiList(t.wikis),a.showWiki("Tracer")})})},{"./app":3,"./app/constructor":2,"./dom":6,"./module":39,"./server":56,"./server/helpers":55,"./utils":70,rsvp:72}],30:[function(t,e,r){"use strict";var n=t("./array2d"),o=function(t,e,r){return n.random(1,t,e,r)[0]},i=function(t,e,r){return n.randomSorted(1,t,e,r)[0]};e.exports={random:o,randomSorted:i}},{"./array2d":31}],31:[function(t,e,r){"use strict";var n=t("./integer"),o=function(t,e,r,o){t||(t=10),e||(e=10),void 0===r&&(r=1),void 0===o&&(o=9);for(var i=[],a=0;t>a;a++){i.push([]);for(var s=0;e>s;s++)i[a].push(n.random(r,o))}return i},i=function(t,e,r,n){return o(t,e,r,n).map(function(t){return t.sort(function(t,e){return t-e})})};e.exports={random:o,randomSorted:i}},{"./integer":35}],32:[function(t,e,r){"use strict";var n=t("./integer"),o=function(t,e,r){t||(t=7),e||(e=1),r||(r=10);for(var o=new Array(t),i=0;t>i;i++)o[i]=new Array(2);for(var i=0;t>i;i++)for(var a=0;a<o[i].length;a++)o[i][a]=n.random(e,r);return o};e.exports={random:o}},{"./integer":35}],33:[function(t,e,r){"use strict";var n=function(t,e){t||(t=5),e||(e=.3);for(var r=new Array(t),n=0;t>n;n++){r[n]=new Array(t);for(var o=0;t>o;o++)n!=o&&(r[n][o]=0==(Math.random()*(1/e)|0)?1:0)}return r};e.exports={random:n}},{}],34:[function(t,e,r){"use strict";var n=t("./integer"),o=t("./array1d"),i=t("./array2d"),a=t("./coordinate_system"),s=t("./directed_graph"),c=t("./undirected_graph"),u=t("./weighted_directed_graph"),l=t("./weighted_undirected_graph");e.exports={Integer:n,Array1D:o,Array2D:i,CoordinateSystem:a,DirectedGraph:s,UndirectedGraph:c,WeightedDirectedGraph:u,WeightedUndirectedGraph:l}},{"./array1d":30,"./array2d":31,"./coordinate_system":32,"./directed_graph":33,"./integer":35,"./undirected_graph":36,"./weighted_directed_graph":37,"./weighted_undirected_graph":38}],35:[function(t,e,r){"use strict";var n=function(t,e){return(Math.random()*(e-t+1)|0)+t};e.exports={random:n}},{}],36:[function(t,e,r){"use strict";var n=function(t,e){t||(t=5),e||(e=.3);for(var r=new Array(t),n=0;t>n;n++)r[n]=new Array(t);for(var n=0;t>n;n++)for(var o=0;t>o;o++)n>o&&(r[n][o]=r[o][n]=0==(Math.random()*(1/e)|0)?1:0);return r};e.exports={random:n}},{}],37:[function(t,e,r){"use strict";var n=t("./integer"),o=function(t,e,r,o){t||(t=5),e||(e=.3),r||(r=1),o||(o=5);for(var i=new Array(t),a=0;t>a;a++){i[a]=new Array(t);for(var s=0;t>s;s++)a!=s&&0==(Math.random()*(1/e)|0)&&(i[a][s]=n.random(r,o))}return i};e.exports={random:o}},{"./integer":35}],38:[function(t,e,r){"use strict";var n=t("./integer"),o=function(t,e,r,o){t||(t=5),e||(e=.3),r||(r=1),o||(o=5);for(var i=new Array(t),a=0;t>a;a++)i[a]=new Array(t);for(var a=0;t>a;a++)for(var s=0;t>s;s++)a>s&&0==(Math.random()*(1/e)|0)&&(i[a][s]=i[s][a]=n.random(r,o));return i};e.exports={random:o}},{"./integer":35}],39:[function(t,e,r){"use strict";var n=t("./tracer"),o=t("./data"),i=$,a=i.extend;e.exports=a(!0,{},n,o)},{"./data":34,"./tracer":45}],40:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function i(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var a=function l(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:l(o,e,r)}if("value"in n)return n.value;var i=n.get;if(void 0!==i)return i.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./array2d"),u=function(t){function e(t){return n(this,e),o(this,Object.getPrototypeOf(e).call(this,t))}return i(e,t),s(e,null,[{key:"getClassName",value:function(){return"Array1DTracer"}}]),s(e,[{key:"_notify",value:function(t,r){return a(Object.getPrototypeOf(e.prototype),"_notify",this).call(this,0,t,r),this}},{key:"_denotify",value:function(t){return a(Object.getPrototypeOf(e.prototype),"_denotify",this).call(this,0,t),this}},{key:"_select",value:function(t,r){return void 0===r?a(Object.getPrototypeOf(e.prototype),"_select",this).call(this,0,t):a(Object.getPrototypeOf(e.prototype),"_selectRow",this).call(this,0,t,r),this}},{key:"_deselect",value:function(t,r){return void 0===r?a(Object.getPrototypeOf(e.prototype),"_deselect",this).call(this,0,t):a(Object.getPrototypeOf(e.prototype),"_deselectRow",this).call(this,0,t,r),this}},{key:"processStep",value:function(t,r){if(a(Object.getPrototypeOf(e.prototype),"processStep",this).call(this,t,r),this.chartTracer){var n=$.extend(!0,{},t);n.capsule=this.chartTracer.capsule,n.s=n.sy,n.e=n.ey,void 0===n.s&&(n.s=n.y),delete n.x,delete n.y,delete n.sx,delete n.sy,delete n.ex,delete n.ey,this.chartTracer.processStep(n,r)}}},{key:"setData",value:function(t){return a(Object.getPrototypeOf(e.prototype),"setData",this).call(this,[t])}}]),e}(c);e.exports=u},{"./array2d":41}],41:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function i(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var a=function h(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:h(o,e,r)}if("value"in n)return n.value;var i=n.get;if(void 0!==i)return i.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./tracer"),u=t("../../tracer_manager/util/index"),l=u.refineByType,f=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.colorClass={selected:"selected",notified:"notified"},r.isNew&&p(r),r}return i(e,t),s(e,null,[{key:"getClassName",value:function(){return"Array2DTracer"}}]),s(e,[{key:"_notify",value:function(t,e,r){return this.manager.pushStep(this.capsule,{type:"notify",x:t,y:e,v:r}),this}},{key:"_denotify",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"denotify",x:t,y:e}),this}},{key:"_select",value:function(t,e,r,n){return this.pushSelectingStep("select",null,arguments),this}},{key:"_selectRow",value:function(t,e,r){return this.pushSelectingStep("select","row",arguments),this}},{key:"_selectCol",value:function(t,e,r){return this.pushSelectingStep("select","col",arguments),this}},{key:"_deselect",value:function(t,e,r,n){return this.pushSelectingStep("deselect",null,arguments),this}},{key:"_deselectRow",value:function(t,e,r){return this.pushSelectingStep("deselect","row",arguments),this}},{key:"_deselectCol",value:function(t,e,r){return this.pushSelectingStep("deselect","col",arguments),this}},{key:"_separate",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"separate",x:t,y:e}),this}},{key:"_separateRow",value:function(t){return this._separate(t,-1),this}},{key:"_separateCol",value:function(t){return this._separate(-1,t),this}},{key:"_deseparate",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"deseparate",x:t,y:e}),this}},{key:"_deseparateRow",value:function(t){return this._deseparate(t,-1),this}},{key:"_deseparateCol",value:function(t){return this._deseparate(-1,t),this}},{key:"pushSelectingStep",value:function(){var t=Array.prototype.slice.call(arguments),e=t.shift(),r=t.shift();t=Array.prototype.slice.call(t.shift());var n;switch(r){case"row":n={x:t[0],sy:t[1],ey:t[2]};break;case"col":n={y:t[0],sx:t[1],ex:t[2]};break;default:n=void 0===t[2]&&void 0===t[3]?{x:t[0],y:t[1]}:{sx:t[0],sy:t[1],ex:t[2],ey:t[3]}}var o={type:e};$.extend(o,n),this.manager.pushStep(this.capsule,o)}},{key:"processStep",value:function(t,r){switch(t.type){case"notify":if(void 0!==t.v){var n=this.$table.find(".mtbl-row").eq(t.x),o=n.find(".mtbl-col").eq(t.y);o.text(l(t.v))}case"denotify":case"select":case"deselect":var i="select"==t.type||"deselect"==t.type?this.colorClass.selected:this.colorClass.notified,s="select"==t.type||"notify"==t.type,c=t.sx,u=t.sy,f=t.ex,p=t.ey;void 0===c&&(c=t.x),void 0===u&&(u=t.y),void 0===f&&(f=t.x),void 0===p&&(p=t.y),this.paintColor(c,u,f,p,i,s);break;case"separate":this.deseparate(t.x,t.y),this.separate(t.x,t.y);break;case"deseparate":this.deseparate(t.x,t.y);break;default:a(Object.getPrototypeOf(e.prototype),"processStep",this).call(this,t,r)}}},{key:"setData",value:function(t){if(this.viewX=this.viewY=0,this.paddingH=6,this.paddingV=3,this.fontSize=16,a(Object.getPrototypeOf(e.prototype),"setData",this).apply(this,arguments))return this.$table.find(".mtbl-row").each(function(e){$(this).find(".mtbl-col").each(function(r){$(this).text(l(t[e][r]))})}),!0;this.$table.empty();for(var r=0;r<t.length;r++){var n=$('<div class="mtbl-row">');this.$table.append(n);for(var o=0;o<t[r].length;o++){var i=$('<div class="mtbl-col">').css(this.getCellCss()).text(l(t[r][o]));n.append(i)}}return this.resize(),!1}},{key:"resize",value:function(){a(Object.getPrototypeOf(e.prototype),"resize",this).call(this),this.refresh()}},{key:"clear",value:function(){a(Object.getPrototypeOf(e.prototype),"clear",this).call(this),this.clearColor(),this.deseparateAll()}},{key:"getCellCss",value:function(){return{padding:this.paddingV.toFixed(1)+"px "+this.paddingH.toFixed(1)+"px","font-size":this.fontSize.toFixed(1)+"px"}}},{key:"refresh",value:function(){a(Object.getPrototypeOf(e.prototype),"refresh",this).call(this);var t=this.$table.parent(),r=t.height()/2-this.$table.height()/2+this.viewY,n=t.width()/2-this.$table.width()/2+this.viewX;this.$table.css("margin-top",r),this.$table.css("margin-left",n)}},{key:"mousedown",value:function(t){a(Object.getPrototypeOf(e.prototype),"mousedown",this).call(this,t),this.dragX=t.pageX,this.dragY=t.pageY,this.dragging=!0}},{key:"mousemove",value:function(t){a(Object.getPrototypeOf(e.prototype),"mousemove",this).call(this,t),this.dragging&&(this.viewX+=t.pageX-this.dragX,this.viewY+=t.pageY-this.dragY,this.dragX=t.pageX,this.dragY=t.pageY,this.refresh())}},{key:"mouseup",value:function(t){a(Object.getPrototypeOf(e.prototype),"mouseup",this).call(this,t),this.dragging=!1}},{key:"mousewheel",value:function(t){a(Object.getPrototypeOf(e.prototype),"mousewheel",this).call(this,t),t.preventDefault(),t=t.originalEvent;var r=void 0!==t.wheelDelta&&t.wheelDelta||void 0!==t.detail&&-t.detail,n=1.01,o=r>0?1/n:n;this.fontSize<4&&1>o||this.fontSize>40&&o>1||(this.paddingV*=o,this.paddingH*=o,this.fontSize*=o,this.$table.find(".mtbl-col").css(this.getCellCss()),this.refresh())}},{key:"paintColor",value:function(t,e,r,n,o,i){for(var a=t;r>=a;a++)for(var s=this.$table.find(".mtbl-row").eq(a),c=e;n>=c;c++){var u=s.find(".mtbl-col").eq(c);i?u.addClass(o):u.removeClass(o)}}},{key:"clearColor",value:function(){this.$table.find(".mtbl-col").removeClass(Object.keys(this.colorClass).join(" "))}},{key:"separate",value:function(t,e){this.$table.find(".mtbl-row").each(function(r){var n=$(this);r==t&&n.after($('<div class="mtbl-empty-row">').attr("data-row",r)),n.find(".mtbl-col").each(function(t){var r=$(this);t==e&&r.after($('<div class="mtbl-empty-col">').attr("data-col",t))})})}},{key:"deseparate",value:function(t,e){this.$table.find("[data-row="+t+"]").remove(),this.$table.find("[data-col="+e+"]").remove()}},{key:"deseparateAll",value:function(){this.$table.find(".mtbl-empty-row, .mtbl-empty-col").remove()}}]),e}(c),p=function(t){t.$table=t.capsule.$table=$('<div class="mtbl-table">'),t.$container.append(t.$table)};e.exports=f},{"../../tracer_manager/util/index":67,"./tracer":47}],42:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function i(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var a=function f(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:f(o,e,r)}if("value"in n)return n.value;var i=n.get;if(void 0!==i)return i.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n); -}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./tracer"),u=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.color={selected:"rgb(0, 0, 255)",notified:"rgb(255, 0, 0)","default":"rgb(136, 136, 136)"},r.isNew&&l(r),r}return i(e,t),s(e,null,[{key:"getClassName",value:function(){return"ChartTracer"}}]),s(e,[{key:"setData",value:function(t){if(a(Object.getPrototypeOf(e.prototype),"setData",this).apply(this,arguments))return this.chart.config.data.datasets[0].data=t,this.chart.update(),!0;for(var r=[],n=0;n<t.length;n++)r.push(this.color["default"]);this.chart.config.data={labels:t.map(String),datasets:[{backgroundColor:r,data:t}]},this.chart.update()}},{key:"_notify",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"notify",s:t,v:e}),this}},{key:"_denotify",value:function(t){return this.manager.pushStep(this.capsule,{type:"denotify",s:t}),this}},{key:"_select",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"select",s:t,e:e}),this}},{key:"_deselect",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"deselect",s:t,e:e}),this}},{key:"processStep",value:function(t,r){switch(t.type){case"notify":void 0!==t.v&&(this.chart.config.data.datasets[0].data[t.s]=t.v,this.chart.config.data.labels[t.s]=t.v.toString());case"denotify":case"select":case"deselect":var n="notify"==t.type?this.color.notified:"select"==t.type?this.color.selected:this.color["default"];if(void 0!==t.e)for(var o=t.s;o<=t.e;o++)this.chart.config.data.datasets[0].backgroundColor[o]=n;else this.chart.config.data.datasets[0].backgroundColor[t.s]=n;this.chart.update();break;default:a(Object.getPrototypeOf(e.prototype),"processStep",this).call(this,t,r)}}},{key:"resize",value:function(){a(Object.getPrototypeOf(e.prototype),"resize",this).call(this),this.chart.resize()}},{key:"clear",value:function(){a(Object.getPrototypeOf(e.prototype),"clear",this).call(this);var t=this.chart.config.data;if(t.datasets.length){for(var r=t.datasets[0].backgroundColor,n=0;n<r.length;n++)r[n]=this.color["default"];this.chart.update()}}}]),e}(c),l=function(t){t.$wrapper=t.capsule.$wrapper=$('<canvas class="mchrt-chart">'),t.$container.append(t.$wrapper),t.chart=t.capsule.chart=new Chart(t.$wrapper,{type:"bar",data:{labels:[],datasets:[]},options:{scales:{yAxes:[{ticks:{beginAtZero:!0}}]},animation:!1,legend:!1,responsive:!0,maintainAspectRatio:!1}})};e.exports=u},{"./tracer":47}],43:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function i(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var a=function f(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:f(o,e,r)}if("value"in n)return n.value;var i=n.get;if(void 0!==i)return i.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./directed_graph"),u=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.isNew&&l(r),r}return i(e,t),s(e,null,[{key:"getClassName",value:function(){return"CoordinateSystemTracer"}}]),s(e,[{key:"setData",value:function(t){if(Tracer.prototype.setData.apply(this,arguments))return!0;this.graph.clear();for(var e=[],r=[],n=0;n<t.length;n++)e.push({id:this.n(n),x:t[n][0],y:t[n][1],label:""+n,size:1,color:this.color["default"]});return this.graph.read({nodes:e,edges:r}),this.s.camera.goTo({x:0,y:0,angle:0,ratio:1}),this.refresh(),!1}},{key:"processStep",value:function(t,r){switch(t.type){case"visit":case"leave":var n="visit"==t.type,o=this.graph.nodes(this.n(t.target)),i=n?this.color.visited:this.color.left;if(o.color=i,void 0!==t.source){var s=this.e(t.source,t.target);if(this.graph.edges(s)){var c=this.graph.edges(s);c.color=i,this.graph.dropEdge(s).addEdge(c)}else this.graph.addEdge({id:this.e(t.target,t.source),source:this.n(t.source),target:this.n(t.target),color:i,size:1})}if(this.logTracer){var u=t.source;void 0===u&&(u=""),this.logTracer.print(n?u+" -> "+t.target:u+" <- "+t.target)}break;default:a(Object.getPrototypeOf(e.prototype),"processStep",this).call(this,t,r)}}},{key:"e",value:function(t,e){if(t>e){var r=t;t=e,e=r}return"e"+t+"_"+e}},{key:"drawOnHover",value:function(t,e,r,n){var o=this;e.setLineDash([5,5]);var i=t.id.substring(1);this.graph.edges().forEach(function(a){var s=a.id.substring(1).split("_");if(s[0]==i){var c="#0ff",u=t,l=o.graph.nodes("n"+s[1]);o.drawEdge(a,u,l,c,e,r),n&&n(a,u,l,c,e,r)}else if(s[1]==i){var c="#0ff",u=o.graph.nodes("n"+s[0]),l=t;o.drawEdge(a,u,l,c,e,r),n&&n(a,u,l,c,e,r)}})}},{key:"drawEdge",value:function(t,e,r,n,o,i){var a=i("prefix")||"",s=t[a+"size"]||1;o.strokeStyle=n,o.lineWidth=s,o.beginPath(),o.moveTo(e[a+"x"],e[a+"y"]),o.lineTo(r[a+"x"],r[a+"y"]),o.stroke()}}]),e}(c),l=function(t){t.s.settings({defaultEdgeType:"def",funcEdgesDef:function(e,r,n,o,i){var a=t.getColor(e,r,n,i);t.drawEdge(e,r,n,a,o,i)}})};e.exports=u},{"./directed_graph":44}],44:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function i(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var a=function h(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:h(o,e,r)}if("value"in n)return n.value;var i=n.get;if(void 0!==i)return i.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./tracer"),u=t("../../tracer_manager/util/index"),l=u.refineByType,f=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.color={selected:"#0f0",visited:"#f00",left:"#000","default":"#888"},r.isNew&&p(r),r}return i(e,t),s(e,null,[{key:"getClassName",value:function(){return"DirectedGraphTracer"}}]),s(e,[{key:"_setTreeData",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"setTreeData",arguments:arguments}),this}},{key:"_visit",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"visit",target:t,source:e}),this}},{key:"_leave",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"leave",target:t,source:e}),this}},{key:"processStep",value:function(t,r){switch(t.type){case"setTreeData":this.setTreeData.apply(this,t.arguments);break;case"visit":case"leave":var n="visit"==t.type,o=this.graph.nodes(this.n(t.target)),i=n?this.color.visited:this.color.left;if(o.color=i,void 0!==t.source){var s=this.e(t.source,t.target),c=this.graph.edges(s);c.color=i,this.graph.dropEdge(s).addEdge(c)}if(this.logTracer){var u=t.source;void 0===u&&(u=""),this.logTracer.print(n?u+" -> "+t.target:u+" <- "+t.target)}break;default:a(Object.getPrototypeOf(e.prototype),"processStep",this).call(this,t,r)}}},{key:"setTreeData",value:function(t,e,r){var n=this;e=e||0;var o=-1,i=new Array(t.length),a=function l(e,r){if(i[e])throw"the given graph is not a tree because it forms a circuit";i[e]=!0,r>o&&(o=r);for(var n=0;n<t[e].length;n++)t[e][n]&&l(n,r+1)};if(a(e,1),this.setData(t,r))return!0;var s=function(t,e,r){var o=n.graph.nodes(n.n(t));o.x=e,o.y=r},c=1/(o-1),u=function f(e,r,n,o){s(e,n+o,r*c);for(var i=0,a=0;a<t[e].length;a++)t[e][a]&&i++;for(var u=(o-n)/i,l=0,a=0;a<t[e].length;a++)t[e][a]&&f(a,r+1,n+u*l,n+u*++l)};u(e,0,0,1),this.refresh()}},{key:"setData",value:function(t,r){if(a(Object.getPrototypeOf(e.prototype),"setData",this).apply(this,arguments))return!0;this.graph.clear();for(var n=[],o=[],i=2*Math.PI/t.length,s=0,c=0;c<t.length;c++)if(s+=i,n.push({id:this.n(c),label:""+c,x:.5+Math.sin(s)/2,y:.5+Math.cos(s)/2,size:1,color:this.color["default"],weight:0}),r)for(var u=0;c>=u;u++){var f=t[c][u]||t[u][c];f&&o.push({id:this.e(c,u),source:this.n(c),target:this.n(u),color:this.color["default"],size:1,weight:l(f)})}else for(var p=0;p<t[c].length;p++)t[c][p]&&o.push({id:this.e(c,p),source:this.n(c),target:this.n(p),color:this.color["default"],size:1,weight:l(t[c][p])});return this.graph.read({nodes:n,edges:o}),this.s.camera.goTo({x:0,y:0,angle:0,ratio:1}),this.refresh(),!1}},{key:"resize",value:function(){a(Object.getPrototypeOf(e.prototype),"resize",this).call(this),this.s.renderers[0].resize(),this.refresh()}},{key:"refresh",value:function(){a(Object.getPrototypeOf(e.prototype),"refresh",this).call(this),this.s.refresh()}},{key:"clear",value:function(){a(Object.getPrototypeOf(e.prototype),"clear",this).call(this),this.clearGraphColor(),this.refresh()}},{key:"clearGraphColor",value:function(){var t=this;this.graph.nodes().forEach(function(e){e.color=t.color["default"]}),this.graph.edges().forEach(function(e){e.color=t.color["default"]})}},{key:"n",value:function(t){return"n"+t}},{key:"e",value:function(t,e){return"e"+t+"_"+e}},{key:"getColor",value:function(t,e,r,n){var o=t.color,i=n("edgeColor"),a=n("defaultNodeColor"),s=n("defaultEdgeColor");if(!o)switch(i){case"source":o=e.color||a;break;case"target":o=r.color||a;break;default:o=s}return o}},{key:"drawLabel",value:function(t,e,r){var n,o=r("prefix")||"",i=t[o+"size"];i<r("labelThreshold")||t.label&&"string"==typeof t.label&&(n="fixed"===r("labelSize")?r("defaultLabelSize"):r("labelSizeRatio")*i,e.font=(r("fontStyle")?r("fontStyle")+" ":"")+n+"px "+r("font"),e.fillStyle="node"===r("labelColor")?t.color||r("defaultNodeColor"):r("defaultLabelColor"),e.textAlign="center",e.fillText(t.label,Math.round(t[o+"x"]),Math.round(t[o+"y"]+n/3)))}},{key:"drawArrow",value:function(t,e,r,n,o,i){var a=i("prefix")||"",s=t[a+"size"]||1,c=r[a+"size"],u=e[a+"x"],l=e[a+"y"],f=r[a+"x"],p=r[a+"y"],h=Math.atan2(p-l,f-u),d=3;u+=Math.sin(h)*d,f+=Math.sin(h)*d,l+=-Math.cos(h)*d,p+=-Math.cos(h)*d;var v=Math.max(2.5*s,i("minArrowSize")),g=Math.sqrt(Math.pow(f-u,2)+Math.pow(p-l,2)),y=u+(f-u)*(g-v-c)/g,m=l+(p-l)*(g-v-c)/g,b=(f-u)*v/g,w=(p-l)*v/g;o.strokeStyle=n,o.lineWidth=s,o.beginPath(),o.moveTo(u,l),o.lineTo(y,m),o.stroke(),o.fillStyle=n,o.beginPath(),o.moveTo(y+b,m+w),o.lineTo(y+.6*w,m-.6*b),o.lineTo(y-.6*w,m+.6*b),o.lineTo(y+b,m+w),o.closePath(),o.fill()}},{key:"drawOnHover",value:function(t,e,r,n){var o=this;e.setLineDash([5,5]);var i=t.id.substring(1);this.graph.edges().forEach(function(a){var s=a.id.substring(1).split("_");if(s[0]==i){var c="#0ff",u=t,l=o.graph.nodes("n"+s[1]);o.drawArrow(a,u,l,c,e,r),n&&n(a,u,l,c,e,r)}else if(s[1]==i){var c="#ff0",u=o.graph.nodes("n"+s[0]),l=t;o.drawArrow(a,u,l,c,e,r),n&&n(a,u,l,c,e,r)}})}}]),e}(c),p=function(t){t.s=t.capsule.s=new sigma({renderer:{container:t.$container[0],type:"canvas"},settings:{minArrowSize:8,defaultEdgeType:"arrow",maxEdgeSize:2.5,labelThreshold:4,font:"Roboto",defaultLabelColor:"#fff",zoomMin:.6,zoomMax:1.2,skipErrors:!0,minNodeSize:.5,maxNodeSize:12,labelSize:"proportional",labelSizeRatio:1.3,funcLabelsDef:function(e,r,n){t.drawLabel(e,r,n)},funcHoversDef:function(e,r,n,o){t.drawOnHover(e,r,n,o)},funcEdgesArrow:function(e,r,n,o,i){var a=t.getColor(e,r,n,i);t.drawArrow(e,r,n,a,o,i)}}}),sigma.plugins.dragNodes(t.s,t.s.renderers[0]),t.graph=t.capsule.graph=t.s.graph};sigma.canvas.labels.def=function(t,e,r){var n=r("funcLabelsDef");n&&n(t,e,r)},sigma.canvas.hovers.def=function(t,e,r){var n=r("funcHoversDef");n&&n(t,e,r)},sigma.canvas.edges.def=function(t,e,r,n,o){var i=o("funcEdgesDef");i&&i(t,e,r,n,o)},sigma.canvas.edges.arrow=function(t,e,r,n,o){var i=o("funcEdgesArrow");i&&i(t,e,r,n,o)},e.exports=f},{"../../tracer_manager/util/index":67,"./tracer":47}],45:[function(t,e,r){"use strict";var n=t("./tracer"),o=t("./log"),i=t("./array1d"),a=t("./array2d"),s=t("./chart"),c=t("./coordinate_system"),u=t("./directed_graph"),l=t("./undirected_graph"),f=t("./weighted_directed_graph"),p=t("./weighted_undirected_graph");e.exports={Tracer:n,LogTracer:o,Array1DTracer:i,Array2DTracer:a,ChartTracer:s,CoordinateSystemTracer:c,DirectedGraphTracer:u,UndirectedGraphTracer:l,WeightedDirectedGraphTracer:f,WeightedUndirectedGraphTracer:p}},{"./array1d":40,"./array2d":41,"./chart":42,"./coordinate_system":43,"./directed_graph":44,"./log":46,"./tracer":47,"./undirected_graph":48,"./weighted_directed_graph":49,"./weighted_undirected_graph":50}],46:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function i(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var a=function f(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:f(o,e,r)}if("value"in n)return n.value;var i=n.get;if(void 0!==i)return i.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./tracer"),u=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.isNew&&l(r),r}return i(e,t),s(e,null,[{key:"getClassName",value:function(){return"LogTracer"}}]),s(e,[{key:"_print",value:function(t){return this.manager.pushStep(this.capsule,{type:"print",msg:t}),this}},{key:"processStep",value:function(t,e){switch(t.type){case"print":this.print(t.msg)}}},{key:"refresh",value:function(){this.scrollToEnd(Math.min(50,this.interval))}},{key:"clear",value:function(){a(Object.getPrototypeOf(e.prototype),"clear",this).call(this),this.$wrapper.empty()}},{key:"print",value:function(t){this.$wrapper.append($("<span>").append(t+"<br/>"))}},{key:"scrollToEnd",value:function(t){this.$container.animate({scrollTop:this.$container[0].scrollHeight},t)}}]),e}(c),l=function(t){t.$wrapper=t.capsule.$wrapper=$('<div class="wrapper">'),t.$container.append(t.$wrapper)};e.exports=u},{"./tracer":47}],47:[function(t,e,r){"use strict";function n(t){if(Array.isArray(t)){for(var e=0,r=Array(t.length);e<t.length;e++)r[e]=t[e];return r}return Array.from(t)}function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}var i=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),a=t("../../app"),s=t("../../tracer_manager/util/index"),c=s.toJSON,u=s.fromJSON,l=function(){function t(e){o(this,t),this.module=this.constructor,this.manager=a.getTracerManager(),this.capsule=this.manager.allocate(this),$.extend(this,this.capsule),this.setName(e)}return i(t,null,[{key:"getClassName",value:function(){return"Tracer"}}]),i(t,[{key:"_setData",value:function(){for(var t=arguments.length,e=Array(t),r=0;t>r;r++)e[r]=arguments[r];return this.manager.pushStep(this.capsule,{type:"setData",args:c(e)}),this}},{key:"_clear",value:function(){return this.manager.pushStep(this.capsule,{type:"clear"}),this}},{key:"_wait",value:function(t){return this.manager.newStep(t),this}},{key:"processStep",value:function(t,e){var r=t.type,o=t.args;switch(r){case"setData":this.setData.apply(this,n(u(o)));break;case"clear":this.clear()}}},{key:"setName",value:function(t){var e=void 0;this.isNew?(e=$('<span class="name">'),this.$container.append(e)):e=this.$container.find("span.name"),e.text(t||this.defaultName)}},{key:"setData",value:function(){var t=c(arguments);return this.isNew||this.lastData!==t?(this.lastData=this.capsule.lastData=t,!1):!0}},{key:"resize",value:function(){}},{key:"refresh",value:function(){}},{key:"clear",value:function(){}},{key:"attach",value:function(t){switch(t.module){case LogTracer:this.logTracer=t;break;case ChartTracer:this.chartTracer=t}return this}},{key:"mousedown",value:function(t){}},{key:"mousemove",value:function(t){}},{key:"mouseup",value:function(t){}},{key:"mousewheel",value:function(t){}}]),t}();e.exports=l},{"../../app":3,"../../tracer_manager/util/index":67}],48:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function i(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var a=function f(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:f(o,e,r)}if("value"in n)return n.value;var i=n.get;if(void 0!==i)return i.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./directed_graph"),u=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.isNew&&l(r),r}return i(e,t),s(e,null,[{key:"getClassName",value:function(){return"UndirectedGraphTracer"}}]),s(e,[{key:"setTreeData",value:function(t,r){return a(Object.getPrototypeOf(e.prototype),"setTreeData",this).call(this,t,r,!0)}},{key:"setData",value:function(t){return a(Object.getPrototypeOf(e.prototype),"setData",this).call(this,t,!0)}},{key:"e",value:function(t,e){if(t>e){var r=t;t=e,e=r}return"e"+t+"_"+e}},{key:"drawOnHover",value:function(t,e,r,n){var o=this;e.setLineDash([5,5]);var i=t.id.substring(1);this.graph.edges().forEach(function(a){var s=a.id.substring(1).split("_");if(s[0]==i){var c="#0ff",u=t,l=o.graph.nodes("n"+s[1]);o.drawEdge(a,u,l,c,e,r),n&&n(a,u,l,c,e,r)}else if(s[1]==i){var c="#0ff",u=o.graph.nodes("n"+s[0]),l=t;o.drawEdge(a,u,l,c,e,r),n&&n(a,u,l,c,e,r)}})}},{key:"drawEdge",value:function(t,e,r,n,o,i){var a=i("prefix")||"",s=t[a+"size"]||1;o.strokeStyle=n,o.lineWidth=s,o.beginPath(),o.moveTo(e[a+"x"],e[a+"y"]),o.lineTo(r[a+"x"],r[a+"y"]),o.stroke()}}]),e}(c),l=function(t){t.s.settings({defaultEdgeType:"def",funcEdgesDef:function(e,r,n,o,i){var a=t.getColor(e,r,n,i);t.drawEdge(e,r,n,a,o,i)}})};e.exports=u},{"./directed_graph":44}],49:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function i(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var a=function h(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:h(o,e,r)}if("value"in n)return n.value;var i=n.get;if(void 0!==i)return i.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./directed_graph"),u=t("../../tracer_manager/util/index"),l=u.refineByType,f=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.isNew&&p(r),r}return i(e,t),s(e,null,[{key:"getClassName",value:function(){return"WeightedDirectedGraphTracer"}}]),s(e,[{key:"_weight",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"weight",target:t,weight:e}),this}},{key:"_visit",value:function(t,e,r){return this.manager.pushStep(this.capsule,{type:"visit",target:t,source:e,weight:r}),this}},{key:"_leave",value:function(t,e,r){return this.manager.pushStep(this.capsule,{type:"leave",target:t,source:e,weight:r}),this}},{key:"processStep",value:function(t,r){switch(t.type){case"weight":var n=this.graph.nodes(this.n(t.target));void 0!==t.weight&&(n.weight=l(t.weight));break;case"visit":case"leave":var o="visit"==t.type,n=this.graph.nodes(this.n(t.target)),i=o?void 0===t.weight?this.color.selected:this.color.visited:this.color.left;if(n.color=i,void 0!==t.weight&&(n.weight=l(t.weight)),void 0!==t.source){var s=this.e(t.source,t.target),c=this.graph.edges(s);c.color=i,this.graph.dropEdge(s).addEdge(c)}if(this.logTracer){var u=t.source;void 0===u&&(u=""),this.logTracer.print(o?u+" -> "+t.target:u+" <- "+t.target)}break;default:a(Object.getPrototypeOf(e.prototype),"processStep",this).call(this,t,r)}}},{key:"clear",value:function(){a(Object.getPrototypeOf(e.prototype),"clear",this).call(this),this.clearWeights()}},{key:"clearWeights",value:function(){this.graph.nodes().forEach(function(t){t.weight=0})}},{key:"drawEdgeWeight",value:function(t,e,r,n,o,i){if(e!=r){var a=i("prefix")||"",s=t[a+"size"]||1;if(!(s<i("edgeLabelThreshold"))){if(0===i("edgeLabelSizePowRatio"))throw'"edgeLabelSizePowRatio" must not be 0.';var c,u=(e[a+"x"]+r[a+"x"])/2,l=(e[a+"y"]+r[a+"y"])/2,f=r[a+"x"]-e[a+"x"],p=r[a+"y"]-e[a+"y"],h=Math.atan2(p,f);c="fixed"===i("edgeLabelSize")?i("defaultEdgeLabelSize"):i("defaultEdgeLabelSize")*s*Math.pow(s,-1/i("edgeLabelSizePowRatio")),o.save(),t.active?(o.font=[i("activeFontStyle"),c+"px",i("activeFont")||i("font")].join(" "),o.fillStyle=n):(o.font=[i("fontStyle"),c+"px",i("font")].join(" "),o.fillStyle=n),o.textAlign="center",o.textBaseline="alphabetic",o.translate(u,l),o.rotate(h),o.fillText(t.weight,0,-s/2-3),o.restore()}}}},{key:"drawNodeWeight",value:function(t,e,r){var n,o=r("prefix")||"",i=t[o+"size"];i<r("labelThreshold")||(n="fixed"===r("labelSize")?r("defaultLabelSize"):r("labelSizeRatio")*i,e.font=(r("fontStyle")?r("fontStyle")+" ":"")+n+"px "+r("font"),e.fillStyle="node"===r("labelColor")?t.color||r("defaultNodeColor"):r("defaultLabelColor"),e.textAlign="left",e.fillText(t.weight,Math.round(t[o+"x"]+1.5*i),Math.round(t[o+"y"]+n/3)))}}]),e}(c),p=function(t){t.s.settings({edgeLabelSize:"proportional",defaultEdgeLabelSize:20,edgeLabelSizePowRatio:.8,funcLabelsDef:function(e,r,n){t.drawNodeWeight(e,r,n),t.drawLabel(e,r,n)},funcHoversDef:function(e,r,n){t.drawOnHover(e,r,n,t.drawEdgeWeight)},funcEdgesArrow:function(e,r,n,o,i){var a=t.getColor(e,r,n,i);t.drawArrow(e,r,n,a,o,i),t.drawEdgeWeight(e,r,n,a,o,i)}})};e.exports=f},{"../../tracer_manager/util/index":67,"./directed_graph":44}],50:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function i(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var a=function p(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:p(o,e,r)}if("value"in n)return n.value;var i=n.get;if(void 0!==i)return i.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./weighted_directed_graph"),u=t("./undirected_graph"),l=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.e=u.prototype.e,r.drawOnHover=u.prototype.drawOnHover,r.drawEdge=u.prototype.drawEdge,r.isNew&&f(r),r}return i(e,t),s(e,null,[{key:"getClassName",value:function(){return"WeightedUndirectedGraphTracer"}}]),s(e,[{key:"setTreeData",value:function(t,r){return a(Object.getPrototypeOf(e.prototype),"setTreeData",this).call(this,t,r,!0)}},{key:"setData",value:function(t){return a(Object.getPrototypeOf(e.prototype),"setData",this).call(this,t,!0)}},{key:"drawEdgeWeight",value:function(t,e,r,n,o,i){var a=i("prefix")||"";if(e[a+"x"]>r[a+"x"]){var s=e;e=r,r=s}c.prototype.drawEdgeWeight.call(this,t,e,r,n,o,i)}}]),e}(c),f=function(t){t.s.settings({defaultEdgeType:"def",funcEdgesDef:function(e,r,n,o,i){var a=t.getColor(e,r,n,i);t.drawEdge(e,r,n,a,o,i),t.drawEdgeWeight(e,r,n,a,o,i)}})};e.exports=l},{"./undirected_graph":48,"./weighted_directed_graph":49}],51:[function(t,e,r){"use strict";var n=t("./request");e.exports=function(t){return n(t,{type:"GET"})}},{"./request":54}],52:[function(t,e,r){"use strict";var n=t("./request");e.exports=function(t){return n(t,{dataType:"json",type:"GET"})}},{"./request":54}],53:[function(t,e,r){"use strict";var n=t("./request");e.exports=function(t,e){return n(t,{dataType:"json",type:"POST",data:JSON.stringify(e)})}},{"./request":54}],54:[function(t,e,r){"use strict";var n=t("rsvp"),o=t("../../app"),i=$,a=i.ajax,s=i.extend,c={};e.exports=function(t){var e=arguments.length<=1||void 0===arguments[1]?{}:arguments[1];return o.setIsLoading(!0),new n.Promise(function(r,n){var i={success:function(t){o.setIsLoading(!1),r(t)},error:function(t){o.setIsLoading(!1),n(t)}},u=s({},c,e,i,{url:t});a(u)})}},{"../../app":3,rsvp:72}],55:[function(t,e,r){"use strict";var n=function(){function t(t,e){var r=[],n=!0,o=!1,i=void 0;try{for(var a,s=t[Symbol.iterator]();!(n=(a=s.next()).done)&&(r.push(a.value),!e||r.length!==e);n=!0);}catch(c){o=!0,i=c}finally{try{!n&&s["return"]&&s["return"]()}finally{if(o)throw i}}return r}return function(e,r){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e))return t(e,r);throw new TypeError("Invalid attempt to destructure non-iterable instance")}}(),o=t("../app"),i=t("../dom/toast"),a=function(){return o.getIsLoading()?(i.showErrorToast("Wait until it completes loading of previous file."),!0):!1},s=function(t){var e=window.location.href,r=new RegExp("[?&]"+t+"(=([^&#]*)|&|#|$)"),o=r.exec(e);if(!o||3!==o.length)return null;var i=n(o,3),a=i[2];return a},c=function(t){if(!t)return null;for(var e=window.location.hash.substr(1),r=e?e.split("&"):[],n=0;n<r.length;n++){var o=r[n].split("=");if(o[0]===t)return o[1]}return null},u=function(t,e){if(t&&e){for(var r=window.location.hash.substr(1),n=r?r.split("&"):[],o=!1,i=0;i<n.length&&!o;i++){var a=n[i].split("=");a[0]===t&&(a[1]=e,n[i]=a.join("="),o=!0)}o||n.push([t,e].join("="));var s=n.join("&");window.location.hash="#"+s}},l=function(t){if(t){for(var e=window.location.hash.substr(1),r=e?e.split("&"):[],n=0;n<r.length;n++){var o=r[n].split("=");if(o[0]===t){r.splice(n,1);break}}var i=r.join("&");window.location.hash="#"+i}},f=function(t,e,r){var n=t?t+(e?"/"+e+(r?"/"+r:""):""):"";u("path",n)},p=function(){var t=c("path");if(t){var e=t.split("/"),r=n(e,3),o=r[0],i=r[1],a=r[2];return{category:o,algorithm:i,file:a}}return!1};e.exports={checkLoading:a,getParameterByName:s,getHashValue:c,setHashValue:u,removeHashValue:l,setPath:f,getPath:p}},{"../app":3,"../dom/toast":24}],56:[function(t,e,r){"use strict";var n=t("./load_algorithm"),o=t("./load_categories"),i=t("./load_file"),a=t("./load_scratch_paper"),s=t("./share_scratch_paper"),c=t("./load_wiki_list"),u=t("./load_wiki");e.exports={loadAlgorithm:n,loadCategories:o,loadFile:i,loadScratchPaper:a,shareScratchPaper:s,loadWikiList:c,loadWiki:u}},{"./load_algorithm":57,"./load_categories":58,"./load_file":59,"./load_scratch_paper":60,"./load_wiki":61,"./load_wiki_list":62,"./share_scratch_paper":63}],57:[function(t,e,r){"use strict";var n=t("./ajax/get_json"),o=t("../utils"),i=o.getAlgorithmDir;e.exports=function(t,e){var r=i(t,e);return n(r+"desc.json")}},{"../utils":70,"./ajax/get_json":52}],58:[function(t,e,r){"use strict";var n=t("./ajax/get_json");e.exports=function(){return n("./algorithm/category.json")}},{"./ajax/get_json":52}],59:[function(t,e,r){"use strict";var n=t("rsvp"),o=t("../app"),i=t("../utils"),a=i.getFileDir,s=i.isScratchPaper,c=t("./helpers"),u=c.checkLoading,l=c.setPath,f=t("./ajax/get"),p=function(t){return n.hash({data:f(t+"data.js"),code:f(t+"code.js")})},h=function(t){return o.getEditor().clearContent(),p(t).then(function(e){o.updateCachedFile(t,e),o.getEditor().setContent(e)})},d=function(t){return t&&void 0!==t.data&&void 0!==t.code};e.exports=function(t,e,r,i){return new n.Promise(function(n,c){if(u())c();else{s(t)?l(t,o.getLoadedScratch()):l(t,e,r),$("#explanation").html(i);var f=a(t,e,r);o.setLastFileUsed(f);var p=o.getCachedFile(f);d(p)?(o.getEditor().setContent(p),n()):h(f).then(n,c)}})}},{"../app":3,"../utils":70,"./ajax/get":51,"./helpers":55,rsvp:72}],60:[function(t,e,r){"use strict";var n=t("rsvp"),o=t("../app"),i=t("../utils"),a=i.getFileDir,s=t("./ajax/get_json"),c=t("./load_algorithm"),u=function(t,e){return t[e+".js"].content};e.exports=function(t){return new n.Promise(function(e,r){o.setLoadedScratch(t),s("https://api.github.com/gists/"+t).then(function(r){var n=r.files,i="scratch",s=t;c(i,s).then(function(t){var r=u(n,"data"),c=u(n,"code"),l=a(i,s,"scratch_paper");o.updateCachedFile(l,{data:r,code:c,"CREDIT.md":"Shared by an anonymous user from http://parkjs814.github.io/AlgorithmVisualizer"}),e({category:i,algorithm:s,data:t})})})})}},{"../app":3,"../utils":70,"./ajax/get_json":52,"./load_algorithm":57,rsvp:72}],61:[function(t,e,r){"use strict";var n=t("./ajax/get");e.exports=function(t){return n("./AlgorithmVisualizer.wiki/"+t+".md")}},{"./ajax/get":51}],62:[function(t,e,r){"use strict";var n=t("./ajax/get_json");e.exports=function(){return n("./wiki.json")}},{"./ajax/get_json":52}],63:[function(t,e,r){"use strict";var n=t("rsvp"),o=t("../app"),i=t("./ajax/post_json"),a=t("./helpers"),s=a.setPath;e.exports=function(){return new n.Promise(function(t,e){var r=o.getEditor(),n=r.dataEditor,a=r.codeEditor,c={description:"temp","public":!0,files:{"data.js":{content:n.getValue()},"code.js":{content:a.getValue()}}};i("https://api.github.com/gists",c).then(function(e){var r=e.id;o.setLoadedScratch(r),s("scratch",r);var n=location,i=n.href;$("#algorithm").html("Shared"),t(i)})})}},{"../app":3,"./ajax/post_json":53,"./helpers":55,rsvp:72}],64:[function(t,e,r){"use strict"; -var n=t("./manager"),o=t("../module/tracer/tracer");e.exports={init:function(){var t=new n;return o.prototype.manager=t,t}}},{"../module/tracer/tracer":47,"./manager":65}],65:[function(t,e,r){"use strict";var n=t("../app"),o=t("../dom/module_container"),i=t("../dom/top_menu"),a=$,s=a.each,c=a.extend,u=a.grep,l=1e6,f=function(){this.timer=null,this.pause=!1,this.capsules=[],this.interval=500};f.prototype={add:function(t){var e=o.create(),r={module:t.module,tracer:t,allocated:!0,defaultName:null,$container:e,isNew:!0};return this.capsules.push(r),r},allocate:function(t){var e=null,r=0;s(this.capsules,function(n,o){return o.module!==t.module||(r++,o.allocated)?void 0:(o.tracer=t,o.allocated=!0,o.isNew=!1,e=o,!1)}),null===e&&(r++,e=this.add(t));var n=t.module.getClassName();return e.defaultName=n+" "+r,e.order=this.order++,e},deallocateAll:function(){this.order=0,this.reset(),s(this.capsules,function(t,e){e.allocated=!1})},removeUnallocated:function(){var t=!1;this.capsules=u(this.capsules,function(e){var r=!e.allocated;return(e.isNew||r)&&(t=!0),r&&e.$container.remove(),!r}),t&&this.place()},place:function(){var t=this.capsules;s(t,function(e,r){var n=100,o=100/t.length,i=o*r.order;r.$container.css({top:i+"%",width:n+"%",height:o+"%"}),r.tracer.resize()})},resize:function(){this.command("resize")},isPause:function(){return this.pause},setInterval:function(t){i.setInterval(t)},reset:function(){this.traces=[],this.traceIndex=-1,this.stepCnt=0,this.timer&&clearTimeout(this.timer),this.command("clear")},pushStep:function(t,e){if(this.stepCnt++>l)throw"Tracer's stack overflow";var r=this.traces.length;0==r&&(r+=this.newStep());var n=this.traces[r-1];n.push(c(e,{capsule:t}))},newStep:function(){var t=arguments.length<=0||void 0===arguments[0]?-1:arguments[0],e=this.traces.length;return e>0&&~t&&this.traces[e-1].push(t),this.traces.push([])},pauseStep:function(){this.traceIndex<0||(this.pause=!0,this.timer&&clearTimeout(this.timer),i.activateBtnPause())},resumeStep:function(){this.pause=!1,this.step(this.traceIndex+1),i.deactivateBtnPause()},step:function(t){var e=arguments.length<=1||void 0===arguments[1]?{}:arguments[1],r=this;if(!(isNaN(t)||t>=this.traces.length||0>t)){this.traceIndex=t;var o=this.traces[t];o.forEach(function(t){return"number"==typeof t?void n.getEditor().highlightLine(t):void t.capsule.tracer.processStep(t,e)}),e.virtual||this.command("refresh"),this.pause||(this.timer=setTimeout(function(){r.nextStep(e)||i.resetTopMenuButtons()},this.interval))}},prevStep:function(){var t=arguments.length<=0||void 0===arguments[0]?{}:arguments[0];this.command("clear");var e=this.traceIndex-1;if(0>e)return this.traceIndex=-1,this.command("refresh"),!1;for(var r=0;e>r;r++)this.step(r,c(t,{virtual:!0}));return this.step(e),!0},nextStep:function(){var t=arguments.length<=0||void 0===arguments[0]?{}:arguments[0],e=this.traceIndex+1;return e>=this.traces.length?(this.traceIndex=this.traces.length-1,!1):(this.step(e,t),!0)},visualize:function(){this.traceIndex=-1,this.resumeStep()},command:function(){for(var t=arguments.length,e=Array(t),r=0;t>r;r++)e[r]=arguments[r];var n=e.shift();s(this.capsules,function(t,r){r.allocated&&r.tracer.module.prototype[n].apply(r.tracer,e)})},findOwner:function(t){var e=null;return s(this.capsules,function(r,n){return n.$container[0]===t?(e=n,!1):void 0}),e.tracer}},e.exports=f},{"../app":3,"../dom/module_container":8,"../dom/top_menu":25}],66:[function(t,e,r){"use strict";var n=JSON.parse,o=function(t){return n(t,function(t,e){return"Infinity"===e?1/0:e})};e.exports=o},{}],67:[function(t,e,r){"use strict";var n=t("./to_json"),o=t("./from_json"),i=t("./refine_by_type");e.exports={toJSON:n,fromJSON:o,refineByType:i}},{"./from_json":66,"./refine_by_type":68,"./to_json":69}],68:[function(t,e,r){"use strict";var n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol?"symbol":typeof t},o=function(t){switch("undefined"==typeof t?"undefined":n(t)){case"number":return a(t);case"boolean":return s(t);default:return i(t)}},i=function(t){return""===t?" ":t},a=function(t){return t===1/0?"∞":t},s=function(t){return t?"T":"F"};e.exports=o},{}],69:[function(t,e,r){"use strict";var n=JSON.stringify,o=function(t){return n(t,function(t,e){return e===1/0?"Infinity":e})};e.exports=o},{}],70:[function(t,e,r){"use strict";var n=function(t,e){return"scratch"==t},o=function(t,e){return n(t)?"./algorithm/scratch_paper/":"./algorithm/"+t+"/"+e+"/"},i=function(t,e,r){return n(t)?"./algorithm/scratch_paper/":"./algorithm/"+t+"/"+e+"/"+r+"/"};e.exports={isScratchPaper:n,getAlgorithmDir:o,getFileDir:i}},{}],71:[function(t,e,r){function n(){l&&s&&(l=!1,s.length?u=s.concat(u):f=-1,u.length&&o())}function o(){if(!l){var t=setTimeout(n);l=!0;for(var e=u.length;e;){for(s=u,u=[];++f<e;)s&&s[f].run();f=-1,e=u.length}s=null,l=!1,clearTimeout(t)}}function i(t,e){this.fun=t,this.array=e}function a(){}var s,c=e.exports={},u=[],l=!1,f=-1;c.nextTick=function(t){var e=new Array(arguments.length-1);if(arguments.length>1)for(var r=1;r<arguments.length;r++)e[r-1]=arguments[r];u.push(new i(t,e)),1!==u.length||l||setTimeout(o,0)},i.prototype.run=function(){this.fun.apply(null,this.array)},c.title="browser",c.browser=!0,c.env={},c.argv=[],c.version="",c.versions={},c.on=a,c.addListener=a,c.once=a,c.off=a,c.removeListener=a,c.removeAllListeners=a,c.emit=a,c.binding=function(t){throw new Error("process.binding is not supported")},c.cwd=function(){return"/"},c.chdir=function(t){throw new Error("process.chdir is not supported")},c.umask=function(){return 0}},{}],72:[function(t,e,r){(function(r,n){(function(){"use strict";function o(t){return"function"==typeof t||"object"==typeof t&&null!==t}function i(t){return"function"==typeof t}function a(t){return"object"==typeof t&&null!==t}function s(){}function c(t,e){for(var r=0,n=t.length;n>r;r++)if(t[r]===e)return r;return-1}function u(t){var e=t._promiseCallbacks;return e||(e=t._promiseCallbacks={}),e}function l(t,e){return"onerror"===t?void jt.on("error",e):2!==arguments.length?jt[t]:void(jt[t]=e)}function f(){setTimeout(function(){for(var t,e=0;e<$t.length;e++){t=$t[e];var r=t.payload;r.guid=r.key+r.id,r.childGuid=r.key+r.childId,r.error&&(r.stack=r.error.stack),jt.trigger(t.name,t.payload)}$t.length=0},50)}function p(t,e,r){1===$t.push({name:t,payload:{key:e._guidKey,id:e._id,eventName:t,detail:e._result,childId:r&&r._id,label:e._label,timeStamp:kt(),error:jt["instrument-with-stack"]?new Error(e._label):null}})&&f()}function h(t,e,r){var n=this,o=n._state;if(o===It&&!t||o===Rt&&!e)return jt.instrument&&Tt("chained",n,n),n;n._onError=null;var i=new n.constructor(O,r),a=n._result;if(jt.instrument&&Tt("chained",n,i),o){var s=arguments[o-1];jt.async(function(){F(o,i,s,a)})}else L(n,i,t,e);return i}function d(t,e){var r=this;if(t&&"object"==typeof t&&t.constructor===r)return t;var n=new r(O,e);return E(n,t),n}function v(t,e,r){return t===It?{state:"fulfilled",value:r}:{state:"rejected",reason:r}}function g(t,e,r,n){this._instanceConstructor=t,this.promise=new t(O,n),this._abortOnReject=r,this._validateInput(e)?(this._input=e,this.length=e.length,this._remaining=e.length,this._init(),0===this.length?A(this.promise,this._result):(this.length=this.length||0,this._enumerate(),0===this._remaining&&A(this.promise,this._result))):D(this.promise,this._validationError())}function y(t,e){return new Pt(this,t,!0,e).promise}function m(t,e){function r(t){E(i,t)}function n(t){D(i,t)}var o=this,i=new o(O,e);if(!xt(t))return D(i,new TypeError("You must pass an array to race.")),i;for(var a=t.length,s=0;i._state===Ft&&a>s;s++)L(o.resolve(t[s]),void 0,r,n);return i}function b(t,e){var r=this,n=new r(O,e);return D(n,t),n}function w(){throw new TypeError("You must pass a resolver function as the first argument to the promise constructor")}function _(){throw new TypeError("Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.")}function x(t,e){this._id=zt++,this._label=e,this._state=void 0,this._result=void 0,this._subscribers=[],jt.instrument&&Tt("created",this),O!==t&&("function"!=typeof t&&w(),this instanceof x?I(this,t):_())}function k(){return new TypeError("A promises callback cannot return that same promise.")}function O(){}function S(t){try{return t.then}catch(e){return Wt.error=e,Wt}}function j(t,e,r,n){try{t.call(e,r,n)}catch(o){return o}}function $(t,e,r){jt.async(function(t){var n=!1,o=j(r,e,function(r){n||(n=!0,e!==r?E(t,r,void 0):A(t,r))},function(e){n||(n=!0,D(t,e))},"Settle: "+(t._label||" unknown promise"));!n&&o&&(n=!0,D(t,o))},t)}function T(t,e){e._state===It?A(t,e._result):e._state===Rt?(e._onError=null,D(t,e._result)):L(e,void 0,function(r){e!==r?E(t,r,void 0):A(t,r)},function(e){D(t,e)})}function C(t,e,r){e.constructor===t.constructor&&r===Ct&&constructor.resolve===Et?T(t,e):r===Wt?D(t,Wt.error):void 0===r?A(t,e):i(r)?$(t,e,r):A(t,e)}function E(t,e){t===e?A(t,e):o(e)?C(t,e,S(e)):A(t,e)}function P(t){t._onError&&t._onError(t._result),M(t)}function A(t,e){t._state===Ft&&(t._result=e,t._state=It,0===t._subscribers.length?jt.instrument&&Tt("fulfilled",t):jt.async(M,t))}function D(t,e){t._state===Ft&&(t._state=Rt,t._result=e,jt.async(P,t))}function L(t,e,r,n){var o=t._subscribers,i=o.length;t._onError=null,o[i]=e,o[i+It]=r,o[i+Rt]=n,0===i&&t._state&&jt.async(M,t)}function M(t){var e=t._subscribers,r=t._state;if(jt.instrument&&Tt(r===It?"fulfilled":"rejected",t),0!==e.length){for(var n,o,i=t._result,a=0;a<e.length;a+=3)n=e[a],o=e[a+r],n?F(r,n,o,i):o(i);t._subscribers.length=0}}function z(){this.error=null}function N(t,e){try{return t(e)}catch(r){return qt.error=r,qt}}function F(t,e,r,n){var o,a,s,c,u=i(r);if(u){if(o=N(r,n),o===qt?(c=!0,a=o.error,o=null):s=!0,e===o)return void D(e,k())}else o=n,s=!0;e._state!==Ft||(u&&s?E(e,o):c?D(e,a):t===It?A(e,o):t===Rt&&D(e,o))}function I(t,e){var r=!1;try{e(function(e){r||(r=!0,E(t,e))},function(e){r||(r=!0,D(t,e))})}catch(n){D(t,n)}}function R(t,e,r){this._superConstructor(t,e,!1,r)}function W(t,e){return new R(Nt,t,e).promise}function q(t,e){return Nt.all(t,e)}function U(t,e){te[Bt]=t,te[Bt+1]=e,Bt+=2,2===Bt&&Vt()}function V(){var t=r.nextTick,e=r.versions.node.match(/^(?:(\d+)\.)?(?:(\d+)\.)?(\*|\d+)$/);return Array.isArray(e)&&"0"===e[1]&&"10"===e[2]&&(t=setImmediate),function(){t(X)}}function H(){return function(){Ut(X)}}function G(){var t=0,e=new Kt(X),r=document.createTextNode("");return e.observe(r,{characterData:!0}),function(){r.data=t=++t%2}}function B(){var t=new MessageChannel;return t.port1.onmessage=X,function(){t.port2.postMessage(0)}}function Y(){return function(){setTimeout(X,1)}}function X(){for(var t=0;Bt>t;t+=2){var e=te[t],r=te[t+1];e(r),te[t]=void 0,te[t+1]=void 0}Bt=0}function J(){try{var e=t,r=e("vertx");return Ut=r.runOnLoop||r.runOnContext,H()}catch(n){return Y()}}function K(t){var e={};return e.promise=new Nt(function(t,r){e.resolve=t,e.reject=r},t),e}function Z(t,e,r){return Nt.all(t,r).then(function(t){if(!i(e))throw new TypeError("You must pass a function as filter's second argument.");for(var n=t.length,o=new Array(n),a=0;n>a;a++)o[a]=e(t[a]);return Nt.all(o,r).then(function(e){for(var r=new Array(n),o=0,i=0;n>i;i++)e[i]&&(r[o]=t[i],o++);return r.length=o,r})})}function Q(t,e,r){this._superConstructor(t,e,!0,r)}function tt(t,e,r){this._superConstructor(t,e,!1,r)}function et(t,e){return new tt(Nt,t,e).promise}function rt(t,e){return new ne(Nt,t,e).promise}function nt(t,e,r){return Nt.all(t,r).then(function(t){if(!i(e))throw new TypeError("You must pass a function as map's second argument.");for(var n=t.length,o=new Array(n),a=0;n>a;a++)o[a]=e(t[a]);return Nt.all(o,r)})}function ot(){this.value=void 0}function it(t){try{return t.then}catch(e){return ce.value=e,ce}}function at(t,e,r){try{t.apply(e,r)}catch(n){return ce.value=n,ce}}function st(t,e){for(var r,n,o={},i=t.length,a=new Array(i),s=0;i>s;s++)a[s]=t[s];for(n=0;n<e.length;n++)r=e[n],o[r]=a[n+1];return o}function ct(t){for(var e=t.length,r=new Array(e-1),n=1;e>n;n++)r[n-1]=t[n];return r}function ut(t,e){return{then:function(r,n){return t.call(e,r,n)}}}function lt(t,e){var r=function(){for(var r,n=this,o=arguments.length,i=new Array(o+1),a=!1,s=0;o>s;++s){if(r=arguments[s],!a){if(a=ht(r),a===ue){var c=new Nt(O);return D(c,ue.value),c}a&&a!==!0&&(r=ut(a,r))}i[s]=r}var u=new Nt(O);return i[o]=function(t,r){t?D(u,t):void 0===e?E(u,r):e===!0?E(u,ct(arguments)):xt(e)?E(u,st(arguments,e)):E(u,r)},a?pt(u,i,t,n):ft(u,i,t,n)};return r.__proto__=t,r}function ft(t,e,r,n){var o=at(r,n,e);return o===ce&&D(t,o.value),t}function pt(t,e,r,n){return Nt.all(e).then(function(e){var o=at(r,n,e);return o===ce&&D(t,o.value),t})}function ht(t){return t&&"object"==typeof t?t.constructor===Nt?!0:it(t):!1}function dt(t,e){return Nt.race(t,e)}function vt(t,e){return Nt.reject(t,e)}function gt(t,e){return Nt.resolve(t,e)}function yt(t){throw setTimeout(function(){throw t}),t}function mt(t,e){jt.async(t,e)}function bt(){jt.on.apply(jt,arguments)}function wt(){jt.off.apply(jt,arguments)}var _t;_t=Array.isArray?Array.isArray:function(t){return"[object Array]"===Object.prototype.toString.call(t)};var xt=_t,kt=Date.now||function(){return(new Date).getTime()},Ot=Object.create||function(t){if(arguments.length>1)throw new Error("Second argument not supported");if("object"!=typeof t)throw new TypeError("Argument must be an object");return s.prototype=t,new s},St={mixin:function(t){return t.on=this.on,t.off=this.off,t.trigger=this.trigger,t._promiseCallbacks=void 0,t},on:function(t,e){if("function"!=typeof e)throw new TypeError("Callback must be a function");var r,n=u(this);r=n[t],r||(r=n[t]=[]),-1===c(r,e)&&r.push(e)},off:function(t,e){var r,n,o=u(this);return e?(r=o[t],n=c(r,e),void(-1!==n&&r.splice(n,1))):void(o[t]=[])},trigger:function(t,e,r){var n,o,i=u(this);if(n=i[t])for(var a=0;a<n.length;a++)(o=n[a])(e,r)}},jt={instrument:!1};St.mixin(jt);var $t=[],Tt=p,Ct=h,Et=d,Pt=g;g.prototype._validateInput=function(t){return xt(t)},g.prototype._validationError=function(){return new Error("Array Methods must be provided an Array")},g.prototype._init=function(){this._result=new Array(this.length)},g.prototype._enumerate=function(){for(var t=this.length,e=this.promise,r=this._input,n=0;e._state===Ft&&t>n;n++)this._eachEntry(r[n],n)},g.prototype._settleMaybeThenable=function(t,e){var r=this._instanceConstructor,n=r.resolve;if(n===Et){var o=S(t);if(o===Ct&&t._state!==Ft)t._onError=null,this._settledAt(t._state,e,t._result);else if("function"!=typeof o)this._remaining--,this._result[e]=this._makeResult(It,e,t);else if(r===Nt){var i=new r(O);C(i,t,o),this._willSettleAt(i,e)}else this._willSettleAt(new r(function(e){e(t)}),e)}else this._willSettleAt(n(t),e)},g.prototype._eachEntry=function(t,e){a(t)?this._settleMaybeThenable(t,e):(this._remaining--,this._result[e]=this._makeResult(It,e,t))},g.prototype._settledAt=function(t,e,r){var n=this.promise;n._state===Ft&&(this._remaining--,this._abortOnReject&&t===Rt?D(n,r):this._result[e]=this._makeResult(t,e,r)),0===this._remaining&&A(n,this._result)},g.prototype._makeResult=function(t,e,r){return r},g.prototype._willSettleAt=function(t,e){var r=this;L(t,void 0,function(t){r._settledAt(It,e,t)},function(t){r._settledAt(Rt,e,t)})};var At=y,Dt=m,Lt=b,Mt="rsvp_"+kt()+"-",zt=0,Nt=x;x.cast=Et,x.all=At,x.race=Dt,x.resolve=Et,x.reject=Lt,x.prototype={constructor:x,_guidKey:Mt,_onError:function(t){var e=this;jt.after(function(){e._onError&&jt.trigger("error",t,e._label)})},then:Ct,"catch":function(t,e){return this.then(void 0,t,e)},"finally":function(t,e){var r=this,n=r.constructor;return r.then(function(e){return n.resolve(t()).then(function(){return e})},function(e){return n.resolve(t()).then(function(){return n.reject(e)})},e)}};var Ft=void 0,It=1,Rt=2,Wt=new z,qt=new z;R.prototype=Ot(Pt.prototype),R.prototype._superConstructor=Pt,R.prototype._makeResult=v,R.prototype._validationError=function(){return new Error("allSettled must be called with an array")};var Ut,Vt,Ht=W,Gt=q,Bt=0,Yt=({}.toString,U),Xt="undefined"!=typeof window?window:void 0,Jt=Xt||{},Kt=Jt.MutationObserver||Jt.WebKitMutationObserver,Zt="undefined"==typeof self&&"undefined"!=typeof r&&"[object process]"==={}.toString.call(r),Qt="undefined"!=typeof Uint8ClampedArray&&"undefined"!=typeof importScripts&&"undefined"!=typeof MessageChannel,te=new Array(1e3);Vt=Zt?V():Kt?G():Qt?B():void 0===Xt&&"function"==typeof t?J():Y();var ee=K,re=Z,ne=Q;Q.prototype=Ot(Pt.prototype),Q.prototype._superConstructor=Pt,Q.prototype._init=function(){this._result={}},Q.prototype._validateInput=function(t){return t&&"object"==typeof t},Q.prototype._validationError=function(){return new Error("Promise.hash must be called with an object")},Q.prototype._enumerate=function(){var t=this,e=t.promise,r=t._input,n=[];for(var o in r)e._state===Ft&&Object.prototype.hasOwnProperty.call(r,o)&&n.push({position:o,entry:r[o]});var i=n.length;t._remaining=i;for(var a,s=0;e._state===Ft&&i>s;s++)a=n[s],t._eachEntry(a.entry,a.position)},tt.prototype=Ot(ne.prototype),tt.prototype._superConstructor=Pt,tt.prototype._makeResult=v,tt.prototype._validationError=function(){return new Error("hashSettled must be called with an object")};var oe,ie=et,ae=rt,se=nt,ce=new ot,ue=new ot,le=lt;if("object"==typeof self)oe=self;else{if("object"!=typeof n)throw new Error("no global: `self` or `global` found");oe=n}var fe=oe,pe=dt,he=vt,de=gt,ve=yt;jt.async=Yt,jt.after=function(t){setTimeout(t,0)};if("undefined"!=typeof window&&"object"==typeof window.__PROMISE_INSTRUMENTATION__){var ge=window.__PROMISE_INSTRUMENTATION__;l("instrument",!0);for(var ye in ge)ge.hasOwnProperty(ye)&&bt(ye,ge[ye])}var me={race:pe,Promise:Nt,allSettled:Ht,hash:ae,hashSettled:ie,denodeify:le,on:bt,off:wt,map:se,filter:re,resolve:de,reject:he,all:Gt,rethrow:ve,defer:ee,EventTarget:St,configure:l,async:mt};"function"==typeof define&&define.amd?define(function(){return me}):"undefined"!=typeof e&&e.exports?e.exports=me:"undefined"!=typeof fe&&(fe.RSVP=me)}).call(this)}).call(this,t("_process"),"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{_process:71}]},{},[29]); +!function t(e,r,n){function o(i,s){if(!r[i]){if(!e[i]){var c="function"==typeof require&&require;if(!s&&c)return c(i,!0);if(a)return a(i,!0);var u=new Error("Cannot find module '"+i+"'");throw u.code="MODULE_NOT_FOUND",u}var l=r[i]={exports:{}};e[i][0].call(l.exports,function(t){var r=e[i][1][t];return o(r?r:t)},l,l.exports,t,e,r,n)}return r[i].exports}for(var a="function"==typeof require&&require,i=0;i<n.length;i++)o(n[i]);return o}({1:[function(t,e,r){"use strict";var n=$,o=n.extend,a={lastFileUsed:"",files:{}},i=function(t){if(!t)throw"Missing file name"};e.exports={getCachedFile:function(t){return i(t),a.files[t]},updateCachedFile:function(t,e){i(t),a.files[t]||(a.files[t]={}),o(a.files[t],e)},getLastFileUsed:function(){return a.lastFileUsed},setLastFileUsed:function(t){a.lastFileUsed=t}}},{}],2:[function(t,e,r){"use strict";var n=t("../editor"),o=t("../tracer_manager"),a=t("../dom/setup"),i=t("../dom/loading_slider"),s=i.showLoadingSlider,c=i.hideLoadingSlider,u=t("./cache"),l={isLoading:null,editor:null,tracerManager:null,categories:null,loadedScratch:null,wikiList:null},f=function(t){l.isLoading=!1,l.editor=new n(t),l.tracerManager=t,l.categories={},l.loadedScratch=null,l.wikiList=[]},p=function(){this.getIsLoading=function(){return l.isLoading},this.setIsLoading=function(t){l.isLoading=t,t?s():c()},this.getEditor=function(){return l.editor},this.getCategories=function(){return l.categories},this.getCategory=function(t){return l.categories[t]},this.setCategories=function(t){l.categories=t},this.updateCategory=function(t,e){$.extend(l.categories[t],e)},this.getTracerManager=function(){return l.tracerManager},this.getLoadedScratch=function(){return l.loadedScratch},this.setLoadedScratch=function(t){l.loadedScratch=t},this.getWikiList=function(){return l.wikiList},this.setWikiList=function(t){l.wikiList=t},this.hasWiki=function(t){return~l.wikiList.indexOf(t)};var t=o.init();f(t),a.setup(t)};p.prototype=u,e.exports=p},{"../dom/loading_slider":7,"../dom/setup":9,"../editor":28,"../tracer_manager":64,"./cache":1}],3:[function(t,e,r){"use strict";e.exports={}},{}],4:[function(t,e,r){"use strict";var n=t("../app"),o=t("../server"),a=t("./show_algorithm"),i=$,s=i.each,c=function(t,e,r){return $('<button class="indent">').append(e[r]).attr("data-algorithm",r).attr("data-category",t).click(function(){o.loadAlgorithm(t,r).then(function(e){a(t,r,e)})})},u=function(t){var e=n.getCategory(t),r=e.name,o=e.list,a=$('<button class="category">').append('<i class="fa fa-fw fa-caret-right">').append(r).attr("data-category",t);a.click(function(){var t=$(this);t.toggleClass("open"),t.next().toggleClass("collapse"),t.find("i.fa").toggleClass("fa-caret-right fa-caret-down")});var i=$('<div class="algorithms collapse">');$("#list").append(a).append(i),s(o,function(e){var r=c(t,o,e);i.append(r)})};e.exports=function(){s(n.getCategories(),u)}},{"../app":3,"../server":56,"./show_algorithm":19}],5:[function(t,e,r){"use strict";var n=t("../server"),o=$,a=o.each,i=function(t,e,r,o){var a=$("<button>").append(r).attr("data-file",r).click(function(){n.loadFile(t,e,r,o),$(".files_bar > .wrapper > button").removeClass("active"),$(this).addClass("active")});return $(".files_bar > .wrapper").append(a),a};e.exports=function(t,e,r,n){$(".files_bar > .wrapper").empty(),a(r,function(r,o){var a=i(t,e,r,o);n&&n==r&&a.click()}),n||$(".files_bar > .wrapper > button").first().click(),$(".files_bar > .wrapper").scroll()}},{"../server":56}],6:[function(t,e,r){"use strict";var n=t("./show_algorithm"),o=t("./add_categories"),a=t("./show_description"),i=t("./add_files"),s=t("./show_first_algorithm"),c=t("./show_requested_algorithm"),u=t("./show_wiki");e.exports={showAlgorithm:n,addCategories:o,showDescription:a,addFiles:i,showFirstAlgorithm:s,showRequestedAlgorithm:c,showWiki:u}},{"./add_categories":4,"./add_files":5,"./show_algorithm":19,"./show_description":20,"./show_first_algorithm":21,"./show_requested_algorithm":22,"./show_wiki":23}],7:[function(t,e,r){"use strict";var n=function(){$("#loading-slider").removeClass("loaded")},o=function(){$("#loading-slider").addClass("loaded")};e.exports={showLoadingSlider:n,hideLoadingSlider:o}},{}],8:[function(t,e,r){"use strict";var n=function(){var t=$('<section class="module_wrapper">');return $(".module_container").append(t),t};e.exports={create:n}},{}],9:[function(t,e,r){"use strict";var n=t("./setup_dividers"),o=t("./setup_document"),a=t("./setup_files_bar"),i=t("./setup_interval"),s=t("./setup_module_container"),c=t("./setup_tab_container"),u=t("./setup_side_menu"),l=t("./setup_top_menu"),f=t("./setup_window"),p=function(){$(".btn input").click(function(t){t.stopPropagation()}),n(),o(),a(),i(),s(),c(),u(),l(),f()};e.exports={setup:p}},{"./setup_dividers":10,"./setup_document":11,"./setup_files_bar":12,"./setup_interval":13,"./setup_module_container":14,"./setup_side_menu":15,"./setup_tab_container":16,"./setup_top_menu":17,"./setup_window":18}],10:[function(t,e,r){"use strict";var n=function(){function t(t,e){var r=[],n=!0,o=!1,a=void 0;try{for(var i,s=t[Symbol.iterator]();!(n=(i=s.next()).done)&&(r.push(i.value),!e||r.length!==e);n=!0);}catch(c){o=!0,a=c}finally{try{!n&&s["return"]&&s["return"]()}finally{if(o)throw a}}return r}return function(e,r){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e))return t(e,r);throw new TypeError("Invalid attempt to destructure non-iterable instance")}}(),o=t("../../app"),a=function(t){var e=n(t,3),r=e[0],a=e[1],i=e[2],s=a.parent(),c=5,u=$('<div class="divider">'),l=!1;r?!function(){u.addClass("vertical");var t=-c/2;u.css({top:0,bottom:0,left:t,width:c});var e=void 0;u.mousedown(function(t){var r=t.pageX;e=r,l=!0}),$(document).mousemove(function(t){var r=t.pageX;if(l){var n=i.position().left+r-e,c=n/s.width()*100;c=Math.min(90,Math.max(10,c)),a.css("right",100-c+"%"),i.css("left",c+"%"),e=r,o.getTracerManager().resize(),$(".files_bar > .wrapper").scroll()}}),$(document).mouseup(function(t){l=!1})}():!function(){u.addClass("horizontal");var t=-c/2;u.css({top:t,height:c,left:0,right:0});var e=void 0;u.mousedown(function(t){var r=t.pageY;e=r,l=!0}),$(document).mousemove(function(t){var r=t.pageY;if(l){var n=i.position().top+r-e,c=n/s.height()*100;c=Math.min(90,Math.max(10,c)),a.css("bottom",100-c+"%"),i.css("top",c+"%"),e=r,o.getTracerManager().resize()}}),$(document).mouseup(function(t){l=!1})}(),i.append(u)};e.exports=function(){for(var t=[["v",$(".sidemenu"),$(".workspace")],["v",$(".viewer_container"),$(".editor_container")],["h",$(".data_container"),$(".code_container")]],e=0;e<t.length;e++)a(t[e])}},{"../../app":3}],11:[function(t,e,r){"use strict";var n=t("../../app");e.exports=function(){$(document).on("click","a",function(t){var e=$(this).attr("href");/^(https?:\/\/).+/.test(e)&&(t.preventDefault(),window.open(e,"_blank")||alert("Please allow popups for this site"))}),$(document).mouseup(function(t){n.getTracerManager().command("mouseup",t)})}},{"../../app":3}],12:[function(t,e,r){"use strict";var n=function(t,e){return t>e+2};e.exports=function(){$(".files_bar > .btn-left").click(function(){var t=$(".files_bar > .wrapper"),e=t.width(),r=t.scrollLeft();$(t.children("button").get().reverse()).each(function(){var n=$(this).position().left,o=n+$(this).outerWidth();return 0>n?(t.scrollLeft(r+o-e),!1):void 0})}),$(".files_bar > .btn-right").click(function(){var t=$(".files_bar > .wrapper"),e=t.width(),r=t.scrollLeft();t.children("button").each(function(){var n=$(this).position().left,o=n+$(this).outerWidth();return o>e?(t.scrollLeft(r+n),!1):void 0})}),$(".files_bar > .wrapper").scroll(function(){var t=$(".files_bar > .wrapper"),e=t.width(),r=t.children("button:first-child"),o=t.children("button:last-child"),a=r.position().left,i=o.position().left+o.outerWidth();if(n(0,a)&&n(e,i)){var s=t.scrollLeft();return void t.scrollLeft(s+e-i)}var c=n(0,a),u=n(i,e);t.toggleClass("shadow-left",c),t.toggleClass("shadow-right",u),$(".files_bar > .btn-left").attr("disabled",!c),$(".files_bar > .btn-right").attr("disabled",!u)})}},{}],13:[function(t,e,r){"use strict";var n=function(){function t(t,e){var r=[],n=!0,o=!1,a=void 0;try{for(var i,s=t[Symbol.iterator]();!(n=(i=s.next()).done)&&(r.push(i.value),!e||r.length!==e);n=!0);}catch(c){o=!0,a=c}finally{try{!n&&s["return"]&&s["return"]()}finally{if(o)throw a}}return r}return function(e,r){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e))return t(e,r);throw new TypeError("Invalid attempt to destructure non-iterable instance")}}(),o=t("../../app"),a=t("../toast"),i=Number.parseFloat,s=.1,c=10,u=.5,l=.1,f=function(t){var e=void 0,r=void 0;return s>t?(e=s,r="Interval of "+t+" seconds is too low. Setting to min allowed interval of "+s+" second(s)."):t>c?(e=c,r="Interval of "+t+" seconds is too high. Setting to max allowed interval of "+c+" second(s)."):(e=t,r="Interval has been set to "+t+" second(s)."),[e,r]};e.exports=function(){var t=$("#interval");t.val(u),t.attr({max:c,min:s,step:l}),$("#interval").on("change",function(){var t=o.getTracerManager(),e=f(i($(this).val())),r=n(e,2),s=r[0],c=r[1];$(this).val(s),t.interval=1e3*s,a.showInfoToast(c)})}},{"../../app":3,"../toast":24}],14:[function(t,e,r){"use strict";var n=t("../../app");e.exports=function(){var t=$(".module_container");t.on("mousedown",".module_wrapper",function(t){n.getTracerManager().findOwner(this).mousedown(t)}),t.on("mousemove",".module_wrapper",function(t){n.getTracerManager().findOwner(this).mousemove(t)}),t.on("DOMMouseScroll mousewheel",".module_wrapper",function(t){n.getTracerManager().findOwner(this).mousewheel(t)})}},{"../../app":3}],15:[function(t,e,r){"use strict";var n=t("../../app"),o=t("../../server"),a=t("../show_algorithm"),i=void 0;e.exports=function(){$("#navigation").click(function(){var t=$(".sidemenu"),e=$(".workspace");t.toggleClass("active"),$(".nav-dropdown").toggleClass("fa-caret-down fa-caret-up"),t.hasClass("active")?(t.css("right",100-i+"%"),e.css("left",i+"%")):(i=e.position().left/$("body").width()*100,t.css("right",0),e.css("left",0)),n.getTracerManager().resize()}),$("#documentation").click(function(){$("#btn_doc").click()}),$("#powered-by").click(function(){$("#powered-by-list button").toggleClass("collapse")}),$("#scratch-paper").click(function(){var t="scratch",e=n.getLoadedScratch();o.loadAlgorithm(t,e).then(function(r){a(t,e,r)})})}},{"../../app":3,"../../server":56,"../show_algorithm":19}],16:[function(t,e,r){"use strict";e.exports=function(){$(".tab_bar > button").click(function(){$(".tab_bar > button").removeClass("active"),$(".tab_container > .tab").removeClass("active"),$(this).addClass("active"),$($(this).attr("data-target")).addClass("active")})}},{}],17:[function(t,e,r){"use strict";var n=t("../../app"),o=t("../../server"),a=t("../toast"),i=t("../top_menu");e.exports=function(){$("#shared").mouseup(function(){$(this).select()}),$("#btn_share").click(function(){var t=$(this).find(".fa-share");t.addClass("fa-spin fa-spin-faster"),o.shareScratchPaper().then(function(e){t.removeClass("fa-spin fa-spin-faster"),$("#shared").removeClass("collapse"),$("#shared").val(e),a.showInfoToast("Shareable link is created.")})});var t=$("#btn_run"),e=$("#btn_trace"),r=$("#btn_pause"),s=$("#btn_prev"),c=$("#btn_next");i.disableFlowControl(),t.click(function(){e.click(),r.removeClass("active"),t.addClass("active"),i.enableFlowControl();var o=n.getEditor().execute();o&&(console.error(o),a.showErrorToast(o),i.resetTopMenuButtons())}),r.click(function(){t.toggleClass("active"),r.toggleClass("active"),n.getTracerManager().isPause()?n.getTracerManager().resumeStep():n.getTracerManager().pauseStep()}),s.click(function(){t.removeClass("active"),r.addClass("active"),n.getTracerManager().pauseStep(),n.getTracerManager().prevStep()}),c.click(function(){t.removeClass("active"),r.addClass("active"),n.getTracerManager().pauseStep(),n.getTracerManager().nextStep()})}},{"../../app":3,"../../server":56,"../toast":24,"../top_menu":25}],18:[function(t,e,r){"use strict";var n=t("../../app");e.exports=function(){$(window).resize(function(){n.getTracerManager().resize()})}},{"../../app":3}],19:[function(t,e,r){"use strict";var n=t("../app"),o=t("../utils"),a=o.isScratchPaper,i=t("./show_description"),s=t("./add_files");e.exports=function(t,e,r,o){var c=void 0,u=void 0,l=void 0;if(a(t))c=$("#scratch-paper"),u="Scratch Paper",l=e?"Shared":"Temporary";else{c=$('[data-category="'+t+'"][data-algorithm="'+e+'"]');var f=n.getCategory(t);u=f.name,l=f.list[e]}$(".sidemenu button").removeClass("active"),c.addClass("active"),$("#category").html(u),$("#algorithm").html(l),$("#tab_desc > .wrapper").empty(),$(".files_bar > .wrapper").empty(),$("#explanation").html(""),n.setLastFileUsed(null),n.getEditor().clearContent();var p=r.files;delete r.files,i(r),s(t,e,p,o)}},{"../app":3,"../utils":70,"./add_files":5,"./show_description":20}],20:[function(t,e,r){"use strict";var n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol?"symbol":typeof t},o=Array.isArray,a=$,i=a.each;e.exports=function(t){var e=$("#tab_desc > .wrapper");e.empty(),i(t,function(t,r){t&&e.append($("<h3>").html(t)),"string"==typeof r?e.append($("<p>").html(r)):o(r)?!function(){var t=$('<ul class="applications">');e.append(t),r.forEach(function(e){t.append($("<li>").html(e))})}():"object"===("undefined"==typeof r?"undefined":n(r))&&!function(){var t=$('<ul class="complexities">');e.append(t),i(r,function(e){var n=$('<div class="complexity">'),o=$('<span class="complexity-type">').html(e+": "),a=$('<span class="complexity-value">').html(""+r[e]);n.append(o).append(a),t.append($("<li>").append(n))})}()})}},{}],21:[function(t,e,r){"use strict";e.exports=function(){$("#list .category").first().click(),$("#list .category + .algorithms > .indent").first().click()}},{}],22:[function(t,e,r){"use strict";var n=t("../server"),o=t("./show_algorithm");e.exports=function(t,e,r){$('.category[data-category="'+t+'"]').click(),n.loadAlgorithm(t,e).then(function(n){o(t,e,n,r)})}},{"../server":56,"./show_algorithm":19}],23:[function(t,e,r){"use strict";var n=t("../app"),o=t("../server"),a=new showdown.Converter({tables:!0});e.exports=function(t){o.loadWiki(t).then(function(r){$("#tab_doc > .wrapper").html(a.makeHtml("#"+t+"\n"+r)),$("#tab_doc").scrollTop(0),$("#tab_doc > .wrapper a").click(function(t){var r=$(this).attr("href");n.hasWiki(r)&&(t.preventDefault(),e.exports(r))})})}},{"../app":3,"../server":56}],24:[function(t,e,r){"use strict";var n=function(t,e){var r=$('<div class="toast '+e+'">').append(t);$(".toast_container").append(r),setTimeout(function(){r.fadeOut(function(){r.remove()})},3e3)},o=function(t){n(t,"error")},a=function(t){n(t,"info")};e.exports={showErrorToast:o,showInfoToast:a}},{}],25:[function(t,e,r){"use strict";var n=t("../app"),o=[$("#btn_pause"),$("#btn_prev"),$("#btn_next")],a=function(t){o.forEach(function(e){return e.attr("disabled",t)})},i=function(){a(!1)},s=function(){a(!0)},c=function(){$(".top-menu-buttons button").removeClass("active"),s(),n.getEditor().unhighlightLine()},u=function(t){$("#interval").val(interval)},l=function(){$("#btn_pause").addClass("active")},f=function(){$("#btn_pause").removeClass("active")};e.exports={enableFlowControl:i,disableFlowControl:s,resetTopMenuButtons:c,setInterval:u,activateBtnPause:l,deactivateBtnPause:f}},{"../app":3}],26:[function(t,e,r){"use strict";e.exports=function(t){var e=ace.edit(t);return e.setOptions({enableBasicAutocompletion:!0,enableSnippets:!0,enableLiveAutocompletion:!0}),e.setTheme("ace/theme/tomorrow_night_eighties"),e.session.setMode("ace/mode/javascript"),e.$blockScrolling=1/0,e}},{}],27:[function(require,module,exports){"use strict";var execute=function execute(tracerManager,code,dataLines){try{!function(){tracerManager.deallocateAll();var lines=code.split("\n"),newLines=[];lines.forEach(function(t,e){newLines.push(t.replace(/(.+\. *_wait *)(\( *\))/g,"$1("+(e-dataLines)+")"))}),eval(newLines.join("\n")),tracerManager.visualize()}()}catch(err){return err}finally{tracerManager.removeUnallocated()}},executeData=function(t,e){return execute(t,e)},executeDataAndCode=function(t,e,r){var n=e.split("\n").length;return execute(t,e+"\n"+r,n)};module.exports={executeData:executeData,executeDataAndCode:executeDataAndCode}},{}],28:[function(t,e,r){"use strict";function n(t){var e=this;if(!t)throw"Cannot create Editor. Missing the tracerManager";ace.require("ace/ext/language_tools");var r=ace.require("ace/range").Range;this.dataEditor=a("data"),this.codeEditor=a("code"),this.setData=function(t){e.dataEditor.setValue(t,-1)},this.setCode=function(t){e.codeEditor.setValue(t,-1)},this.setContent=function(t){var r=t.data,n=t.code;e.setData(r),e.setCode(n)},this.clearData=function(){e.dataEditor.setValue("")},this.clearCode=function(){e.codeEditor.setValue("")},this.clearContent=function(){e.clearData(),e.clearCode()},this.execute=function(){var r=e.dataEditor.getValue(),n=e.codeEditor.getValue();return i.executeDataAndCode(t,r,n)},this.highlightLine=function(t){var n=e.codeEditor.getSession();e.marker&&n.removeMarker(e.marker),e.marker=n.addMarker(new r(t,0,t,1/0),"executing","line",!0)},this.unhighlightLine=function(){var t=e.codeEditor.getSession();e.marker&&t.removeMarker(e.marker)},this.dataEditor.on("change",function(){var r=e.dataEditor.getValue(),n=o.getLastFileUsed();n&&o.updateCachedFile(n,{data:r}),i.executeData(t,r),s.resetTopMenuButtons()}),this.codeEditor.on("change",function(){var r=e.codeEditor.getValue(),n=o.getLastFileUsed();n&&o.updateCachedFile(n,{code:r}),t.reset(),s.resetTopMenuButtons()})}var o=t("../app"),a=t("./create"),i=t("./executor"),s=t("../dom/top_menu");e.exports=n},{"../app":3,"../dom/top_menu":25,"./create":26,"./executor":27}],29:[function(t,e,r){"use strict";var n=t("rsvp"),o=t("./app"),a=t("./app/constructor"),i=t("./dom"),s=t("./server"),c=t("./module"),u=$,l=u.extend;$.ajaxSetup({cache:!1,dataType:"text"});var f=t("./utils"),p=f.isScratchPaper,h=t("./server/helpers"),d=h.getHashValue,v=h.getParameterByName,g=h.getPath;n.on("error",function(t){console.assert(!1,t)}),$(function(){var t=new a;l(!0,o,t),l(!0,window,c),s.loadCategories().then(function(t){o.setCategories(t),i.addCategories();var e=g(),r=e.category,n=e.algorithm,a=e.file;p(r)?n?s.loadScratchPaper(n).then(function(t){var e=t.category,r=t.algorithm,n=t.data;i.showAlgorithm(e,r,n)}):s.loadAlgorithm(r).then(function(t){i.showAlgorithm(r,null,t)}):r&&n?i.showRequestedAlgorithm(r,n,a):i.showFirstAlgorithm()}),s.loadWikiList().then(function(t){o.setWikiList(t.wikis),i.showWiki("Tracer")});var e=d("scratch-paper"),r=v("scratch-paper"),n=e||r;n&&(window.location.href=window.location.protocol+"//"+window.location.host+window.location.pathname+"#path=scratch/"+n)})},{"./app":3,"./app/constructor":2,"./dom":6,"./module":39,"./server":56,"./server/helpers":55,"./utils":70,rsvp:72}],30:[function(t,e,r){"use strict";var n=t("./array2d"),o=function(t,e,r){return n.random(1,t,e,r)[0]},a=function(t,e,r){return n.randomSorted(1,t,e,r)[0]};e.exports={random:o,randomSorted:a}},{"./array2d":31}],31:[function(t,e,r){"use strict";var n=t("./integer"),o=function(t,e,r,o){t||(t=10),e||(e=10),void 0===r&&(r=1),void 0===o&&(o=9);for(var a=[],i=0;t>i;i++){a.push([]);for(var s=0;e>s;s++)a[i].push(n.random(r,o))}return a},a=function(t,e,r,n){return o(t,e,r,n).map(function(t){return t.sort(function(t,e){return t-e})})};e.exports={random:o,randomSorted:a}},{"./integer":35}],32:[function(t,e,r){"use strict";var n=t("./integer"),o=function(t,e,r){t||(t=7),e||(e=1),r||(r=10);for(var o=new Array(t),a=0;t>a;a++)o[a]=new Array(2);for(var a=0;t>a;a++)for(var i=0;i<o[a].length;i++)o[a][i]=n.random(e,r);return o};e.exports={random:o}},{"./integer":35}],33:[function(t,e,r){"use strict";var n=function(t,e){t||(t=5),e||(e=.3);for(var r=new Array(t),n=0;t>n;n++){r[n]=new Array(t);for(var o=0;t>o;o++)n!=o&&(r[n][o]=0==(Math.random()*(1/e)|0)?1:0)}return r};e.exports={random:n}},{}],34:[function(t,e,r){"use strict";var n=t("./integer"),o=t("./array1d"),a=t("./array2d"),i=t("./coordinate_system"),s=t("./directed_graph"),c=t("./undirected_graph"),u=t("./weighted_directed_graph"),l=t("./weighted_undirected_graph");e.exports={Integer:n,Array1D:o,Array2D:a,CoordinateSystem:i,DirectedGraph:s,UndirectedGraph:c,WeightedDirectedGraph:u,WeightedUndirectedGraph:l}},{"./array1d":30,"./array2d":31,"./coordinate_system":32,"./directed_graph":33,"./integer":35,"./undirected_graph":36,"./weighted_directed_graph":37,"./weighted_undirected_graph":38}],35:[function(t,e,r){"use strict";var n=function(t,e){return(Math.random()*(e-t+1)|0)+t};e.exports={random:n}},{}],36:[function(t,e,r){"use strict";var n=function(t,e){t||(t=5),e||(e=.3);for(var r=new Array(t),n=0;t>n;n++)r[n]=new Array(t);for(var n=0;t>n;n++)for(var o=0;t>o;o++)n>o&&(r[n][o]=r[o][n]=0==(Math.random()*(1/e)|0)?1:0);return r};e.exports={random:n}},{}],37:[function(t,e,r){"use strict";var n=t("./integer"),o=function(t,e,r,o){t||(t=5),e||(e=.3),r||(r=1),o||(o=5);for(var a=new Array(t),i=0;t>i;i++){a[i]=new Array(t);for(var s=0;t>s;s++)i!=s&&0==(Math.random()*(1/e)|0)&&(a[i][s]=n.random(r,o))}return a};e.exports={random:o}},{"./integer":35}],38:[function(t,e,r){"use strict";var n=t("./integer"),o=function(t,e,r,o){t||(t=5),e||(e=.3),r||(r=1),o||(o=5);for(var a=new Array(t),i=0;t>i;i++)a[i]=new Array(t);for(var i=0;t>i;i++)for(var s=0;t>s;s++)i>s&&0==(Math.random()*(1/e)|0)&&(a[i][s]=a[s][i]=n.random(r,o));return a};e.exports={random:o}},{"./integer":35}],39:[function(t,e,r){"use strict";var n=t("./tracer"),o=t("./data"),a=$,i=a.extend;e.exports=i(!0,{},n,o)},{"./data":34,"./tracer":45}],40:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function a(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=function l(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:l(o,e,r)}if("value"in n)return n.value;var a=n.get;if(void 0!==a)return a.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./array2d"),u=function(t){function e(t){return n(this,e),o(this,Object.getPrototypeOf(e).call(this,t))}return a(e,t),s(e,null,[{key:"getClassName",value:function(){return"Array1DTracer"}}]),s(e,[{key:"_notify",value:function(t,r){return i(Object.getPrototypeOf(e.prototype),"_notify",this).call(this,0,t,r),this}},{key:"_denotify",value:function(t){return i(Object.getPrototypeOf(e.prototype),"_denotify",this).call(this,0,t),this}},{key:"_select",value:function(t,r){return void 0===r?i(Object.getPrototypeOf(e.prototype),"_select",this).call(this,0,t):i(Object.getPrototypeOf(e.prototype),"_selectRow",this).call(this,0,t,r),this}},{key:"_deselect",value:function(t,r){return void 0===r?i(Object.getPrototypeOf(e.prototype),"_deselect",this).call(this,0,t):i(Object.getPrototypeOf(e.prototype),"_deselectRow",this).call(this,0,t,r),this}},{key:"processStep",value:function(t,r){if(i(Object.getPrototypeOf(e.prototype),"processStep",this).call(this,t,r),this.chartTracer){var n=$.extend(!0,{},t);n.capsule=this.chartTracer.capsule,n.s=n.sy,n.e=n.ey,void 0===n.s&&(n.s=n.y),delete n.x,delete n.y,delete n.sx,delete n.sy,delete n.ex,delete n.ey,this.chartTracer.processStep(n,r)}}},{key:"setData",value:function(t){return i(Object.getPrototypeOf(e.prototype),"setData",this).call(this,[t])}}]),e}(c);e.exports=u},{"./array2d":41}],41:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function a(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=function h(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:h(o,e,r)}if("value"in n)return n.value;var a=n.get;if(void 0!==a)return a.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./tracer"),u=t("../../tracer_manager/util/index"),l=u.refineByType,f=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.colorClass={selected:"selected",notified:"notified"},r.isNew&&p(r),r}return a(e,t),s(e,null,[{key:"getClassName",value:function(){return"Array2DTracer"}}]),s(e,[{key:"_notify",value:function(t,e,r){return this.manager.pushStep(this.capsule,{type:"notify",x:t,y:e,v:r}),this}},{key:"_denotify",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"denotify",x:t,y:e}),this}},{key:"_select",value:function(t,e,r,n){return this.pushSelectingStep("select",null,arguments),this}},{key:"_selectRow",value:function(t,e,r){return this.pushSelectingStep("select","row",arguments),this}},{key:"_selectCol",value:function(t,e,r){return this.pushSelectingStep("select","col",arguments),this}},{key:"_deselect",value:function(t,e,r,n){return this.pushSelectingStep("deselect",null,arguments),this}},{key:"_deselectRow",value:function(t,e,r){return this.pushSelectingStep("deselect","row",arguments),this}},{key:"_deselectCol",value:function(t,e,r){return this.pushSelectingStep("deselect","col",arguments),this}},{key:"_separate",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"separate",x:t,y:e}),this}},{key:"_separateRow",value:function(t){return this._separate(t,-1),this}},{key:"_separateCol",value:function(t){return this._separate(-1,t),this}},{key:"_deseparate",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"deseparate",x:t,y:e}),this}},{key:"_deseparateRow",value:function(t){return this._deseparate(t,-1),this}},{key:"_deseparateCol",value:function(t){return this._deseparate(-1,t),this}},{key:"pushSelectingStep",value:function(){var t=Array.prototype.slice.call(arguments),e=t.shift(),r=t.shift();t=Array.prototype.slice.call(t.shift());var n;switch(r){case"row":n={x:t[0],sy:t[1],ey:t[2]};break;case"col":n={y:t[0],sx:t[1],ex:t[2]};break;default:n=void 0===t[2]&&void 0===t[3]?{x:t[0],y:t[1]}:{sx:t[0],sy:t[1],ex:t[2],ey:t[3]}}var o={type:e};$.extend(o,n),this.manager.pushStep(this.capsule,o)}},{key:"processStep",value:function(t,r){switch(t.type){case"notify":if(void 0!==t.v){var n=this.$table.find(".mtbl-row").eq(t.x),o=n.find(".mtbl-col").eq(t.y);o.text(l(t.v))}case"denotify":case"select":case"deselect":var a="select"==t.type||"deselect"==t.type?this.colorClass.selected:this.colorClass.notified,s="select"==t.type||"notify"==t.type,c=t.sx,u=t.sy,f=t.ex,p=t.ey;void 0===c&&(c=t.x),void 0===u&&(u=t.y),void 0===f&&(f=t.x),void 0===p&&(p=t.y),this.paintColor(c,u,f,p,a,s);break;case"separate":this.deseparate(t.x,t.y),this.separate(t.x,t.y);break;case"deseparate":this.deseparate(t.x,t.y);break;default:i(Object.getPrototypeOf(e.prototype),"processStep",this).call(this,t,r)}}},{key:"setData",value:function(t){if(this.viewX=this.viewY=0,this.paddingH=6,this.paddingV=3,this.fontSize=16,i(Object.getPrototypeOf(e.prototype),"setData",this).apply(this,arguments))return this.$table.find(".mtbl-row").each(function(e){$(this).find(".mtbl-col").each(function(r){$(this).text(l(t[e][r]))})}),!0;this.$table.empty();for(var r=0;r<t.length;r++){var n=$('<div class="mtbl-row">');this.$table.append(n);for(var o=0;o<t[r].length;o++){var a=$('<div class="mtbl-col">').css(this.getCellCss()).text(l(t[r][o]));n.append(a)}}return this.resize(),!1}},{key:"resize",value:function(){i(Object.getPrototypeOf(e.prototype),"resize",this).call(this),this.refresh()}},{key:"clear",value:function(){i(Object.getPrototypeOf(e.prototype),"clear",this).call(this),this.clearColor(),this.deseparateAll()}},{key:"getCellCss",value:function(){return{padding:this.paddingV.toFixed(1)+"px "+this.paddingH.toFixed(1)+"px","font-size":this.fontSize.toFixed(1)+"px"}}},{key:"refresh",value:function(){i(Object.getPrototypeOf(e.prototype),"refresh",this).call(this);var t=this.$table.parent(),r=t.height()/2-this.$table.height()/2+this.viewY,n=t.width()/2-this.$table.width()/2+this.viewX;this.$table.css("margin-top",r),this.$table.css("margin-left",n)}},{key:"mousedown",value:function(t){i(Object.getPrototypeOf(e.prototype),"mousedown",this).call(this,t),this.dragX=t.pageX,this.dragY=t.pageY,this.dragging=!0}},{key:"mousemove",value:function(t){i(Object.getPrototypeOf(e.prototype),"mousemove",this).call(this,t),this.dragging&&(this.viewX+=t.pageX-this.dragX,this.viewY+=t.pageY-this.dragY,this.dragX=t.pageX,this.dragY=t.pageY,this.refresh())}},{key:"mouseup",value:function(t){i(Object.getPrototypeOf(e.prototype),"mouseup",this).call(this,t),this.dragging=!1}},{key:"mousewheel",value:function(t){i(Object.getPrototypeOf(e.prototype),"mousewheel",this).call(this,t),t.preventDefault(),t=t.originalEvent;var r=void 0!==t.wheelDelta&&t.wheelDelta||void 0!==t.detail&&-t.detail,n=1.01,o=r>0?1/n:n;this.fontSize<4&&1>o||this.fontSize>40&&o>1||(this.paddingV*=o,this.paddingH*=o,this.fontSize*=o,this.$table.find(".mtbl-col").css(this.getCellCss()),this.refresh())}},{key:"paintColor",value:function(t,e,r,n,o,a){for(var i=t;r>=i;i++)for(var s=this.$table.find(".mtbl-row").eq(i),c=e;n>=c;c++){var u=s.find(".mtbl-col").eq(c);a?u.addClass(o):u.removeClass(o)}}},{key:"clearColor",value:function(){this.$table.find(".mtbl-col").removeClass(Object.keys(this.colorClass).join(" "))}},{key:"separate",value:function(t,e){this.$table.find(".mtbl-row").each(function(r){var n=$(this);r==t&&n.after($('<div class="mtbl-empty-row">').attr("data-row",r)),n.find(".mtbl-col").each(function(t){var r=$(this);t==e&&r.after($('<div class="mtbl-empty-col">').attr("data-col",t))})})}},{key:"deseparate",value:function(t,e){this.$table.find("[data-row="+t+"]").remove(),this.$table.find("[data-col="+e+"]").remove()}},{key:"deseparateAll",value:function(){this.$table.find(".mtbl-empty-row, .mtbl-empty-col").remove()}}]),e}(c),p=function(t){t.$table=t.capsule.$table=$('<div class="mtbl-table">'),t.$container.append(t.$table)};e.exports=f},{"../../tracer_manager/util/index":67,"./tracer":47}],42:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function a(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=function f(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:f(o,e,r)}if("value"in n)return n.value; +var a=n.get;if(void 0!==a)return a.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./tracer"),u=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.color={selected:"rgb(0, 0, 255)",notified:"rgb(255, 0, 0)","default":"rgb(136, 136, 136)"},r.isNew&&l(r),r}return a(e,t),s(e,null,[{key:"getClassName",value:function(){return"ChartTracer"}}]),s(e,[{key:"setData",value:function(t){if(i(Object.getPrototypeOf(e.prototype),"setData",this).apply(this,arguments))return this.chart.config.data.datasets[0].data=t,this.chart.update(),!0;for(var r=[],n=0;n<t.length;n++)r.push(this.color["default"]);this.chart.config.data={labels:t.map(String),datasets:[{backgroundColor:r,data:t}]},this.chart.update()}},{key:"_notify",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"notify",s:t,v:e}),this}},{key:"_denotify",value:function(t){return this.manager.pushStep(this.capsule,{type:"denotify",s:t}),this}},{key:"_select",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"select",s:t,e:e}),this}},{key:"_deselect",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"deselect",s:t,e:e}),this}},{key:"processStep",value:function(t,r){switch(t.type){case"notify":void 0!==t.v&&(this.chart.config.data.datasets[0].data[t.s]=t.v,this.chart.config.data.labels[t.s]=t.v.toString());case"denotify":case"select":case"deselect":var n="notify"==t.type?this.color.notified:"select"==t.type?this.color.selected:this.color["default"];if(void 0!==t.e)for(var o=t.s;o<=t.e;o++)this.chart.config.data.datasets[0].backgroundColor[o]=n;else this.chart.config.data.datasets[0].backgroundColor[t.s]=n;this.chart.update();break;default:i(Object.getPrototypeOf(e.prototype),"processStep",this).call(this,t,r)}}},{key:"resize",value:function(){i(Object.getPrototypeOf(e.prototype),"resize",this).call(this),this.chart.resize()}},{key:"clear",value:function(){i(Object.getPrototypeOf(e.prototype),"clear",this).call(this);var t=this.chart.config.data;if(t.datasets.length){for(var r=t.datasets[0].backgroundColor,n=0;n<r.length;n++)r[n]=this.color["default"];this.chart.update()}}}]),e}(c),l=function(t){t.$wrapper=t.capsule.$wrapper=$('<canvas class="mchrt-chart">'),t.$container.append(t.$wrapper),t.chart=t.capsule.chart=new Chart(t.$wrapper,{type:"bar",data:{labels:[],datasets:[]},options:{scales:{yAxes:[{ticks:{beginAtZero:!0}}]},animation:!1,legend:!1,responsive:!0,maintainAspectRatio:!1}})};e.exports=u},{"./tracer":47}],43:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function a(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=function f(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:f(o,e,r)}if("value"in n)return n.value;var a=n.get;if(void 0!==a)return a.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./directed_graph"),u=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.isNew&&l(r),r}return a(e,t),s(e,null,[{key:"getClassName",value:function(){return"CoordinateSystemTracer"}}]),s(e,[{key:"setData",value:function(t){if(Tracer.prototype.setData.apply(this,arguments))return!0;this.graph.clear();for(var e=[],r=[],n=0;n<t.length;n++)e.push({id:this.n(n),x:t[n][0],y:t[n][1],label:""+n,size:1,color:this.color["default"]});return this.graph.read({nodes:e,edges:r}),this.s.camera.goTo({x:0,y:0,angle:0,ratio:1}),this.refresh(),!1}},{key:"processStep",value:function(t,r){switch(t.type){case"visit":case"leave":var n="visit"==t.type,o=this.graph.nodes(this.n(t.target)),a=n?this.color.visited:this.color.left;if(o.color=a,void 0!==t.source){var s=this.e(t.source,t.target);if(this.graph.edges(s)){var c=this.graph.edges(s);c.color=a,this.graph.dropEdge(s).addEdge(c)}else this.graph.addEdge({id:this.e(t.target,t.source),source:this.n(t.source),target:this.n(t.target),color:a,size:1})}if(this.logTracer){var u=t.source;void 0===u&&(u=""),this.logTracer.print(n?u+" -> "+t.target:u+" <- "+t.target)}break;default:i(Object.getPrototypeOf(e.prototype),"processStep",this).call(this,t,r)}}},{key:"e",value:function(t,e){if(t>e){var r=t;t=e,e=r}return"e"+t+"_"+e}},{key:"drawOnHover",value:function(t,e,r,n){var o=this;e.setLineDash([5,5]);var a=t.id.substring(1);this.graph.edges().forEach(function(i){var s=i.id.substring(1).split("_");if(s[0]==a){var c="#0ff",u=t,l=o.graph.nodes("n"+s[1]);o.drawEdge(i,u,l,c,e,r),n&&n(i,u,l,c,e,r)}else if(s[1]==a){var c="#0ff",u=o.graph.nodes("n"+s[0]),l=t;o.drawEdge(i,u,l,c,e,r),n&&n(i,u,l,c,e,r)}})}},{key:"drawEdge",value:function(t,e,r,n,o,a){var i=a("prefix")||"",s=t[i+"size"]||1;o.strokeStyle=n,o.lineWidth=s,o.beginPath(),o.moveTo(e[i+"x"],e[i+"y"]),o.lineTo(r[i+"x"],r[i+"y"]),o.stroke()}}]),e}(c),l=function(t){t.s.settings({defaultEdgeType:"def",funcEdgesDef:function(e,r,n,o,a){var i=t.getColor(e,r,n,a);t.drawEdge(e,r,n,i,o,a)}})};e.exports=u},{"./directed_graph":44}],44:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function a(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=function h(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:h(o,e,r)}if("value"in n)return n.value;var a=n.get;if(void 0!==a)return a.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./tracer"),u=t("../../tracer_manager/util/index"),l=u.refineByType,f=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.color={selected:"#0f0",visited:"#f00",left:"#000","default":"#888"},r.isNew&&p(r),r}return a(e,t),s(e,null,[{key:"getClassName",value:function(){return"DirectedGraphTracer"}}]),s(e,[{key:"_setTreeData",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"setTreeData",arguments:arguments}),this}},{key:"_visit",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"visit",target:t,source:e}),this}},{key:"_leave",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"leave",target:t,source:e}),this}},{key:"processStep",value:function(t,r){switch(t.type){case"setTreeData":this.setTreeData.apply(this,t.arguments);break;case"visit":case"leave":var n="visit"==t.type,o=this.graph.nodes(this.n(t.target)),a=n?this.color.visited:this.color.left;if(o.color=a,void 0!==t.source){var s=this.e(t.source,t.target),c=this.graph.edges(s);c.color=a,this.graph.dropEdge(s).addEdge(c)}if(this.logTracer){var u=t.source;void 0===u&&(u=""),this.logTracer.print(n?u+" -> "+t.target:u+" <- "+t.target)}break;default:i(Object.getPrototypeOf(e.prototype),"processStep",this).call(this,t,r)}}},{key:"setTreeData",value:function(t,e,r){var n=this;e=e||0;var o=-1,a=new Array(t.length),i=function l(e,r){if(a[e])throw"the given graph is not a tree because it forms a circuit";a[e]=!0,r>o&&(o=r);for(var n=0;n<t[e].length;n++)t[e][n]&&l(n,r+1)};if(i(e,1),this.setData(t,r))return!0;var s=function(t,e,r){var o=n.graph.nodes(n.n(t));o.x=e,o.y=r},c=1/(o-1),u=function f(e,r,n,o){s(e,n+o,r*c);for(var a=0,i=0;i<t[e].length;i++)t[e][i]&&a++;for(var u=(o-n)/a,l=0,i=0;i<t[e].length;i++)t[e][i]&&f(i,r+1,n+u*l,n+u*++l)};u(e,0,0,1),this.refresh()}},{key:"setData",value:function(t,r){if(i(Object.getPrototypeOf(e.prototype),"setData",this).apply(this,arguments))return!0;this.graph.clear();for(var n=[],o=[],a=2*Math.PI/t.length,s=0,c=0;c<t.length;c++)if(s+=a,n.push({id:this.n(c),label:""+c,x:.5+Math.sin(s)/2,y:.5+Math.cos(s)/2,size:1,color:this.color["default"],weight:0}),r)for(var u=0;c>=u;u++){var f=t[c][u]||t[u][c];f&&o.push({id:this.e(c,u),source:this.n(c),target:this.n(u),color:this.color["default"],size:1,weight:l(f)})}else for(var p=0;p<t[c].length;p++)t[c][p]&&o.push({id:this.e(c,p),source:this.n(c),target:this.n(p),color:this.color["default"],size:1,weight:l(t[c][p])});return this.graph.read({nodes:n,edges:o}),this.s.camera.goTo({x:0,y:0,angle:0,ratio:1}),this.refresh(),!1}},{key:"resize",value:function(){i(Object.getPrototypeOf(e.prototype),"resize",this).call(this),this.s.renderers[0].resize(),this.refresh()}},{key:"refresh",value:function(){i(Object.getPrototypeOf(e.prototype),"refresh",this).call(this),this.s.refresh()}},{key:"clear",value:function(){i(Object.getPrototypeOf(e.prototype),"clear",this).call(this),this.clearGraphColor(),this.refresh()}},{key:"clearGraphColor",value:function(){var t=this;this.graph.nodes().forEach(function(e){e.color=t.color["default"]}),this.graph.edges().forEach(function(e){e.color=t.color["default"]})}},{key:"n",value:function(t){return"n"+t}},{key:"e",value:function(t,e){return"e"+t+"_"+e}},{key:"getColor",value:function(t,e,r,n){var o=t.color,a=n("edgeColor"),i=n("defaultNodeColor"),s=n("defaultEdgeColor");if(!o)switch(a){case"source":o=e.color||i;break;case"target":o=r.color||i;break;default:o=s}return o}},{key:"drawLabel",value:function(t,e,r){var n,o=r("prefix")||"",a=t[o+"size"];a<r("labelThreshold")||t.label&&"string"==typeof t.label&&(n="fixed"===r("labelSize")?r("defaultLabelSize"):r("labelSizeRatio")*a,e.font=(r("fontStyle")?r("fontStyle")+" ":"")+n+"px "+r("font"),e.fillStyle="node"===r("labelColor")?t.color||r("defaultNodeColor"):r("defaultLabelColor"),e.textAlign="center",e.fillText(t.label,Math.round(t[o+"x"]),Math.round(t[o+"y"]+n/3)))}},{key:"drawArrow",value:function(t,e,r,n,o,a){var i=a("prefix")||"",s=t[i+"size"]||1,c=r[i+"size"],u=e[i+"x"],l=e[i+"y"],f=r[i+"x"],p=r[i+"y"],h=Math.atan2(p-l,f-u),d=3;u+=Math.sin(h)*d,f+=Math.sin(h)*d,l+=-Math.cos(h)*d,p+=-Math.cos(h)*d;var v=Math.max(2.5*s,a("minArrowSize")),g=Math.sqrt(Math.pow(f-u,2)+Math.pow(p-l,2)),y=u+(f-u)*(g-v-c)/g,m=l+(p-l)*(g-v-c)/g,w=(f-u)*v/g,b=(p-l)*v/g;o.strokeStyle=n,o.lineWidth=s,o.beginPath(),o.moveTo(u,l),o.lineTo(y,m),o.stroke(),o.fillStyle=n,o.beginPath(),o.moveTo(y+w,m+b),o.lineTo(y+.6*b,m-.6*w),o.lineTo(y-.6*b,m+.6*w),o.lineTo(y+w,m+b),o.closePath(),o.fill()}},{key:"drawOnHover",value:function(t,e,r,n){var o=this;e.setLineDash([5,5]);var a=t.id.substring(1);this.graph.edges().forEach(function(i){var s=i.id.substring(1).split("_");if(s[0]==a){var c="#0ff",u=t,l=o.graph.nodes("n"+s[1]);o.drawArrow(i,u,l,c,e,r),n&&n(i,u,l,c,e,r)}else if(s[1]==a){var c="#ff0",u=o.graph.nodes("n"+s[0]),l=t;o.drawArrow(i,u,l,c,e,r),n&&n(i,u,l,c,e,r)}})}}]),e}(c),p=function(t){t.s=t.capsule.s=new sigma({renderer:{container:t.$container[0],type:"canvas"},settings:{minArrowSize:8,defaultEdgeType:"arrow",maxEdgeSize:2.5,labelThreshold:4,font:"Roboto",defaultLabelColor:"#fff",zoomMin:.6,zoomMax:1.2,skipErrors:!0,minNodeSize:.5,maxNodeSize:12,labelSize:"proportional",labelSizeRatio:1.3,funcLabelsDef:function(e,r,n){t.drawLabel(e,r,n)},funcHoversDef:function(e,r,n,o){t.drawOnHover(e,r,n,o)},funcEdgesArrow:function(e,r,n,o,a){var i=t.getColor(e,r,n,a);t.drawArrow(e,r,n,i,o,a)}}}),sigma.plugins.dragNodes(t.s,t.s.renderers[0]),t.graph=t.capsule.graph=t.s.graph};sigma.canvas.labels.def=function(t,e,r){var n=r("funcLabelsDef");n&&n(t,e,r)},sigma.canvas.hovers.def=function(t,e,r){var n=r("funcHoversDef");n&&n(t,e,r)},sigma.canvas.edges.def=function(t,e,r,n,o){var a=o("funcEdgesDef");a&&a(t,e,r,n,o)},sigma.canvas.edges.arrow=function(t,e,r,n,o){var a=o("funcEdgesArrow");a&&a(t,e,r,n,o)},e.exports=f},{"../../tracer_manager/util/index":67,"./tracer":47}],45:[function(t,e,r){"use strict";var n=t("./tracer"),o=t("./log"),a=t("./array1d"),i=t("./array2d"),s=t("./chart"),c=t("./coordinate_system"),u=t("./directed_graph"),l=t("./undirected_graph"),f=t("./weighted_directed_graph"),p=t("./weighted_undirected_graph");e.exports={Tracer:n,LogTracer:o,Array1DTracer:a,Array2DTracer:i,ChartTracer:s,CoordinateSystemTracer:c,DirectedGraphTracer:u,UndirectedGraphTracer:l,WeightedDirectedGraphTracer:f,WeightedUndirectedGraphTracer:p}},{"./array1d":40,"./array2d":41,"./chart":42,"./coordinate_system":43,"./directed_graph":44,"./log":46,"./tracer":47,"./undirected_graph":48,"./weighted_directed_graph":49,"./weighted_undirected_graph":50}],46:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function a(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=function f(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:f(o,e,r)}if("value"in n)return n.value;var a=n.get;if(void 0!==a)return a.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./tracer"),u=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.isNew&&l(r),r}return a(e,t),s(e,null,[{key:"getClassName",value:function(){return"LogTracer"}}]),s(e,[{key:"_print",value:function(t){return this.manager.pushStep(this.capsule,{type:"print",msg:t}),this}},{key:"processStep",value:function(t,e){switch(t.type){case"print":this.print(t.msg)}}},{key:"refresh",value:function(){this.scrollToEnd(Math.min(50,this.interval))}},{key:"clear",value:function(){i(Object.getPrototypeOf(e.prototype),"clear",this).call(this),this.$wrapper.empty()}},{key:"print",value:function(t){this.$wrapper.append($("<span>").append(t+"<br/>"))}},{key:"scrollToEnd",value:function(t){this.$container.animate({scrollTop:this.$container[0].scrollHeight},t)}}]),e}(c),l=function(t){t.$wrapper=t.capsule.$wrapper=$('<div class="wrapper">'),t.$container.append(t.$wrapper)};e.exports=u},{"./tracer":47}],47:[function(t,e,r){"use strict";function n(t){if(Array.isArray(t)){for(var e=0,r=Array(t.length);e<t.length;e++)r[e]=t[e];return r}return Array.from(t)}function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}var a=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),i=t("../../app"),s=t("../../tracer_manager/util/index"),c=s.toJSON,u=s.fromJSON,l=function(){function t(e){o(this,t),this.module=this.constructor,this.manager=i.getTracerManager(),this.capsule=this.manager.allocate(this),$.extend(this,this.capsule),this.setName(e)}return a(t,null,[{key:"getClassName",value:function(){return"Tracer"}}]),a(t,[{key:"_setData",value:function(){for(var t=arguments.length,e=Array(t),r=0;t>r;r++)e[r]=arguments[r];return this.manager.pushStep(this.capsule,{type:"setData",args:c(e)}),this}},{key:"_clear",value:function(){return this.manager.pushStep(this.capsule,{type:"clear"}),this}},{key:"_wait",value:function(t){return this.manager.newStep(t),this}},{key:"processStep",value:function(t,e){var r=t.type,o=t.args;switch(r){case"setData":this.setData.apply(this,n(u(o)));break;case"clear":this.clear()}}},{key:"setName",value:function(t){var e=void 0;this.isNew?(e=$('<span class="name">'),this.$container.append(e)):e=this.$container.find("span.name"),e.text(t||this.defaultName)}},{key:"setData",value:function(){var t=c(arguments);return this.isNew||this.lastData!==t?(this.lastData=this.capsule.lastData=t,!1):!0}},{key:"resize",value:function(){}},{key:"refresh",value:function(){}},{key:"clear",value:function(){}},{key:"attach",value:function(t){switch(t.module){case LogTracer:this.logTracer=t;break;case ChartTracer:this.chartTracer=t}return this}},{key:"mousedown",value:function(t){}},{key:"mousemove",value:function(t){}},{key:"mouseup",value:function(t){}},{key:"mousewheel",value:function(t){}}]),t}();e.exports=l},{"../../app":3,"../../tracer_manager/util/index":67}],48:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function a(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=function f(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:f(o,e,r)}if("value"in n)return n.value;var a=n.get;if(void 0!==a)return a.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./directed_graph"),u=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.isNew&&l(r),r}return a(e,t),s(e,null,[{key:"getClassName",value:function(){return"UndirectedGraphTracer"}}]),s(e,[{key:"setTreeData",value:function(t,r){return i(Object.getPrototypeOf(e.prototype),"setTreeData",this).call(this,t,r,!0)}},{key:"setData",value:function(t){return i(Object.getPrototypeOf(e.prototype),"setData",this).call(this,t,!0)}},{key:"e",value:function(t,e){if(t>e){var r=t;t=e,e=r}return"e"+t+"_"+e}},{key:"drawOnHover",value:function(t,e,r,n){var o=this;e.setLineDash([5,5]);var a=t.id.substring(1);this.graph.edges().forEach(function(i){var s=i.id.substring(1).split("_");if(s[0]==a){var c="#0ff",u=t,l=o.graph.nodes("n"+s[1]);o.drawEdge(i,u,l,c,e,r),n&&n(i,u,l,c,e,r)}else if(s[1]==a){var c="#0ff",u=o.graph.nodes("n"+s[0]),l=t;o.drawEdge(i,u,l,c,e,r),n&&n(i,u,l,c,e,r)}})}},{key:"drawEdge",value:function(t,e,r,n,o,a){var i=a("prefix")||"",s=t[i+"size"]||1;o.strokeStyle=n,o.lineWidth=s,o.beginPath(),o.moveTo(e[i+"x"],e[i+"y"]),o.lineTo(r[i+"x"],r[i+"y"]),o.stroke()}}]),e}(c),l=function(t){t.s.settings({defaultEdgeType:"def",funcEdgesDef:function(e,r,n,o,a){var i=t.getColor(e,r,n,a);t.drawEdge(e,r,n,i,o,a)}})};e.exports=u},{"./directed_graph":44}],49:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function a(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=function h(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:h(o,e,r)}if("value"in n)return n.value;var a=n.get;if(void 0!==a)return a.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./directed_graph"),u=t("../../tracer_manager/util/index"),l=u.refineByType,f=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.isNew&&p(r),r}return a(e,t),s(e,null,[{key:"getClassName",value:function(){return"WeightedDirectedGraphTracer"}}]),s(e,[{key:"_weight",value:function(t,e){return this.manager.pushStep(this.capsule,{type:"weight",target:t,weight:e}),this}},{key:"_visit",value:function(t,e,r){return this.manager.pushStep(this.capsule,{type:"visit",target:t,source:e,weight:r}),this}},{key:"_leave",value:function(t,e,r){return this.manager.pushStep(this.capsule,{type:"leave",target:t,source:e,weight:r}),this}},{key:"processStep",value:function(t,r){switch(t.type){case"weight":var n=this.graph.nodes(this.n(t.target));void 0!==t.weight&&(n.weight=l(t.weight));break;case"visit":case"leave":var o="visit"==t.type,n=this.graph.nodes(this.n(t.target)),a=o?void 0===t.weight?this.color.selected:this.color.visited:this.color.left;if(n.color=a,void 0!==t.weight&&(n.weight=l(t.weight)),void 0!==t.source){var s=this.e(t.source,t.target),c=this.graph.edges(s);c.color=a,this.graph.dropEdge(s).addEdge(c)}if(this.logTracer){var u=t.source;void 0===u&&(u=""),this.logTracer.print(o?u+" -> "+t.target:u+" <- "+t.target)}break;default:i(Object.getPrototypeOf(e.prototype),"processStep",this).call(this,t,r)}}},{key:"clear",value:function(){i(Object.getPrototypeOf(e.prototype),"clear",this).call(this),this.clearWeights()}},{key:"clearWeights",value:function(){this.graph.nodes().forEach(function(t){t.weight=0})}},{key:"drawEdgeWeight",value:function(t,e,r,n,o,a){if(e!=r){var i=a("prefix")||"",s=t[i+"size"]||1;if(!(s<a("edgeLabelThreshold"))){if(0===a("edgeLabelSizePowRatio"))throw'"edgeLabelSizePowRatio" must not be 0.';var c,u=(e[i+"x"]+r[i+"x"])/2,l=(e[i+"y"]+r[i+"y"])/2,f=r[i+"x"]-e[i+"x"],p=r[i+"y"]-e[i+"y"],h=Math.atan2(p,f);c="fixed"===a("edgeLabelSize")?a("defaultEdgeLabelSize"):a("defaultEdgeLabelSize")*s*Math.pow(s,-1/a("edgeLabelSizePowRatio")),o.save(),t.active?(o.font=[a("activeFontStyle"),c+"px",a("activeFont")||a("font")].join(" "),o.fillStyle=n):(o.font=[a("fontStyle"),c+"px",a("font")].join(" "),o.fillStyle=n),o.textAlign="center",o.textBaseline="alphabetic",o.translate(u,l),o.rotate(h),o.fillText(t.weight,0,-s/2-3),o.restore()}}}},{key:"drawNodeWeight",value:function(t,e,r){var n,o=r("prefix")||"",a=t[o+"size"];a<r("labelThreshold")||(n="fixed"===r("labelSize")?r("defaultLabelSize"):r("labelSizeRatio")*a,e.font=(r("fontStyle")?r("fontStyle")+" ":"")+n+"px "+r("font"),e.fillStyle="node"===r("labelColor")?t.color||r("defaultNodeColor"):r("defaultLabelColor"),e.textAlign="left",e.fillText(t.weight,Math.round(t[o+"x"]+1.5*a),Math.round(t[o+"y"]+n/3)))}}]),e}(c),p=function(t){t.s.settings({edgeLabelSize:"proportional",defaultEdgeLabelSize:20,edgeLabelSizePowRatio:.8,funcLabelsDef:function(e,r,n){t.drawNodeWeight(e,r,n),t.drawLabel(e,r,n)},funcHoversDef:function(e,r,n){t.drawOnHover(e,r,n,t.drawEdgeWeight)},funcEdgesArrow:function(e,r,n,o,a){var i=t.getColor(e,r,n,a);t.drawArrow(e,r,n,i,o,a),t.drawEdgeWeight(e,r,n,i,o,a)}})};e.exports=f},{"../../tracer_manager/util/index":67,"./directed_graph":44}],50:[function(t,e,r){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function a(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}var i=function p(t,e,r){null===t&&(t=Function.prototype);var n=Object.getOwnPropertyDescriptor(t,e);if(void 0===n){var o=Object.getPrototypeOf(t);return null===o?void 0:p(o,e,r)}if("value"in n)return n.value;var a=n.get;if(void 0!==a)return a.call(r)},s=function(){function t(t,e){for(var r=0;r<e.length;r++){var n=e[r];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,r,n){return r&&t(e.prototype,r),n&&t(e,n),e}}(),c=t("./weighted_directed_graph"),u=t("./undirected_graph"),l=function(t){function e(t){n(this,e);var r=o(this,Object.getPrototypeOf(e).call(this,t));return r.e=u.prototype.e,r.drawOnHover=u.prototype.drawOnHover,r.drawEdge=u.prototype.drawEdge,r.isNew&&f(r),r}return a(e,t),s(e,null,[{key:"getClassName",value:function(){return"WeightedUndirectedGraphTracer"}}]),s(e,[{key:"setTreeData",value:function(t,r){return i(Object.getPrototypeOf(e.prototype),"setTreeData",this).call(this,t,r,!0)}},{key:"setData",value:function(t){return i(Object.getPrototypeOf(e.prototype),"setData",this).call(this,t,!0)}},{key:"drawEdgeWeight",value:function(t,e,r,n,o,a){var i=a("prefix")||"";if(e[i+"x"]>r[i+"x"]){var s=e;e=r,r=s}c.prototype.drawEdgeWeight.call(this,t,e,r,n,o,a)}}]),e}(c),f=function(t){t.s.settings({defaultEdgeType:"def",funcEdgesDef:function(e,r,n,o,a){var i=t.getColor(e,r,n,a);t.drawEdge(e,r,n,i,o,a),t.drawEdgeWeight(e,r,n,i,o,a)}})};e.exports=l},{"./undirected_graph":48,"./weighted_directed_graph":49}],51:[function(t,e,r){"use strict";var n=t("./request");e.exports=function(t){return n(t,{type:"GET"})}},{"./request":54}],52:[function(t,e,r){"use strict";var n=t("./request");e.exports=function(t){return n(t,{dataType:"json",type:"GET"})}},{"./request":54}],53:[function(t,e,r){"use strict";var n=t("./request");e.exports=function(t,e){return n(t,{dataType:"json",type:"POST",data:JSON.stringify(e)})}},{"./request":54}],54:[function(t,e,r){"use strict";var n=t("rsvp"),o=t("../../app"),a=$,i=a.ajax,s=a.extend,c={};e.exports=function(t){var e=arguments.length<=1||void 0===arguments[1]?{}:arguments[1];return o.setIsLoading(!0),new n.Promise(function(r,n){var a={success:function(t){o.setIsLoading(!1),r(t)},error:function(t){o.setIsLoading(!1),n(t)}},u=s({},c,e,a,{url:t});i(u)})}},{"../../app":3,rsvp:72}],55:[function(t,e,r){"use strict";var n=function(){function t(t,e){var r=[],n=!0,o=!1,a=void 0;try{for(var i,s=t[Symbol.iterator]();!(n=(i=s.next()).done)&&(r.push(i.value),!e||r.length!==e);n=!0);}catch(c){o=!0,a=c}finally{try{!n&&s["return"]&&s["return"]()}finally{if(o)throw a}}return r}return function(e,r){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e))return t(e,r);throw new TypeError("Invalid attempt to destructure non-iterable instance")}}(),o=t("../app"),a=t("../dom/toast"),i=function(){return o.getIsLoading()?(a.showErrorToast("Wait until it completes loading of previous file."),!0):!1},s=function(t){var e=window.location.href,r=new RegExp("[?&]"+t+"(=([^&#]*)|&|#|$)"),o=r.exec(e);if(!o||3!==o.length)return null;var a=n(o,3),i=a[2];return i},c=function(t){if(!t)return null;for(var e=window.location.hash.substr(1),r=e?e.split("&"):[],n=0;n<r.length;n++){var o=r[n].split("=");if(o[0]===t)return o[1]}return null},u=function(t,e){if(t&&e){for(var r=window.location.hash.substr(1),n=r?r.split("&"):[],o=!1,a=0;a<n.length&&!o;a++){var i=n[a].split("=");i[0]===t&&(i[1]=e,n[a]=i.join("="),o=!0)}o||n.push([t,e].join("="));var s=n.join("&");window.location.hash="#"+s}},l=function(t){if(t){for(var e=window.location.hash.substr(1),r=e?e.split("&"):[],n=0;n<r.length;n++){var o=r[n].split("=");if(o[0]===t){r.splice(n,1);break}}var a=r.join("&");window.location.hash="#"+a}},f=function(t,e,r){var n=t?t+(e?"/"+e+(r?"/"+r:""):""):"";u("path",n)},p=function(){var t=c("path");if(t){var e=t.split("/"),r=n(e,3),o=r[0],a=r[1],i=r[2];return{category:o,algorithm:a,file:i}}return!1};e.exports={checkLoading:i,getParameterByName:s,getHashValue:c,setHashValue:u,removeHashValue:l,setPath:f,getPath:p}},{"../app":3,"../dom/toast":24}],56:[function(t,e,r){"use strict";var n=t("./load_algorithm"),o=t("./load_categories"),a=t("./load_file"),i=t("./load_scratch_paper"),s=t("./share_scratch_paper"),c=t("./load_wiki_list"),u=t("./load_wiki");e.exports={loadAlgorithm:n,loadCategories:o,loadFile:a,loadScratchPaper:i,shareScratchPaper:s,loadWikiList:c,loadWiki:u}},{"./load_algorithm":57,"./load_categories":58,"./load_file":59,"./load_scratch_paper":60,"./load_wiki":61,"./load_wiki_list":62,"./share_scratch_paper":63}],57:[function(t,e,r){"use strict";var n=t("./ajax/get_json"),o=t("../utils"),a=o.getAlgorithmDir;e.exports=function(t,e){var r=a(t,e);return n(r+"desc.json")}},{"../utils":70,"./ajax/get_json":52}],58:[function(t,e,r){"use strict";var n=t("./ajax/get_json");e.exports=function(){return n("./algorithm/category.json")}},{"./ajax/get_json":52}],59:[function(t,e,r){"use strict";var n=t("rsvp"),o=t("../app"),a=t("../utils"),i=a.getFileDir,s=a.isScratchPaper,c=t("./helpers"),u=c.checkLoading,l=c.setPath,f=t("./ajax/get"),p=function(t){return n.hash({data:f(t+"data.js"),code:f(t+"code.js")})},h=function(t){return o.getEditor().clearContent(),p(t).then(function(e){o.updateCachedFile(t,e),o.getEditor().setContent(e)})},d=function(t){return t&&void 0!==t.data&&void 0!==t.code};e.exports=function(t,e,r,a){return new n.Promise(function(n,c){if(u())c();else{s(t)?l(t,o.getLoadedScratch()):l(t,e,r),$("#explanation").html(a);var f=i(t,e,r);o.setLastFileUsed(f);var p=o.getCachedFile(f);d(p)?(o.getEditor().setContent(p),n()):h(f).then(n,c)}})}},{"../app":3,"../utils":70,"./ajax/get":51,"./helpers":55,rsvp:72}],60:[function(t,e,r){"use strict";var n=t("rsvp"),o=t("../app"),a=t("../utils"),i=a.getFileDir,s=t("./ajax/get_json"),c=t("./load_algorithm"),u=function(t,e){return t[e+".js"].content};e.exports=function(t){return new n.Promise(function(e,r){o.setLoadedScratch(t),s("https://api.github.com/gists/"+t).then(function(r){var n=r.files,a="scratch",s=t;c(a,s).then(function(t){var r=u(n,"data"),c=u(n,"code"),l=i(a,s,"scratch_paper");o.updateCachedFile(l,{data:r,code:c,"CREDIT.md":"Shared by an anonymous user from http://parkjs814.github.io/AlgorithmVisualizer"}),e({category:a,algorithm:s,data:t})})})})}},{"../app":3,"../utils":70,"./ajax/get_json":52,"./load_algorithm":57,rsvp:72}],61:[function(t,e,r){"use strict";var n=t("./ajax/get");e.exports=function(t){return n("./AlgorithmVisualizer.wiki/"+t+".md")}},{"./ajax/get":51}],62:[function(t,e,r){"use strict";var n=t("./ajax/get_json");e.exports=function(){return n("./wiki.json")}},{"./ajax/get_json":52}],63:[function(t,e,r){"use strict";var n=t("rsvp"),o=t("../app"),a=t("./ajax/post_json"),i=t("./helpers"),s=i.setPath;e.exports=function(){return new n.Promise(function(t,e){var r=o.getEditor(),n=r.dataEditor,i=r.codeEditor,c={description:"temp","public":!0,files:{"data.js":{content:n.getValue()},"code.js":{content:i.getValue()}}};a("https://api.github.com/gists",c).then(function(e){ +var r=e.id;o.setLoadedScratch(r),s("scratch",r);var n=location,a=n.href;$("#algorithm").html("Shared"),t(a)})})}},{"../app":3,"./ajax/post_json":53,"./helpers":55,rsvp:72}],64:[function(t,e,r){"use strict";var n=t("./manager"),o=t("../module/tracer/tracer");e.exports={init:function(){var t=new n;return o.prototype.manager=t,t}}},{"../module/tracer/tracer":47,"./manager":65}],65:[function(t,e,r){"use strict";var n=t("../app"),o=t("../dom/module_container"),a=t("../dom/top_menu"),i=$,s=i.each,c=i.extend,u=i.grep,l=1e6,f=function(){this.timer=null,this.pause=!1,this.capsules=[],this.interval=500};f.prototype={add:function(t){var e=o.create(),r={module:t.module,tracer:t,allocated:!0,defaultName:null,$container:e,isNew:!0};return this.capsules.push(r),r},allocate:function(t){var e=null,r=0;s(this.capsules,function(n,o){return o.module!==t.module||(r++,o.allocated)?void 0:(o.tracer=t,o.allocated=!0,o.isNew=!1,e=o,!1)}),null===e&&(r++,e=this.add(t));var n=t.module.getClassName();return e.defaultName=n+" "+r,e.order=this.order++,e},deallocateAll:function(){this.order=0,this.reset(),s(this.capsules,function(t,e){e.allocated=!1})},removeUnallocated:function(){var t=!1;this.capsules=u(this.capsules,function(e){var r=!e.allocated;return(e.isNew||r)&&(t=!0),r&&e.$container.remove(),!r}),t&&this.place()},place:function(){var t=this.capsules;s(t,function(e,r){var n=100,o=100/t.length,a=o*r.order;r.$container.css({top:a+"%",width:n+"%",height:o+"%"}),r.tracer.resize()})},resize:function(){this.command("resize")},isPause:function(){return this.pause},setInterval:function(t){a.setInterval(t)},reset:function(){this.traces=[],this.traceIndex=-1,this.stepCnt=0,this.timer&&clearTimeout(this.timer),this.command("clear")},pushStep:function(t,e){if(this.stepCnt++>l)throw"Tracer's stack overflow";var r=this.traces.length;0==r&&(r+=this.newStep());var n=this.traces[r-1];n.push(c(e,{capsule:t}))},newStep:function(){var t=arguments.length<=0||void 0===arguments[0]?-1:arguments[0],e=this.traces.length;return e>0&&~t&&this.traces[e-1].push(t),this.traces.push([])},pauseStep:function(){this.traceIndex<0||(this.pause=!0,this.timer&&clearTimeout(this.timer),a.activateBtnPause())},resumeStep:function(){this.pause=!1,this.step(this.traceIndex+1),a.deactivateBtnPause()},step:function(t){var e=arguments.length<=1||void 0===arguments[1]?{}:arguments[1],r=this;if(!(isNaN(t)||t>=this.traces.length||0>t)){this.traceIndex=t;var o=this.traces[t];o.forEach(function(t){return"number"==typeof t?void n.getEditor().highlightLine(t):void t.capsule.tracer.processStep(t,e)}),e.virtual||this.command("refresh"),this.pause||(this.timer=setTimeout(function(){r.nextStep(e)||a.resetTopMenuButtons()},this.interval))}},prevStep:function(){var t=arguments.length<=0||void 0===arguments[0]?{}:arguments[0];this.command("clear");var e=this.traceIndex-1;if(0>e)return this.traceIndex=-1,this.command("refresh"),!1;for(var r=0;e>r;r++)this.step(r,c(t,{virtual:!0}));return this.step(e),!0},nextStep:function(){var t=arguments.length<=0||void 0===arguments[0]?{}:arguments[0],e=this.traceIndex+1;return e>=this.traces.length?(this.traceIndex=this.traces.length-1,!1):(this.step(e,t),!0)},visualize:function(){this.traceIndex=-1,this.resumeStep()},command:function(){for(var t=arguments.length,e=Array(t),r=0;t>r;r++)e[r]=arguments[r];var n=e.shift();s(this.capsules,function(t,r){r.allocated&&r.tracer.module.prototype[n].apply(r.tracer,e)})},findOwner:function(t){var e=null;return s(this.capsules,function(r,n){return n.$container[0]===t?(e=n,!1):void 0}),e.tracer}},e.exports=f},{"../app":3,"../dom/module_container":8,"../dom/top_menu":25}],66:[function(t,e,r){"use strict";var n=JSON.parse,o=function(t){return n(t,function(t,e){return"Infinity"===e?1/0:e})};e.exports=o},{}],67:[function(t,e,r){"use strict";var n=t("./to_json"),o=t("./from_json"),a=t("./refine_by_type");e.exports={toJSON:n,fromJSON:o,refineByType:a}},{"./from_json":66,"./refine_by_type":68,"./to_json":69}],68:[function(t,e,r){"use strict";var n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol?"symbol":typeof t},o=function(t){switch("undefined"==typeof t?"undefined":n(t)){case"number":return i(t);case"boolean":return s(t);default:return a(t)}},a=function(t){return""===t?" ":t},i=function(t){return t===1/0?"∞":t},s=function(t){return t?"T":"F"};e.exports=o},{}],69:[function(t,e,r){"use strict";var n=JSON.stringify,o=function(t){return n(t,function(t,e){return e===1/0?"Infinity":e})};e.exports=o},{}],70:[function(t,e,r){"use strict";var n=function(t,e){return"scratch"==t},o=function(t,e){return n(t)?"./algorithm/scratch_paper/":"./algorithm/"+t+"/"+e+"/"},a=function(t,e,r){return n(t)?"./algorithm/scratch_paper/":"./algorithm/"+t+"/"+e+"/"+r+"/"};e.exports={isScratchPaper:n,getAlgorithmDir:o,getFileDir:a}},{}],71:[function(t,e,r){function n(){l&&s&&(l=!1,s.length?u=s.concat(u):f=-1,u.length&&o())}function o(){if(!l){var t=setTimeout(n);l=!0;for(var e=u.length;e;){for(s=u,u=[];++f<e;)s&&s[f].run();f=-1,e=u.length}s=null,l=!1,clearTimeout(t)}}function a(t,e){this.fun=t,this.array=e}function i(){}var s,c=e.exports={},u=[],l=!1,f=-1;c.nextTick=function(t){var e=new Array(arguments.length-1);if(arguments.length>1)for(var r=1;r<arguments.length;r++)e[r-1]=arguments[r];u.push(new a(t,e)),1!==u.length||l||setTimeout(o,0)},a.prototype.run=function(){this.fun.apply(null,this.array)},c.title="browser",c.browser=!0,c.env={},c.argv=[],c.version="",c.versions={},c.on=i,c.addListener=i,c.once=i,c.off=i,c.removeListener=i,c.removeAllListeners=i,c.emit=i,c.binding=function(t){throw new Error("process.binding is not supported")},c.cwd=function(){return"/"},c.chdir=function(t){throw new Error("process.chdir is not supported")},c.umask=function(){return 0}},{}],72:[function(t,e,r){(function(r,n){(function(){"use strict";function o(t){return"function"==typeof t||"object"==typeof t&&null!==t}function a(t){return"function"==typeof t}function i(t){return"object"==typeof t&&null!==t}function s(){}function c(t,e){for(var r=0,n=t.length;n>r;r++)if(t[r]===e)return r;return-1}function u(t){var e=t._promiseCallbacks;return e||(e=t._promiseCallbacks={}),e}function l(t,e){return"onerror"===t?void jt.on("error",e):2!==arguments.length?jt[t]:void(jt[t]=e)}function f(){setTimeout(function(){for(var t,e=0;e<$t.length;e++){t=$t[e];var r=t.payload;r.guid=r.key+r.id,r.childGuid=r.key+r.childId,r.error&&(r.stack=r.error.stack),jt.trigger(t.name,t.payload)}$t.length=0},50)}function p(t,e,r){1===$t.push({name:t,payload:{key:e._guidKey,id:e._id,eventName:t,detail:e._result,childId:r&&r._id,label:e._label,timeStamp:kt(),error:jt["instrument-with-stack"]?new Error(e._label):null}})&&f()}function h(t,e,r){var n=this,o=n._state;if(o===It&&!t||o===Rt&&!e)return jt.instrument&&Tt("chained",n,n),n;n._onError=null;var a=new n.constructor(O,r),i=n._result;if(jt.instrument&&Tt("chained",n,a),o){var s=arguments[o-1];jt.async(function(){F(o,a,s,i)})}else L(n,a,t,e);return a}function d(t,e){var r=this;if(t&&"object"==typeof t&&t.constructor===r)return t;var n=new r(O,e);return E(n,t),n}function v(t,e,r){return t===It?{state:"fulfilled",value:r}:{state:"rejected",reason:r}}function g(t,e,r,n){this._instanceConstructor=t,this.promise=new t(O,n),this._abortOnReject=r,this._validateInput(e)?(this._input=e,this.length=e.length,this._remaining=e.length,this._init(),0===this.length?A(this.promise,this._result):(this.length=this.length||0,this._enumerate(),0===this._remaining&&A(this.promise,this._result))):D(this.promise,this._validationError())}function y(t,e){return new Pt(this,t,!0,e).promise}function m(t,e){function r(t){E(a,t)}function n(t){D(a,t)}var o=this,a=new o(O,e);if(!xt(t))return D(a,new TypeError("You must pass an array to race.")),a;for(var i=t.length,s=0;a._state===Ft&&i>s;s++)L(o.resolve(t[s]),void 0,r,n);return a}function w(t,e){var r=this,n=new r(O,e);return D(n,t),n}function b(){throw new TypeError("You must pass a resolver function as the first argument to the promise constructor")}function _(){throw new TypeError("Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.")}function x(t,e){this._id=zt++,this._label=e,this._state=void 0,this._result=void 0,this._subscribers=[],jt.instrument&&Tt("created",this),O!==t&&("function"!=typeof t&&b(),this instanceof x?I(this,t):_())}function k(){return new TypeError("A promises callback cannot return that same promise.")}function O(){}function S(t){try{return t.then}catch(e){return Wt.error=e,Wt}}function j(t,e,r,n){try{t.call(e,r,n)}catch(o){return o}}function $(t,e,r){jt.async(function(t){var n=!1,o=j(r,e,function(r){n||(n=!0,e!==r?E(t,r,void 0):A(t,r))},function(e){n||(n=!0,D(t,e))},"Settle: "+(t._label||" unknown promise"));!n&&o&&(n=!0,D(t,o))},t)}function T(t,e){e._state===It?A(t,e._result):e._state===Rt?(e._onError=null,D(t,e._result)):L(e,void 0,function(r){e!==r?E(t,r,void 0):A(t,r)},function(e){D(t,e)})}function C(t,e,r){e.constructor===t.constructor&&r===Ct&&constructor.resolve===Et?T(t,e):r===Wt?D(t,Wt.error):void 0===r?A(t,e):a(r)?$(t,e,r):A(t,e)}function E(t,e){t===e?A(t,e):o(e)?C(t,e,S(e)):A(t,e)}function P(t){t._onError&&t._onError(t._result),M(t)}function A(t,e){t._state===Ft&&(t._result=e,t._state=It,0===t._subscribers.length?jt.instrument&&Tt("fulfilled",t):jt.async(M,t))}function D(t,e){t._state===Ft&&(t._state=Rt,t._result=e,jt.async(P,t))}function L(t,e,r,n){var o=t._subscribers,a=o.length;t._onError=null,o[a]=e,o[a+It]=r,o[a+Rt]=n,0===a&&t._state&&jt.async(M,t)}function M(t){var e=t._subscribers,r=t._state;if(jt.instrument&&Tt(r===It?"fulfilled":"rejected",t),0!==e.length){for(var n,o,a=t._result,i=0;i<e.length;i+=3)n=e[i],o=e[i+r],n?F(r,n,o,a):o(a);t._subscribers.length=0}}function z(){this.error=null}function N(t,e){try{return t(e)}catch(r){return qt.error=r,qt}}function F(t,e,r,n){var o,i,s,c,u=a(r);if(u){if(o=N(r,n),o===qt?(c=!0,i=o.error,o=null):s=!0,e===o)return void D(e,k())}else o=n,s=!0;e._state!==Ft||(u&&s?E(e,o):c?D(e,i):t===It?A(e,o):t===Rt&&D(e,o))}function I(t,e){var r=!1;try{e(function(e){r||(r=!0,E(t,e))},function(e){r||(r=!0,D(t,e))})}catch(n){D(t,n)}}function R(t,e,r){this._superConstructor(t,e,!1,r)}function W(t,e){return new R(Nt,t,e).promise}function q(t,e){return Nt.all(t,e)}function U(t,e){te[Gt]=t,te[Gt+1]=e,Gt+=2,2===Gt&&Vt()}function V(){var t=r.nextTick,e=r.versions.node.match(/^(?:(\d+)\.)?(?:(\d+)\.)?(\*|\d+)$/);return Array.isArray(e)&&"0"===e[1]&&"10"===e[2]&&(t=setImmediate),function(){t(X)}}function H(){return function(){Ut(X)}}function B(){var t=0,e=new Kt(X),r=document.createTextNode("");return e.observe(r,{characterData:!0}),function(){r.data=t=++t%2}}function G(){var t=new MessageChannel;return t.port1.onmessage=X,function(){t.port2.postMessage(0)}}function Y(){return function(){setTimeout(X,1)}}function X(){for(var t=0;Gt>t;t+=2){var e=te[t],r=te[t+1];e(r),te[t]=void 0,te[t+1]=void 0}Gt=0}function J(){try{var e=t,r=e("vertx");return Ut=r.runOnLoop||r.runOnContext,H()}catch(n){return Y()}}function K(t){var e={};return e.promise=new Nt(function(t,r){e.resolve=t,e.reject=r},t),e}function Z(t,e,r){return Nt.all(t,r).then(function(t){if(!a(e))throw new TypeError("You must pass a function as filter's second argument.");for(var n=t.length,o=new Array(n),i=0;n>i;i++)o[i]=e(t[i]);return Nt.all(o,r).then(function(e){for(var r=new Array(n),o=0,a=0;n>a;a++)e[a]&&(r[o]=t[a],o++);return r.length=o,r})})}function Q(t,e,r){this._superConstructor(t,e,!0,r)}function tt(t,e,r){this._superConstructor(t,e,!1,r)}function et(t,e){return new tt(Nt,t,e).promise}function rt(t,e){return new ne(Nt,t,e).promise}function nt(t,e,r){return Nt.all(t,r).then(function(t){if(!a(e))throw new TypeError("You must pass a function as map's second argument.");for(var n=t.length,o=new Array(n),i=0;n>i;i++)o[i]=e(t[i]);return Nt.all(o,r)})}function ot(){this.value=void 0}function at(t){try{return t.then}catch(e){return ce.value=e,ce}}function it(t,e,r){try{t.apply(e,r)}catch(n){return ce.value=n,ce}}function st(t,e){for(var r,n,o={},a=t.length,i=new Array(a),s=0;a>s;s++)i[s]=t[s];for(n=0;n<e.length;n++)r=e[n],o[r]=i[n+1];return o}function ct(t){for(var e=t.length,r=new Array(e-1),n=1;e>n;n++)r[n-1]=t[n];return r}function ut(t,e){return{then:function(r,n){return t.call(e,r,n)}}}function lt(t,e){var r=function(){for(var r,n=this,o=arguments.length,a=new Array(o+1),i=!1,s=0;o>s;++s){if(r=arguments[s],!i){if(i=ht(r),i===ue){var c=new Nt(O);return D(c,ue.value),c}i&&i!==!0&&(r=ut(i,r))}a[s]=r}var u=new Nt(O);return a[o]=function(t,r){t?D(u,t):void 0===e?E(u,r):e===!0?E(u,ct(arguments)):xt(e)?E(u,st(arguments,e)):E(u,r)},i?pt(u,a,t,n):ft(u,a,t,n)};return r.__proto__=t,r}function ft(t,e,r,n){var o=it(r,n,e);return o===ce&&D(t,o.value),t}function pt(t,e,r,n){return Nt.all(e).then(function(e){var o=it(r,n,e);return o===ce&&D(t,o.value),t})}function ht(t){return t&&"object"==typeof t?t.constructor===Nt?!0:at(t):!1}function dt(t,e){return Nt.race(t,e)}function vt(t,e){return Nt.reject(t,e)}function gt(t,e){return Nt.resolve(t,e)}function yt(t){throw setTimeout(function(){throw t}),t}function mt(t,e){jt.async(t,e)}function wt(){jt.on.apply(jt,arguments)}function bt(){jt.off.apply(jt,arguments)}var _t;_t=Array.isArray?Array.isArray:function(t){return"[object Array]"===Object.prototype.toString.call(t)};var xt=_t,kt=Date.now||function(){return(new Date).getTime()},Ot=Object.create||function(t){if(arguments.length>1)throw new Error("Second argument not supported");if("object"!=typeof t)throw new TypeError("Argument must be an object");return s.prototype=t,new s},St={mixin:function(t){return t.on=this.on,t.off=this.off,t.trigger=this.trigger,t._promiseCallbacks=void 0,t},on:function(t,e){if("function"!=typeof e)throw new TypeError("Callback must be a function");var r,n=u(this);r=n[t],r||(r=n[t]=[]),-1===c(r,e)&&r.push(e)},off:function(t,e){var r,n,o=u(this);return e?(r=o[t],n=c(r,e),void(-1!==n&&r.splice(n,1))):void(o[t]=[])},trigger:function(t,e,r){var n,o,a=u(this);if(n=a[t])for(var i=0;i<n.length;i++)(o=n[i])(e,r)}},jt={instrument:!1};St.mixin(jt);var $t=[],Tt=p,Ct=h,Et=d,Pt=g;g.prototype._validateInput=function(t){return xt(t)},g.prototype._validationError=function(){return new Error("Array Methods must be provided an Array")},g.prototype._init=function(){this._result=new Array(this.length)},g.prototype._enumerate=function(){for(var t=this.length,e=this.promise,r=this._input,n=0;e._state===Ft&&t>n;n++)this._eachEntry(r[n],n)},g.prototype._settleMaybeThenable=function(t,e){var r=this._instanceConstructor,n=r.resolve;if(n===Et){var o=S(t);if(o===Ct&&t._state!==Ft)t._onError=null,this._settledAt(t._state,e,t._result);else if("function"!=typeof o)this._remaining--,this._result[e]=this._makeResult(It,e,t);else if(r===Nt){var a=new r(O);C(a,t,o),this._willSettleAt(a,e)}else this._willSettleAt(new r(function(e){e(t)}),e)}else this._willSettleAt(n(t),e)},g.prototype._eachEntry=function(t,e){i(t)?this._settleMaybeThenable(t,e):(this._remaining--,this._result[e]=this._makeResult(It,e,t))},g.prototype._settledAt=function(t,e,r){var n=this.promise;n._state===Ft&&(this._remaining--,this._abortOnReject&&t===Rt?D(n,r):this._result[e]=this._makeResult(t,e,r)),0===this._remaining&&A(n,this._result)},g.prototype._makeResult=function(t,e,r){return r},g.prototype._willSettleAt=function(t,e){var r=this;L(t,void 0,function(t){r._settledAt(It,e,t)},function(t){r._settledAt(Rt,e,t)})};var At=y,Dt=m,Lt=w,Mt="rsvp_"+kt()+"-",zt=0,Nt=x;x.cast=Et,x.all=At,x.race=Dt,x.resolve=Et,x.reject=Lt,x.prototype={constructor:x,_guidKey:Mt,_onError:function(t){var e=this;jt.after(function(){e._onError&&jt.trigger("error",t,e._label)})},then:Ct,"catch":function(t,e){return this.then(void 0,t,e)},"finally":function(t,e){var r=this,n=r.constructor;return r.then(function(e){return n.resolve(t()).then(function(){return e})},function(e){return n.resolve(t()).then(function(){return n.reject(e)})},e)}};var Ft=void 0,It=1,Rt=2,Wt=new z,qt=new z;R.prototype=Ot(Pt.prototype),R.prototype._superConstructor=Pt,R.prototype._makeResult=v,R.prototype._validationError=function(){return new Error("allSettled must be called with an array")};var Ut,Vt,Ht=W,Bt=q,Gt=0,Yt=({}.toString,U),Xt="undefined"!=typeof window?window:void 0,Jt=Xt||{},Kt=Jt.MutationObserver||Jt.WebKitMutationObserver,Zt="undefined"==typeof self&&"undefined"!=typeof r&&"[object process]"==={}.toString.call(r),Qt="undefined"!=typeof Uint8ClampedArray&&"undefined"!=typeof importScripts&&"undefined"!=typeof MessageChannel,te=new Array(1e3);Vt=Zt?V():Kt?B():Qt?G():void 0===Xt&&"function"==typeof t?J():Y();var ee=K,re=Z,ne=Q;Q.prototype=Ot(Pt.prototype),Q.prototype._superConstructor=Pt,Q.prototype._init=function(){this._result={}},Q.prototype._validateInput=function(t){return t&&"object"==typeof t},Q.prototype._validationError=function(){return new Error("Promise.hash must be called with an object")},Q.prototype._enumerate=function(){var t=this,e=t.promise,r=t._input,n=[];for(var o in r)e._state===Ft&&Object.prototype.hasOwnProperty.call(r,o)&&n.push({position:o,entry:r[o]});var a=n.length;t._remaining=a;for(var i,s=0;e._state===Ft&&a>s;s++)i=n[s],t._eachEntry(i.entry,i.position)},tt.prototype=Ot(ne.prototype),tt.prototype._superConstructor=Pt,tt.prototype._makeResult=v,tt.prototype._validationError=function(){return new Error("hashSettled must be called with an object")};var oe,ae=et,ie=rt,se=nt,ce=new ot,ue=new ot,le=lt;if("object"==typeof self)oe=self;else{if("object"!=typeof n)throw new Error("no global: `self` or `global` found");oe=n}var fe=oe,pe=dt,he=vt,de=gt,ve=yt;jt.async=Yt,jt.after=function(t){setTimeout(t,0)};if("undefined"!=typeof window&&"object"==typeof window.__PROMISE_INSTRUMENTATION__){var ge=window.__PROMISE_INSTRUMENTATION__;l("instrument",!0);for(var ye in ge)ge.hasOwnProperty(ye)&&wt(ye,ge[ye])}var me={race:pe,Promise:Nt,allSettled:Ht,hash:ie,hashSettled:ae,denodeify:le,on:wt,off:bt,map:se,filter:re,resolve:de,reject:he,all:Bt,rethrow:ve,defer:ee,EventTarget:St,configure:l,async:mt};"function"==typeof define&&define.amd?define(function(){return me}):"undefined"!=typeof e&&e.exports?e.exports=me:"undefined"!=typeof fe&&(fe.RSVP=me)}).call(this)}).call(this,t("_process"),"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{_process:71}]},{},[29]); //# sourceMappingURL=algorithm_visualizer.min.js.map diff --git a/public/algorithm_visualizer.min.js.map b/public/algorithm_visualizer.min.js.map index d69b4a7..15bc94d 100644 --- a/public/algorithm_visualizer.min.js.map +++ b/public/algorithm_visualizer.min.js.map @@ -1 +1 @@ -{"version":3,"sources":["algorithm_visualizer.min.js"],"names":["e","t","n","r","s","o","u","a","require","i","f","Error","code","l","exports","call","length","1","module","_$","$","extend","cache","lastFileUsed","files","assertFileName","name","getCachedFile","updateCachedFile","updates","getLastFileUsed","setLastFileUsed","file","2","Editor","TracerManager","DOM","_require","showLoadingSlider","hideLoadingSlider","Cache","state","isLoading","editor","tracerManager","categories","loadedScratch","wikiList","initState","App","this","getIsLoading","setIsLoading","loading","getEditor","getCategories","getCategory","setCategories","updateCategory","getTracerManager","getLoadedScratch","setLoadedScratch","getWikiList","setWikiList","hasWiki","wiki","indexOf","init","setup","prototype","../dom/loading_slider","../dom/setup","../editor","../tracer_manager","./cache","3","4","app","Server","showAlgorithm","each","getAlgorithmDOM","category","subList","algorithm","append","attr","click","loadAlgorithm","then","data","addCategoryToDOM","_app$getCategory","categoryName","categorySubList","list","$category","$self","toggleClass","next","find","$algorithms","$algorithm","../app","../server","./show_algorithm","5","addFileToDOM","explanation","$file","loadFile","removeClass","addClass","requestedFile","empty","first","scroll","6","addCategories","showDescription","addFiles","showFirstAlgorithm","showRequestedAlgorithm","showWiki","./add_categories","./add_files","./show_description","./show_first_algorithm","./show_requested_algorithm","./show_wiki","7","8","create","$container","9","setupDividers","setupDocument","setupFilesBar","setupInterval","setupModuleContainer","setupTabContainer","setupSideMenu","setupTopMenu","setupWindow","stopPropagation","./setup_dividers","./setup_document","./setup_files_bar","./setup_interval","./setup_module_container","./setup_side_menu","./setup_tab_container","./setup_top_menu","./setup_window","10","_slicedToArray","sliceIterator","arr","_arr","_n","_d","_e","undefined","_s","_i","Symbol","iterator","done","push","value","err","Array","isArray","Object","TypeError","addDividerToDom","divider","_divider","vertical","$first","$second","$parent","parent","thickness","$divider","dragging","_left","css","top","bottom","left","width","x","mousedown","_ref","pageX","document","mousemove","_ref2","new_left","position","percent","Math","min","max","resize","mouseup","_top","height","right","y","_ref3","pageY","_ref4","new_top","dividers","../../app","11","on","href","test","preventDefault","window","open","alert","command","12","definitelyBigger","$wrapper","clipWidth","scrollLeft","children","get","reverse","outerWidth","$left","$right","lefter","righter","13","Toast","parseFloat","Number","minInterval","maxInterval","startInterval","stepInterval","normalize","sec","interval","message","$interval","val","step","_normalize","_normalize2","seconds","showInfoToast","../toast","14","$module_container","findOwner","mousewheel","15","sidemenu_percent","$sidemenu","$workspace","hasClass","../../server","../show_algorithm","16","17","TopMenu","select","$icon","shareScratchPaper","url","$btnRun","$btnTrace","$btnPause","$btnPrev","$btnNext","disableFlowControl","enableFlowControl","execute","console","error","showErrorToast","resetTopMenuButtons","isPause","resumeStep","pauseStep","prevStep","nextStep","../top_menu","18","19","isScratchPaper","$menu","category_name","algorithm_name","categoryObj","html","clearContent","../utils","20","_typeof","obj","constructor","key","$ul","forEach","li","prop","$type","$value","21","22","23","converter","showdown","Converter","tables","loadWiki","makeHtml","scrollTop","24","showToast","type","$toast","setTimeout","fadeOut","remove","25","flowControlBtns","setFlowControlState","isDisabled","$btn","unhighlightLine","setInterval","activateBtnPause","deactivateBtnPause","26","id","ace","edit","setOptions","enableBasicAutocompletion","enableSnippets","enableLiveAutocompletion","setTheme","session","setMode","$blockScrolling","Infinity","27","dataLines","deallocateAll","lines","split","newLines","line","replace","eval","join","visualize","removeUnallocated","executeData","algoData","executeDataAndCode","algoCode","28","_this","Range","dataEditor","createEditor","codeEditor","setData","setValue","setCode","setContent","clearData","clearCode","getValue","Executor","highlightLine","lineNumber","getSession","marker","removeMarker","addMarker","reset","../dom/top_menu","./create","./executor","29","RSVP","AppConstructor","modules","ajaxSetup","dataType","_require2","getPath","reason","assert","appConstructor","loadCategories","_getPath","loadScratchPaper","loadWikiList","wikis","./app","./app/constructor","./dom","./module","./server","./server/helpers","./utils","rsvp","30","Array2D","random","N","randomSorted","./array2d","31","Integer","M","D","j","map","sort","b","./integer","32","C","33","ratio","G","34","Array1D","CoordinateSystem","DirectedGraph","UndirectedGraph","WeightedDirectedGraph","WeightedUndirectedGraph","./array1d","./coordinate_system","./directed_graph","./undirected_graph","./weighted_directed_graph","./weighted_undirected_graph","35","36","37","38","39","tracers","datas","./data","./tracer","40","_classCallCheck","instance","Constructor","_possibleConstructorReturn","self","ReferenceError","_inherits","subClass","superClass","enumerable","writable","configurable","setPrototypeOf","__proto__","_get","object","property","receiver","Function","desc","getOwnPropertyDescriptor","getPrototypeOf","getter","_createClass","defineProperties","target","props","descriptor","defineProperty","protoProps","staticProps","Array2DTracer","Array1DTracer","_Array2DTracer","idx","v","options","chartTracer","newStep","capsule","sy","ey","sx","ex","processStep","41","Tracer","refineByType","_Tracer","colorClass","selected","notified","isNew","initView","manager","pushStep","pushSelectingStep","arguments","_separate","_deseparate","args","slice","shift","mode","coord","$row","$table","eq","$col","text","paintColor","deseparate","separate","viewX","viewY","paddingH","paddingV","fontSize","apply","getCellCss","refresh","clearColor","deseparateAll","padding","toFixed","font-size","dragX","dragY","originalEvent","delta","wheelDelta","detail","weight","keys","after","tracer","../../tracer_manager/util/index","42","ChartTracer","color","default","chart","config","datasets","update","labels","String","backgroundColor","toString","Chart","scales","yAxes","ticks","beginAtZero","animation","legend","responsive","maintainAspectRatio","43","DirectedGraphTracer","CoordinateSystemTracer","_DirectedGraphTracer","graph","clear","nodes","edges","label","size","read","camera","goTo","angle","visit","targetNode","visited","source","edgeId","edge","dropEdge","addEdge","logTracer","print","v1","v2","temp","node","context","settings","setLineDash","nodeIdx","substring","ends","drawEdge","prefix","strokeStyle","lineWidth","beginPath","moveTo","lineTo","stroke","defaultEdgeType","funcEdgesDef","getColor","44","root","setTreeData","undirected","maxDepth","chk","getDepth","depth","place","wgap","dfs","vgap","cnt","unitAngle","PI","currentAngle","sin","cos","_j","renderers","clearGraphColor","edgeColor","defaultNodeColor","defaultEdgeColor","font","fillStyle","textAlign","fillText","round","tSize","sX","sY","tX","tY","atan2","dist","aSize","d","sqrt","pow","aX","aY","vX","vY","closePath","fill","drawArrow","sigma","renderer","container","minArrowSize","maxEdgeSize","labelThreshold","defaultLabelColor","zoomMin","zoomMax","skipErrors","minNodeSize","maxNodeSize","labelSize","labelSizeRatio","funcLabelsDef","drawLabel","funcHoversDef","drawOnHover","funcEdgesArrow","plugins","dragNodes","canvas","def","func","hovers","arrow","45","LogTracer","UndirectedGraphTracer","WeightedDirectedGraphTracer","WeightedUndirectedGraphTracer","./chart","./log","46","msg","scrollToEnd","duration","animate","scrollHeight","47","_toConsumableArray","arr2","from","toJSON","fromJSON","allocate","setName","_len","_key","$name","defaultName","lastData","48","49","clearWeights","dX","dY","save","active","textBaseline","translate","rotate","restore","edgeLabelSize","defaultEdgeLabelSize","edgeLabelSizePowRatio","drawNodeWeight","drawEdgeWeight","50","_WeightedDirectedGrap","51","request","./request","52","53","JSON","stringify","54","ajax","defaults","Promise","resolve","reject","callbacks","success","response","opts","55","checkLoading","getParameterByName","location","regex","RegExp","results","exec","_results","getHashValue","hash","substr","params","pair","setHashValue","found","newHash","removeHashValue","splice","setPath","path","_hash$split","_hash$split2","../dom/toast","56","./load_algorithm","./load_categories","./load_file","./load_scratch_paper","./load_wiki","./load_wiki_list","./share_scratch_paper","57","getJSON","getAlgorithmDir","dir","./ajax/get_json","58","59","getFileDir","loadDataAndCode","loadFileAndUpdateContent","content","cachedContentExists","cachedFile","./ajax/get","./helpers","60","extractGistCode","gistID","CREDIT.md","61","62","63","postJSON","_app$getEditor","gist","description","public","data.js","code.js","_location","./ajax/post_json","64","tm","../module/tracer/tracer","./manager","65","ModuleContainer","grep","stepLimit","timer","pause","capsules","add","allocated","newTracer","selectedCapsule","count","className","getClassName","order","changed","removed","traces","traceIndex","stepCnt","clearTimeout","len","last","isNaN","trace","virtual","finalIndex","functionName","../dom/module_container","66","parse","67","./from_json","./refine_by_type","./to_json","68","item","refineNumber","refineBoolean","refineString","str","num","bool","69","70","71","cleanUpNextTick","draining","currentQueue","queue","concat","queueIndex","drainQueue","timeout","run","Item","fun","array","noop","process","nextTick","title","browser","env","argv","version","versions","addListener","once","off","removeListener","removeAllListeners","emit","binding","cwd","chdir","umask","72","global","lib$rsvp$utils$$objectOrFunction","lib$rsvp$utils$$isFunction","lib$rsvp$utils$$isMaybeThenable","lib$rsvp$utils$$F","lib$rsvp$events$$indexOf","callback","lib$rsvp$events$$callbacksFor","_promiseCallbacks","lib$rsvp$config$$configure","lib$rsvp$config$$config","lib$rsvp$instrument$$scheduleFlush","entry","lib$rsvp$instrument$$queue","payload","guid","childGuid","childId","stack","lib$rsvp$instrument$$instrument","eventName","promise","child","_guidKey","_id","_result","_label","timeStamp","lib$rsvp$utils$$now","lib$rsvp$then$$then","onFulfillment","onRejection","_state","lib$rsvp$$internal$$FULFILLED","lib$rsvp$$internal$$REJECTED","instrument","lib$rsvp$instrument$$default","_onError","lib$rsvp$$internal$$noop","result","async","lib$rsvp$$internal$$invokeCallback","lib$rsvp$$internal$$subscribe","lib$rsvp$promise$resolve$$resolve","lib$rsvp$$internal$$resolve","lib$rsvp$enumerator$$makeSettledResult","lib$rsvp$enumerator$$Enumerator","input","abortOnReject","_instanceConstructor","_abortOnReject","_validateInput","_input","_remaining","_init","lib$rsvp$$internal$$fulfill","_enumerate","lib$rsvp$$internal$$reject","_validationError","lib$rsvp$promise$all$$all","entries","lib$rsvp$enumerator$$default","lib$rsvp$promise$race$$race","lib$rsvp$utils$$isArray","lib$rsvp$$internal$$PENDING","lib$rsvp$promise$reject$$reject","lib$rsvp$promise$$needsResolver","lib$rsvp$promise$$needsNew","lib$rsvp$promise$$Promise","resolver","lib$rsvp$promise$$counter","_subscribers","lib$rsvp$$internal$$initializePromise","lib$rsvp$$internal$$withOwnPromise","lib$rsvp$$internal$$getThen","lib$rsvp$$internal$$GET_THEN_ERROR","lib$rsvp$$internal$$tryThen","fulfillmentHandler","rejectionHandler","lib$rsvp$$internal$$handleForeignThenable","thenable","sealed","lib$rsvp$$internal$$handleOwnThenable","lib$rsvp$$internal$$handleMaybeThenable","maybeThenable","lib$rsvp$then$$default","lib$rsvp$promise$resolve$$default","lib$rsvp$$internal$$publishRejection","lib$rsvp$$internal$$publish","subscribers","settled","lib$rsvp$$internal$$ErrorObject","lib$rsvp$$internal$$tryCatch","lib$rsvp$$internal$$TRY_CATCH_ERROR","succeeded","failed","hasCallback","resolved","lib$rsvp$all$settled$$AllSettled","_superConstructor","lib$rsvp$all$settled$$allSettled","lib$rsvp$promise$$default","lib$rsvp$all$$all","all","lib$rsvp$asap$$asap","arg","lib$rsvp$asap$$queue","lib$rsvp$asap$$len","lib$rsvp$asap$$scheduleFlush","lib$rsvp$asap$$useNextTick","match","setImmediate","lib$rsvp$asap$$flush","lib$rsvp$asap$$useVertxTimer","lib$rsvp$asap$$vertxNext","lib$rsvp$asap$$useMutationObserver","iterations","observer","lib$rsvp$asap$$BrowserMutationObserver","createTextNode","observe","characterData","lib$rsvp$asap$$useMessageChannel","channel","MessageChannel","port1","onmessage","port2","postMessage","lib$rsvp$asap$$useSetTimeout","lib$rsvp$asap$$attemptVertex","vertx","runOnLoop","runOnContext","lib$rsvp$defer$$defer","deferred","lib$rsvp$filter$$filter","promises","filterFn","values","filtered","newLength","lib$rsvp$promise$hash$$PromiseHash","lib$rsvp$hash$settled$$HashSettled","lib$rsvp$hash$settled$$hashSettled","lib$rsvp$hash$$hash","lib$rsvp$promise$hash$$default","lib$rsvp$map$$map","mapFn","lib$rsvp$node$$Result","lib$rsvp$node$$getThen","lib$rsvp$node$$ERROR","lib$rsvp$node$$tryApply","lib$rsvp$node$$makeObject","_","argumentNames","lib$rsvp$node$$arrayResult","lib$rsvp$node$$wrapThenable","onFulFillment","lib$rsvp$node$$denodeify","nodeFunc","fn","promiseInput","lib$rsvp$node$$needsPromiseInput","lib$rsvp$node$$GET_THEN_ERROR","p","lib$rsvp$node$$handlePromiseInput","lib$rsvp$node$$handleValueInput","lib$rsvp$race$$race","race","lib$rsvp$reject$$reject","lib$rsvp$resolve$$resolve","lib$rsvp$rethrow$$rethrow","lib$rsvp$$async","lib$rsvp$$on","lib$rsvp$$off","lib$rsvp$utils$$_isArray","Date","now","getTime","lib$rsvp$utils$$o_create","lib$rsvp$events$$default","mixin","allCallbacks","index","trigger","_eachEntry","_settleMaybeThenable","c","_settledAt","_makeResult","_willSettleAt","enumerator","lib$rsvp$promise$all$$default","lib$rsvp$promise$race$$default","lib$rsvp$promise$reject$$default","lib$rsvp$promise$$guidKey","cast","catch","finally","lib$rsvp$all$settled$$default","lib$rsvp$all$$default","lib$rsvp$asap$$default","lib$rsvp$asap$$browserWindow","lib$rsvp$asap$$browserGlobal","MutationObserver","WebKitMutationObserver","lib$rsvp$asap$$isNode","lib$rsvp$asap$$isWorker","Uint8ClampedArray","importScripts","lib$rsvp$defer$$default","lib$rsvp$filter$$default","hasOwnProperty","lib$rsvp$platform$$platform","lib$rsvp$hash$settled$$default","lib$rsvp$hash$$default","lib$rsvp$map$$default","lib$rsvp$node$$default","lib$rsvp$platform$$default","lib$rsvp$race$$default","lib$rsvp$reject$$default","lib$rsvp$resolve$$default","lib$rsvp$rethrow$$default","cb","lib$rsvp$$callbacks","lib$rsvp$$eventName","lib$rsvp$umd$$RSVP","allSettled","hashSettled","denodeify","filter","rethrow","defer","EventTarget","configure","define","_process"],"mappings":"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","file":"algorithm_visualizer.min.js","sourcesContent":["/**\n * algorithm-visualizer - Algorithm Visualizer\n * @version v0.1.0\n * @author Jason Park & contributors\n * @link https://github.com/parkjs814/AlgorithmVisualizer#readme\n * @license MIT\n */\n(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})({1:[function(require,module,exports){\n'use strict';\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\nvar cache = {\n lastFileUsed: '',\n files: {}\n};\n\nvar assertFileName = function assertFileName(name) {\n if (!name) {\n throw 'Missing file name';\n }\n};\n\n/**\n * Global application cache\n */\nmodule.exports = {\n getCachedFile: function getCachedFile(name) {\n assertFileName(name);\n return cache.files[name];\n },\n updateCachedFile: function updateCachedFile(name, updates) {\n assertFileName(name);\n if (!cache.files[name]) {\n cache.files[name] = {};\n }\n extend(cache.files[name], updates);\n },\n getLastFileUsed: function getLastFileUsed() {\n return cache.lastFileUsed;\n },\n setLastFileUsed: function setLastFileUsed(file) {\n cache.lastFileUsed = file;\n }\n};\n\n},{}],2:[function(require,module,exports){\n'use strict';\n\nvar Editor = require('../editor');\nvar TracerManager = require('../tracer_manager');\nvar DOM = require('../dom/setup');\n\nvar _require = require('../dom/loading_slider');\n\nvar showLoadingSlider = _require.showLoadingSlider;\nvar hideLoadingSlider = _require.hideLoadingSlider;\n\n\nvar Cache = require('./cache');\n\nvar state = {\n isLoading: null,\n editor: null,\n tracerManager: null,\n categories: null,\n loadedScratch: null,\n wikiList: null\n};\n\nvar initState = function initState(tracerManager) {\n state.isLoading = false;\n state.editor = new Editor(tracerManager);\n state.tracerManager = tracerManager;\n state.categories = {};\n state.loadedScratch = null;\n state.wikiList = [];\n};\n\n/**\n * Global application singleton.\n */\nvar App = function App() {\n\n this.getIsLoading = function () {\n return state.isLoading;\n };\n\n this.setIsLoading = function (loading) {\n state.isLoading = loading;\n if (loading) {\n showLoadingSlider();\n } else {\n hideLoadingSlider();\n }\n };\n\n this.getEditor = function () {\n return state.editor;\n };\n\n this.getCategories = function () {\n return state.categories;\n };\n\n this.getCategory = function (name) {\n return state.categories[name];\n };\n\n this.setCategories = function (categories) {\n state.categories = categories;\n };\n\n this.updateCategory = function (name, updates) {\n $.extend(state.categories[name], updates);\n };\n\n this.getTracerManager = function () {\n return state.tracerManager;\n };\n\n this.getLoadedScratch = function () {\n return state.loadedScratch;\n };\n\n this.setLoadedScratch = function (loadedScratch) {\n state.loadedScratch = loadedScratch;\n };\n\n this.getWikiList = function () {\n return state.wikiList;\n };\n\n this.setWikiList = function (wikiList) {\n state.wikiList = wikiList;\n };\n\n this.hasWiki = function (wiki) {\n return ~state.wikiList.indexOf(wiki);\n };\n\n var tracerManager = TracerManager.init();\n\n initState(tracerManager);\n DOM.setup(tracerManager);\n};\n\nApp.prototype = Cache;\n\nmodule.exports = App;\n\n},{\"../dom/loading_slider\":7,\"../dom/setup\":9,\"../editor\":28,\"../tracer_manager\":64,\"./cache\":1}],3:[function(require,module,exports){\n'use strict';\n\n/**\n * This is the main application instance.\n * Gets populated on page load. \n */\n\nmodule.exports = {};\n\n},{}],4:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar Server = require('../server');\nvar showAlgorithm = require('./show_algorithm');\n\nvar _$ = $;\nvar each = _$.each;\n\n\nvar getAlgorithmDOM = function getAlgorithmDOM(category, subList, algorithm) {\n return $('<button class=\"indent\">').append(subList[algorithm]).attr('data-algorithm', algorithm).attr('data-category', category).click(function () {\n Server.loadAlgorithm(category, algorithm).then(function (data) {\n showAlgorithm(category, algorithm, data);\n });\n });\n\n $('#list').append($algorithm);\n};\n\nvar addCategoryToDOM = function addCategoryToDOM(category) {\n var _app$getCategory = app.getCategory(category);\n\n var categoryName = _app$getCategory.name;\n var categorySubList = _app$getCategory.list;\n\n\n var $category = $('<button class=\"category\">').append('<i class=\"fa fa-fw fa-caret-right\">').append(categoryName).attr('data-category', category);\n\n $category.click(function () {\n var $self = $(this);\n $self.toggleClass('open');\n $self.next().toggleClass('collapse');\n $self.find('i.fa').toggleClass('fa-caret-right fa-caret-down');\n });\n\n var $algorithms = $('<div class=\"algorithms collapse\">');\n $('#list').append($category).append($algorithms);\n\n each(categorySubList, function (algorithm) {\n var $algorithm = getAlgorithmDOM(category, categorySubList, algorithm);\n $algorithms.append($algorithm);\n });\n};\n\nmodule.exports = function () {\n each(app.getCategories(), addCategoryToDOM);\n};\n\n},{\"../app\":3,\"../server\":56,\"./show_algorithm\":19}],5:[function(require,module,exports){\n'use strict';\n\nvar Server = require('../server');\n\nvar _$ = $;\nvar each = _$.each;\n\n\nvar addFileToDOM = function addFileToDOM(category, algorithm, file, explanation) {\n var $file = $('<button>').append(file).attr('data-file', file).click(function () {\n Server.loadFile(category, algorithm, file, explanation);\n $('.files_bar > .wrapper > button').removeClass('active');\n $(this).addClass('active');\n });\n $('.files_bar > .wrapper').append($file);\n return $file;\n};\n\nmodule.exports = function (category, algorithm, files, requestedFile) {\n $('.files_bar > .wrapper').empty();\n\n each(files, function (file, explanation) {\n var $file = addFileToDOM(category, algorithm, file, explanation);\n if (requestedFile && requestedFile == file) $file.click();\n });\n\n if (!requestedFile) $('.files_bar > .wrapper > button').first().click();\n $('.files_bar > .wrapper').scroll();\n};\n\n},{\"../server\":56}],6:[function(require,module,exports){\n'use strict';\n\nvar showAlgorithm = require('./show_algorithm');\nvar addCategories = require('./add_categories');\nvar showDescription = require('./show_description');\nvar addFiles = require('./add_files');\nvar showFirstAlgorithm = require('./show_first_algorithm');\nvar showRequestedAlgorithm = require('./show_requested_algorithm');\nvar showWiki = require('./show_wiki');\n\nmodule.exports = {\n showAlgorithm: showAlgorithm,\n addCategories: addCategories,\n showDescription: showDescription,\n addFiles: addFiles,\n showFirstAlgorithm: showFirstAlgorithm,\n showRequestedAlgorithm: showRequestedAlgorithm,\n showWiki: showWiki\n};\n\n},{\"./add_categories\":4,\"./add_files\":5,\"./show_algorithm\":19,\"./show_description\":20,\"./show_first_algorithm\":21,\"./show_requested_algorithm\":22,\"./show_wiki\":23}],7:[function(require,module,exports){\n'use strict';\n\nvar showLoadingSlider = function showLoadingSlider() {\n $('#loading-slider').removeClass('loaded');\n};\n\nvar hideLoadingSlider = function hideLoadingSlider() {\n $('#loading-slider').addClass('loaded');\n};\n\nmodule.exports = {\n showLoadingSlider: showLoadingSlider,\n hideLoadingSlider: hideLoadingSlider\n};\n\n},{}],8:[function(require,module,exports){\n'use strict';\n\nvar create = function create() {\n var $container = $('<section class=\"module_wrapper\">');\n $('.module_container').append($container);\n return $container;\n};\n\nmodule.exports = {\n create: create\n};\n\n},{}],9:[function(require,module,exports){\n'use strict';\n\nvar setupDividers = require('./setup_dividers');\nvar setupDocument = require('./setup_document');\nvar setupFilesBar = require('./setup_files_bar');\nvar setupInterval = require('./setup_interval');\nvar setupModuleContainer = require('./setup_module_container');\nvar setupTabContainer = require('./setup_tab_container');\nvar setupSideMenu = require('./setup_side_menu');\nvar setupTopMenu = require('./setup_top_menu');\nvar setupWindow = require('./setup_window');\n\n/**\n * Initializes elements once the app loads in the DOM.\n */\nvar setup = function setup() {\n\n $('.btn input').click(function (e) {\n e.stopPropagation();\n });\n\n // dividers\n setupDividers();\n\n // document\n setupDocument();\n\n // files bar\n setupFilesBar();\n\n // interval\n setupInterval();\n\n // module container\n setupModuleContainer();\n\n // tab container\n setupTabContainer();\n\n // side menu\n setupSideMenu();\n\n // top menu\n setupTopMenu();\n\n // window\n setupWindow();\n};\n\nmodule.exports = {\n setup: setup\n};\n\n},{\"./setup_dividers\":10,\"./setup_document\":11,\"./setup_files_bar\":12,\"./setup_interval\":13,\"./setup_module_container\":14,\"./setup_side_menu\":15,\"./setup_tab_container\":16,\"./setup_top_menu\":17,\"./setup_window\":18}],10:[function(require,module,exports){\n'use strict';\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar app = require('../../app');\n\nvar addDividerToDom = function addDividerToDom(divider) {\n var _divider = _slicedToArray(divider, 3);\n\n var vertical = _divider[0];\n var $first = _divider[1];\n var $second = _divider[2];\n\n var $parent = $first.parent();\n var thickness = 5;\n\n var $divider = $('<div class=\"divider\">');\n\n var dragging = false;\n if (vertical) {\n (function () {\n $divider.addClass('vertical');\n\n var _left = -thickness / 2;\n $divider.css({\n top: 0,\n bottom: 0,\n left: _left,\n width: thickness\n });\n\n var x = void 0;\n $divider.mousedown(function (_ref) {\n var pageX = _ref.pageX;\n\n x = pageX;\n dragging = true;\n });\n\n $(document).mousemove(function (_ref2) {\n var pageX = _ref2.pageX;\n\n if (dragging) {\n var new_left = $second.position().left + pageX - x;\n var percent = new_left / $parent.width() * 100;\n percent = Math.min(90, Math.max(10, percent));\n $first.css('right', 100 - percent + '%');\n $second.css('left', percent + '%');\n x = pageX;\n app.getTracerManager().resize();\n $('.files_bar > .wrapper').scroll();\n }\n });\n\n $(document).mouseup(function (e) {\n dragging = false;\n });\n })();\n } else {\n (function () {\n\n $divider.addClass('horizontal');\n var _top = -thickness / 2;\n $divider.css({\n top: _top,\n height: thickness,\n left: 0,\n right: 0\n });\n\n var y = void 0;\n $divider.mousedown(function (_ref3) {\n var pageY = _ref3.pageY;\n\n y = pageY;\n dragging = true;\n });\n\n $(document).mousemove(function (_ref4) {\n var pageY = _ref4.pageY;\n\n if (dragging) {\n var new_top = $second.position().top + pageY - y;\n var percent = new_top / $parent.height() * 100;\n percent = Math.min(90, Math.max(10, percent));\n $first.css('bottom', 100 - percent + '%');\n $second.css('top', percent + '%');\n y = pageY;\n app.getTracerManager().resize();\n }\n });\n\n $(document).mouseup(function (e) {\n dragging = false;\n });\n })();\n }\n\n $second.append($divider);\n};\n\nmodule.exports = function () {\n var dividers = [['v', $('.sidemenu'), $('.workspace')], ['v', $('.viewer_container'), $('.editor_container')], ['h', $('.data_container'), $('.code_container')]];\n for (var i = 0; i < dividers.length; i++) {\n addDividerToDom(dividers[i]);\n }\n};\n\n},{\"../../app\":3}],11:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n $(document).on('click', 'a', function (e) {\n var href = $(this).attr('href');\n if (/^(https?:\\/\\/).+/.test(href)) {\n e.preventDefault();\n if (!window.open(href, '_blank')) {\n alert('Please allow popups for this site');\n }\n }\n });\n\n $(document).mouseup(function (e) {\n app.getTracerManager().command('mouseup', e);\n });\n};\n\n},{\"../../app\":3}],12:[function(require,module,exports){\n'use strict';\n\nvar definitelyBigger = function definitelyBigger(x, y) {\n return x > y + 2;\n};\n\nmodule.exports = function () {\n\n $('.files_bar > .btn-left').click(function () {\n var $wrapper = $('.files_bar > .wrapper');\n var clipWidth = $wrapper.width();\n var scrollLeft = $wrapper.scrollLeft();\n\n $($wrapper.children('button').get().reverse()).each(function () {\n var left = $(this).position().left;\n var right = left + $(this).outerWidth();\n if (0 > left) {\n $wrapper.scrollLeft(scrollLeft + right - clipWidth);\n return false;\n }\n });\n });\n\n $('.files_bar > .btn-right').click(function () {\n var $wrapper = $('.files_bar > .wrapper');\n var clipWidth = $wrapper.width();\n var scrollLeft = $wrapper.scrollLeft();\n\n $wrapper.children('button').each(function () {\n var left = $(this).position().left;\n var right = left + $(this).outerWidth();\n if (clipWidth < right) {\n $wrapper.scrollLeft(scrollLeft + left);\n return false;\n }\n });\n });\n\n $('.files_bar > .wrapper').scroll(function () {\n\n var $wrapper = $('.files_bar > .wrapper');\n var clipWidth = $wrapper.width();\n var $left = $wrapper.children('button:first-child');\n var $right = $wrapper.children('button:last-child');\n var left = $left.position().left;\n var right = $right.position().left + $right.outerWidth();\n\n if (definitelyBigger(0, left) && definitelyBigger(clipWidth, right)) {\n var scrollLeft = $wrapper.scrollLeft();\n $wrapper.scrollLeft(scrollLeft + clipWidth - right);\n return;\n }\n\n var lefter = definitelyBigger(0, left);\n var righter = definitelyBigger(right, clipWidth);\n $wrapper.toggleClass('shadow-left', lefter);\n $wrapper.toggleClass('shadow-right', righter);\n $('.files_bar > .btn-left').attr('disabled', !lefter);\n $('.files_bar > .btn-right').attr('disabled', !righter);\n });\n};\n\n},{}],13:[function(require,module,exports){\n'use strict';\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar app = require('../../app');\nvar Toast = require('../toast');\n\nvar parseFloat = Number.parseFloat;\n\n\nvar minInterval = 0.1;\nvar maxInterval = 10;\nvar startInterval = 0.5;\nvar stepInterval = 0.1;\n\nvar normalize = function normalize(sec) {\n\n var interval = void 0;\n var message = void 0;\n if (sec < minInterval) {\n interval = minInterval;\n message = 'Interval of ' + sec + ' seconds is too low. Setting to min allowed interval of ' + minInterval + ' second(s).';\n } else if (sec > maxInterval) {\n interval = maxInterval;\n message = 'Interval of ' + sec + ' seconds is too high. Setting to max allowed interval of ' + maxInterval + ' second(s).';\n } else {\n interval = sec;\n message = 'Interval has been set to ' + sec + ' second(s).';\n }\n\n return [interval, message];\n};\n\nmodule.exports = function () {\n\n var $interval = $('#interval');\n $interval.val(startInterval);\n $interval.attr({\n max: maxInterval,\n min: minInterval,\n step: stepInterval\n });\n\n $('#interval').on('change', function () {\n var tracerManager = app.getTracerManager();\n\n var _normalize = normalize(parseFloat($(this).val()));\n\n var _normalize2 = _slicedToArray(_normalize, 2);\n\n var seconds = _normalize2[0];\n var message = _normalize2[1];\n\n\n $(this).val(seconds);\n tracerManager.interval = seconds * 1000;\n Toast.showInfoToast(message);\n });\n};\n\n},{\"../../app\":3,\"../toast\":24}],14:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n\n var $module_container = $('.module_container');\n\n $module_container.on('mousedown', '.module_wrapper', function (e) {\n app.getTracerManager().findOwner(this).mousedown(e);\n });\n\n $module_container.on('mousemove', '.module_wrapper', function (e) {\n app.getTracerManager().findOwner(this).mousemove(e);\n });\n\n $module_container.on('DOMMouseScroll mousewheel', '.module_wrapper', function (e) {\n app.getTracerManager().findOwner(this).mousewheel(e);\n });\n};\n\n},{\"../../app\":3}],15:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\nvar Server = require('../../server');\nvar showAlgorithm = require('../show_algorithm');\n\nvar sidemenu_percent = void 0;\n\nmodule.exports = function () {\n $('#navigation').click(function () {\n var $sidemenu = $('.sidemenu');\n var $workspace = $('.workspace');\n\n $sidemenu.toggleClass('active');\n $('.nav-dropdown').toggleClass('fa-caret-down fa-caret-up');\n\n if ($sidemenu.hasClass('active')) {\n $sidemenu.css('right', 100 - sidemenu_percent + '%');\n $workspace.css('left', sidemenu_percent + '%');\n } else {\n sidemenu_percent = $workspace.position().left / $('body').width() * 100;\n $sidemenu.css('right', 0);\n $workspace.css('left', 0);\n }\n\n app.getTracerManager().resize();\n });\n\n $('#documentation').click(function () {\n $('#btn_doc').click();\n });\n\n $('#powered-by').click(function () {\n $('#powered-by-list button').toggleClass('collapse');\n });\n\n $('#scratch-paper').click(function () {\n var category = 'scratch';\n var algorithm = app.getLoadedScratch();\n Server.loadAlgorithm(category, algorithm).then(function (data) {\n showAlgorithm(category, algorithm, data);\n });\n });\n};\n\n},{\"../../app\":3,\"../../server\":56,\"../show_algorithm\":19}],16:[function(require,module,exports){\n'use strict';\n\nmodule.exports = function () {\n $('.tab_bar > button').click(function () {\n $('.tab_bar > button').removeClass('active');\n $('.tab_container > .tab').removeClass('active');\n $(this).addClass('active');\n $($(this).attr('data-target')).addClass('active');\n });\n};\n\n},{}],17:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\nvar Server = require('../../server');\nvar Toast = require('../toast');\nvar TopMenu = require('../top_menu');\n\nmodule.exports = function () {\n\n // shared\n $('#shared').mouseup(function () {\n $(this).select();\n });\n\n $('#btn_share').click(function () {\n\n var $icon = $(this).find('.fa-share');\n $icon.addClass('fa-spin fa-spin-faster');\n\n Server.shareScratchPaper().then(function (url) {\n $icon.removeClass('fa-spin fa-spin-faster');\n $('#shared').removeClass('collapse');\n $('#shared').val(url);\n Toast.showInfoToast('Shareable link is created.');\n });\n });\n\n // control\n\n var $btnRun = $('#btn_run');\n var $btnTrace = $('#btn_trace');\n var $btnPause = $('#btn_pause');\n var $btnPrev = $('#btn_prev');\n var $btnNext = $('#btn_next');\n\n // initially, control buttons are disabled\n TopMenu.disableFlowControl();\n\n $btnRun.click(function () {\n $btnTrace.click();\n $btnPause.removeClass('active');\n $btnRun.addClass('active');\n TopMenu.enableFlowControl();\n var err = app.getEditor().execute();\n if (err) {\n console.error(err);\n Toast.showErrorToast(err);\n TopMenu.resetTopMenuButtons();\n }\n });\n\n $btnPause.click(function () {\n $btnRun.toggleClass('active');\n $btnPause.toggleClass('active');\n if (app.getTracerManager().isPause()) {\n app.getTracerManager().resumeStep();\n } else {\n app.getTracerManager().pauseStep();\n }\n });\n\n $btnPrev.click(function () {\n $btnRun.removeClass('active');\n $btnPause.addClass('active');\n app.getTracerManager().pauseStep();\n app.getTracerManager().prevStep();\n });\n\n $btnNext.click(function () {\n $btnRun.removeClass('active');\n $btnPause.addClass('active');\n app.getTracerManager().pauseStep();\n app.getTracerManager().nextStep();\n });\n};\n\n},{\"../../app\":3,\"../../server\":56,\"../toast\":24,\"../top_menu\":25}],18:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n $(window).resize(function () {\n app.getTracerManager().resize();\n });\n};\n\n},{\"../../app\":3}],19:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\n\nvar _require = require('../utils');\n\nvar isScratchPaper = _require.isScratchPaper;\n\n\nvar showDescription = require('./show_description');\nvar addFiles = require('./add_files');\n\nmodule.exports = function (category, algorithm, data, requestedFile) {\n var $menu = void 0;\n var category_name = void 0;\n var algorithm_name = void 0;\n\n if (isScratchPaper(category)) {\n $menu = $('#scratch-paper');\n category_name = 'Scratch Paper';\n algorithm_name = algorithm ? 'Shared' : 'Temporary';\n } else {\n $menu = $('[data-category=\"' + category + '\"][data-algorithm=\"' + algorithm + '\"]');\n var categoryObj = app.getCategory(category);\n category_name = categoryObj.name;\n algorithm_name = categoryObj.list[algorithm];\n }\n\n $('.sidemenu button').removeClass('active');\n $menu.addClass('active');\n\n $('#category').html(category_name);\n $('#algorithm').html(algorithm_name);\n $('#tab_desc > .wrapper').empty();\n $('.files_bar > .wrapper').empty();\n $('#explanation').html('');\n\n app.setLastFileUsed(null);\n app.getEditor().clearContent();\n\n var files = data.files;\n\n\n delete data.files;\n\n showDescription(data);\n addFiles(category, algorithm, files, requestedFile);\n};\n\n},{\"../app\":3,\"../utils\":70,\"./add_files\":5,\"./show_description\":20}],20:[function(require,module,exports){\n'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol ? \"symbol\" : typeof obj; };\n\nvar isArray = Array.isArray;\nvar _$ = $;\nvar each = _$.each;\n\n\nmodule.exports = function (data) {\n var $container = $('#tab_desc > .wrapper');\n $container.empty();\n\n each(data, function (key, value) {\n\n if (key) {\n $container.append($('<h3>').html(key));\n }\n\n if (typeof value === 'string') {\n $container.append($('<p>').html(value));\n } else if (isArray(value)) {\n (function () {\n\n var $ul = $('<ul class=\"applications\">');\n $container.append($ul);\n\n value.forEach(function (li) {\n $ul.append($('<li>').html(li));\n });\n })();\n } else if ((typeof value === 'undefined' ? 'undefined' : _typeof(value)) === 'object') {\n (function () {\n\n var $ul = $('<ul class=\"complexities\">');\n $container.append($ul);\n\n each(value, function (prop) {\n var $wrapper = $('<div class=\"complexity\">');\n var $type = $('<span class=\"complexity-type\">').html(prop + ': ');\n var $value = $('<span class=\"complexity-value\">').html('' + value[prop]);\n\n $wrapper.append($type).append($value);\n\n $ul.append($('<li>').append($wrapper));\n });\n })();\n }\n });\n};\n\n},{}],21:[function(require,module,exports){\n'use strict';\n\n// click the first algorithm in the first category\n\nmodule.exports = function () {\n $('#list .category').first().click();\n $('#list .category + .algorithms > .indent').first().click();\n};\n\n},{}],22:[function(require,module,exports){\n'use strict';\n\nvar Server = require('../server');\nvar showAlgorithm = require('./show_algorithm');\n\nmodule.exports = function (category, algorithm, file) {\n $('.category[data-category=\"' + category + '\"]').click();\n Server.loadAlgorithm(category, algorithm).then(function (data) {\n showAlgorithm(category, algorithm, data, file);\n });\n};\n\n},{\"../server\":56,\"./show_algorithm\":19}],23:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar Server = require('../server');\nvar converter = new showdown.Converter({ tables: true });\n\nmodule.exports = function (wiki) {\n Server.loadWiki(wiki).then(function (data) {\n $('#tab_doc > .wrapper').html(converter.makeHtml('#' + wiki + '\\n' + data));\n $('#tab_doc').scrollTop(0);\n $('#tab_doc > .wrapper a').click(function (e) {\n var href = $(this).attr('href');\n if (app.hasWiki(href)) {\n e.preventDefault();\n module.exports(href);\n }\n });\n });\n};\n\n},{\"../app\":3,\"../server\":56}],24:[function(require,module,exports){\n'use strict';\n\nvar showToast = function showToast(data, type) {\n var $toast = $('<div class=\"toast ' + type + '\">').append(data);\n\n $('.toast_container').append($toast);\n setTimeout(function () {\n $toast.fadeOut(function () {\n $toast.remove();\n });\n }, 3000);\n};\n\nvar showErrorToast = function showErrorToast(err) {\n showToast(err, 'error');\n};\n\nvar showInfoToast = function showInfoToast(err) {\n showToast(err, 'info');\n};\n\nmodule.exports = {\n showErrorToast: showErrorToast,\n showInfoToast: showInfoToast\n};\n\n},{}],25:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\n\nvar flowControlBtns = [$('#btn_pause'), $('#btn_prev'), $('#btn_next')];\nvar setFlowControlState = function setFlowControlState(isDisabled) {\n flowControlBtns.forEach(function ($btn) {\n return $btn.attr('disabled', isDisabled);\n });\n};\n\nvar enableFlowControl = function enableFlowControl() {\n setFlowControlState(false);\n};\n\nvar disableFlowControl = function disableFlowControl() {\n setFlowControlState(true);\n};\n\nvar resetTopMenuButtons = function resetTopMenuButtons() {\n $('.top-menu-buttons button').removeClass('active');\n disableFlowControl();\n app.getEditor().unhighlightLine();\n};\n\nvar setInterval = function setInterval(val) {\n $('#interval').val(interval);\n};\n\nvar activateBtnPause = function activateBtnPause() {\n $('#btn_pause').addClass('active');\n};\n\nvar deactivateBtnPause = function deactivateBtnPause() {\n $('#btn_pause').removeClass('active');\n};\n\nmodule.exports = {\n enableFlowControl: enableFlowControl,\n disableFlowControl: disableFlowControl,\n resetTopMenuButtons: resetTopMenuButtons,\n setInterval: setInterval,\n activateBtnPause: activateBtnPause,\n deactivateBtnPause: deactivateBtnPause\n};\n\n},{\"../app\":3}],26:[function(require,module,exports){\n'use strict';\n\nmodule.exports = function (id) {\n var editor = ace.edit(id);\n\n editor.setOptions({\n enableBasicAutocompletion: true,\n enableSnippets: true,\n enableLiveAutocompletion: true\n });\n\n editor.setTheme('ace/theme/tomorrow_night_eighties');\n editor.session.setMode('ace/mode/javascript');\n editor.$blockScrolling = Infinity;\n\n return editor;\n};\n\n},{}],27:[function(require,module,exports){\n'use strict';\n\nvar execute = function execute(tracerManager, code, dataLines) {\n // all modules available to eval are obtained from window\n try {\n (function () {\n tracerManager.deallocateAll();\n var lines = code.split('\\n');\n var newLines = [];\n lines.forEach(function (line, i) {\n newLines.push(line.replace(/(.+\\. *_wait *)(\\( *\\))/g, '$1(' + (i - dataLines) + ')'));\n });\n eval(newLines.join('\\n'));\n tracerManager.visualize();\n })();\n } catch (err) {\n return err;\n } finally {\n tracerManager.removeUnallocated();\n }\n};\n\nvar executeData = function executeData(tracerManager, algoData) {\n return execute(tracerManager, algoData);\n};\n\nvar executeDataAndCode = function executeDataAndCode(tracerManager, algoData, algoCode) {\n var dataLines = algoData.split('\\n').length;\n return execute(tracerManager, algoData + '\\n' + algoCode, dataLines);\n};\n\nmodule.exports = {\n executeData: executeData,\n executeDataAndCode: executeDataAndCode\n};\n\n},{}],28:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar createEditor = require('./create');\nvar Executor = require('./executor');\nvar TopMenu = require('../dom/top_menu');\n\nfunction Editor(tracerManager) {\n var _this = this;\n\n if (!tracerManager) {\n throw 'Cannot create Editor. Missing the tracerManager';\n }\n\n ace.require('ace/ext/language_tools');\n var Range = ace.require(\"ace/range\").Range;\n\n this.dataEditor = createEditor('data');\n this.codeEditor = createEditor('code');\n\n // Setting data\n\n this.setData = function (data) {\n _this.dataEditor.setValue(data, -1);\n };\n\n this.setCode = function (code) {\n _this.codeEditor.setValue(code, -1);\n };\n\n this.setContent = function (_ref) {\n var data = _ref.data;\n var code = _ref.code;\n\n _this.setData(data);\n _this.setCode(code);\n };\n\n // Clearing data\n\n this.clearData = function () {\n _this.dataEditor.setValue('');\n };\n\n this.clearCode = function () {\n _this.codeEditor.setValue('');\n };\n\n this.clearContent = function () {\n _this.clearData();\n _this.clearCode();\n };\n\n this.execute = function () {\n var data = _this.dataEditor.getValue();\n var code = _this.codeEditor.getValue();\n return Executor.executeDataAndCode(tracerManager, data, code);\n };\n\n this.highlightLine = function (lineNumber) {\n var session = _this.codeEditor.getSession();\n if (_this.marker) session.removeMarker(_this.marker);\n _this.marker = session.addMarker(new Range(lineNumber, 0, lineNumber, Infinity), \"executing\", \"line\", true);\n };\n\n this.unhighlightLine = function () {\n var session = _this.codeEditor.getSession();\n if (_this.marker) session.removeMarker(_this.marker);\n };\n\n // listeners\n\n this.dataEditor.on('change', function () {\n var data = _this.dataEditor.getValue();\n var lastFileUsed = app.getLastFileUsed();\n if (lastFileUsed) {\n app.updateCachedFile(lastFileUsed, {\n data: data\n });\n }\n Executor.executeData(tracerManager, data);\n TopMenu.resetTopMenuButtons();\n });\n\n this.codeEditor.on('change', function () {\n var code = _this.codeEditor.getValue();\n var lastFileUsed = app.getLastFileUsed();\n if (lastFileUsed) {\n app.updateCachedFile(lastFileUsed, {\n code: code\n });\n }\n tracerManager.reset();\n TopMenu.resetTopMenuButtons();\n });\n}\n\nmodule.exports = Editor;\n\n},{\"../app\":3,\"../dom/top_menu\":25,\"./create\":26,\"./executor\":27}],29:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('./app');\nvar AppConstructor = require('./app/constructor');\nvar DOM = require('./dom');\nvar Server = require('./server');\n\nvar modules = require('./module');\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\n$.ajaxSetup({\n cache: false,\n dataType: 'text'\n});\n\nvar _require = require('./utils');\n\nvar isScratchPaper = _require.isScratchPaper;\n\nvar _require2 = require('./server/helpers');\n\nvar getPath = _require2.getPath;\n\n// set global promise error handler\n\nRSVP.on('error', function (reason) {\n console.assert(false, reason);\n});\n\n$(function () {\n\n // initialize the application and attach in to the instance module\n var appConstructor = new AppConstructor();\n extend(true, app, appConstructor);\n\n // load modules to the global scope so they can be evaled\n extend(true, window, modules);\n\n Server.loadCategories().then(function (data) {\n app.setCategories(data);\n DOM.addCategories();\n\n // determine if the app is loading a pre-existing scratch-pad\n // or the home page\n\n var _getPath = getPath();\n\n var category = _getPath.category;\n var algorithm = _getPath.algorithm;\n var file = _getPath.file;\n\n if (isScratchPaper(category)) {\n if (algorithm) {\n Server.loadScratchPaper(algorithm).then(function (_ref) {\n var category = _ref.category;\n var algorithm = _ref.algorithm;\n var data = _ref.data;\n\n DOM.showAlgorithm(category, algorithm, data);\n });\n } else {\n Server.loadAlgorithm(category).then(function (data) {\n DOM.showAlgorithm(category, null, data);\n });\n }\n } else if (category && algorithm) {\n DOM.showRequestedAlgorithm(category, algorithm, file);\n } else {\n DOM.showFirstAlgorithm();\n }\n });\n\n Server.loadWikiList().then(function (data) {\n app.setWikiList(data.wikis);\n\n DOM.showWiki('Tracer');\n });\n});\n\n},{\"./app\":3,\"./app/constructor\":2,\"./dom\":6,\"./module\":39,\"./server\":56,\"./server/helpers\":55,\"./utils\":70,\"rsvp\":72}],30:[function(require,module,exports){\n'use strict';\n\nvar Array2D = require('./array2d');\n\nvar random = function random(N, min, max) {\n return Array2D.random(1, N, min, max)[0];\n};\n\nvar randomSorted = function randomSorted(N, min, max) {\n return Array2D.randomSorted(1, N, min, max)[0];\n};\n\nmodule.exports = {\n random: random,\n randomSorted: randomSorted\n};\n\n},{\"./array2d\":31}],31:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, M, min, max) {\n if (!N) N = 10;\n if (!M) M = 10;\n if (min === undefined) min = 1;\n if (max === undefined) max = 9;\n var D = [];\n for (var i = 0; i < N; i++) {\n D.push([]);\n for (var j = 0; j < M; j++) {\n D[i].push(Integer.random(min, max));\n }\n }\n return D;\n};\n\nvar randomSorted = function randomSorted(N, M, min, max) {\n return random(N, M, min, max).map(function (arr) {\n return arr.sort(function (a, b) {\n return a - b;\n });\n });\n};\n\nmodule.exports = {\n random: random,\n randomSorted: randomSorted\n};\n\n},{\"./integer\":35}],32:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, min, max) {\n if (!N) N = 7;\n if (!min) min = 1;\n if (!max) max = 10;\n var C = new Array(N);\n for (var i = 0; i < N; i++) {\n C[i] = new Array(2);\n }for (var i = 0; i < N; i++) {\n for (var j = 0; j < C[i].length; j++) {\n C[i][j] = Integer.random(min, max);\n }\n }return C;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{\"./integer\":35}],33:[function(require,module,exports){\n'use strict';\n\nvar random = function random(N, ratio) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n for (var j = 0; j < N; j++) {\n if (i != j) {\n G[i][j] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],34:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\nvar Array1D = require('./array1d');\nvar Array2D = require('./array2d');\nvar CoordinateSystem = require('./coordinate_system');\nvar DirectedGraph = require('./directed_graph');\nvar UndirectedGraph = require('./undirected_graph');\nvar WeightedDirectedGraph = require('./weighted_directed_graph');\nvar WeightedUndirectedGraph = require('./weighted_undirected_graph');\n\nmodule.exports = {\n Integer: Integer,\n Array1D: Array1D,\n Array2D: Array2D,\n CoordinateSystem: CoordinateSystem,\n DirectedGraph: DirectedGraph,\n UndirectedGraph: UndirectedGraph,\n WeightedDirectedGraph: WeightedDirectedGraph,\n WeightedUndirectedGraph: WeightedUndirectedGraph\n};\n\n},{\"./array1d\":30,\"./array2d\":31,\"./coordinate_system\":32,\"./directed_graph\":33,\"./integer\":35,\"./undirected_graph\":36,\"./weighted_directed_graph\":37,\"./weighted_undirected_graph\":38}],35:[function(require,module,exports){\n'use strict';\n\nvar random = function random(min, max) {\n return (Math.random() * (max - min + 1) | 0) + min;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],36:[function(require,module,exports){\n'use strict';\n\nvar random = function random(N, ratio) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n }for (var i = 0; i < N; i++) {\n for (var j = 0; j < N; j++) {\n if (i > j) {\n G[i][j] = G[j][i] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],37:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, ratio, min, max) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n if (!min) min = 1;\n if (!max) max = 5;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n for (var j = 0; j < N; j++) {\n if (i != j && (Math.random() * (1 / ratio) | 0) == 0) {\n G[i][j] = Integer.random(min, max);\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{\"./integer\":35}],38:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, ratio, min, max) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n if (!min) min = 1;\n if (!max) max = 5;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n }for (var i = 0; i < N; i++) {\n for (var j = 0; j < N; j++) {\n if (i > j && (Math.random() * (1 / ratio) | 0) == 0) {\n G[i][j] = G[j][i] = Integer.random(min, max);\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{\"./integer\":35}],39:[function(require,module,exports){\n'use strict';\n\nvar tracers = require('./tracer');\nvar datas = require('./data');\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\nmodule.exports = extend(true, {}, tracers, datas);\n\n},{\"./data\":34,\"./tracer\":45}],40:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Array2DTracer = require('./array2d');\n\nvar Array1DTracer = function (_Array2DTracer) {\n _inherits(Array1DTracer, _Array2DTracer);\n\n _createClass(Array1DTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'Array1DTracer';\n }\n }]);\n\n function Array1DTracer(name) {\n _classCallCheck(this, Array1DTracer);\n\n return _possibleConstructorReturn(this, Object.getPrototypeOf(Array1DTracer).call(this, name));\n }\n\n _createClass(Array1DTracer, [{\n key: '_notify',\n value: function _notify(idx, v) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_notify', this).call(this, 0, idx, v);\n return this;\n }\n }, {\n key: '_denotify',\n value: function _denotify(idx) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_denotify', this).call(this, 0, idx);\n return this;\n }\n }, {\n key: '_select',\n value: function _select(s, e) {\n if (e === undefined) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_select', this).call(this, 0, s);\n } else {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_selectRow', this).call(this, 0, s, e);\n }\n return this;\n }\n }, {\n key: '_deselect',\n value: function _deselect(s, e) {\n if (e === undefined) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_deselect', this).call(this, 0, s);\n } else {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_deselectRow', this).call(this, 0, s, e);\n }\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), 'processStep', this).call(this, step, options);\n if (this.chartTracer) {\n var newStep = $.extend(true, {}, step);\n newStep.capsule = this.chartTracer.capsule;\n newStep.s = newStep.sy;\n newStep.e = newStep.ey;\n if (newStep.s === undefined) newStep.s = newStep.y;\n delete newStep.x;\n delete newStep.y;\n delete newStep.sx;\n delete newStep.sy;\n delete newStep.ex;\n delete newStep.ey;\n this.chartTracer.processStep(newStep, options);\n }\n }\n }, {\n key: 'setData',\n value: function setData(D) {\n return _get(Object.getPrototypeOf(Array1DTracer.prototype), 'setData', this).call(this, [D]);\n }\n }]);\n\n return Array1DTracer;\n}(Array2DTracer);\n\nmodule.exports = Array1DTracer;\n\n},{\"./array2d\":41}],41:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar refineByType = _require.refineByType;\n\nvar Array2DTracer = function (_Tracer) {\n _inherits(Array2DTracer, _Tracer);\n\n _createClass(Array2DTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'Array2DTracer';\n }\n }]);\n\n function Array2DTracer(name) {\n _classCallCheck(this, Array2DTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(Array2DTracer).call(this, name));\n\n _this.colorClass = {\n selected: 'selected',\n notified: 'notified'\n };\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(Array2DTracer, [{\n key: '_notify',\n value: function _notify(x, y, v) {\n this.manager.pushStep(this.capsule, {\n type: 'notify',\n x: x,\n y: y,\n v: v\n });\n return this;\n }\n }, {\n key: '_denotify',\n value: function _denotify(x, y) {\n this.manager.pushStep(this.capsule, {\n type: 'denotify',\n x: x,\n y: y\n });\n return this;\n }\n }, {\n key: '_select',\n value: function _select(sx, sy, ex, ey) {\n this.pushSelectingStep('select', null, arguments);\n return this;\n }\n }, {\n key: '_selectRow',\n value: function _selectRow(x, sy, ey) {\n this.pushSelectingStep('select', 'row', arguments);\n return this;\n }\n }, {\n key: '_selectCol',\n value: function _selectCol(y, sx, ex) {\n this.pushSelectingStep('select', 'col', arguments);\n return this;\n }\n }, {\n key: '_deselect',\n value: function _deselect(sx, sy, ex, ey) {\n this.pushSelectingStep('deselect', null, arguments);\n return this;\n }\n }, {\n key: '_deselectRow',\n value: function _deselectRow(x, sy, ey) {\n this.pushSelectingStep('deselect', 'row', arguments);\n return this;\n }\n }, {\n key: '_deselectCol',\n value: function _deselectCol(y, sx, ex) {\n this.pushSelectingStep('deselect', 'col', arguments);\n return this;\n }\n }, {\n key: '_separate',\n value: function _separate(x, y) {\n this.manager.pushStep(this.capsule, {\n type: 'separate',\n x: x,\n y: y\n });\n return this;\n }\n }, {\n key: '_separateRow',\n value: function _separateRow(x) {\n this._separate(x, -1);\n return this;\n }\n }, {\n key: '_separateCol',\n value: function _separateCol(y) {\n this._separate(-1, y);\n return this;\n }\n }, {\n key: '_deseparate',\n value: function _deseparate(x, y) {\n this.manager.pushStep(this.capsule, {\n type: 'deseparate',\n x: x,\n y: y\n });\n return this;\n }\n }, {\n key: '_deseparateRow',\n value: function _deseparateRow(x) {\n this._deseparate(x, -1);\n return this;\n }\n }, {\n key: '_deseparateCol',\n value: function _deseparateCol(y) {\n this._deseparate(-1, y);\n return this;\n }\n }, {\n key: 'pushSelectingStep',\n value: function pushSelectingStep() {\n var args = Array.prototype.slice.call(arguments);\n var type = args.shift();\n var mode = args.shift();\n args = Array.prototype.slice.call(args.shift());\n var coord;\n switch (mode) {\n case 'row':\n coord = {\n x: args[0],\n sy: args[1],\n ey: args[2]\n };\n break;\n case 'col':\n coord = {\n y: args[0],\n sx: args[1],\n ex: args[2]\n };\n break;\n default:\n if (args[2] === undefined && args[3] === undefined) {\n coord = {\n x: args[0],\n y: args[1]\n };\n } else {\n coord = {\n sx: args[0],\n sy: args[1],\n ex: args[2],\n ey: args[3]\n };\n }\n }\n var step = {\n type: type\n };\n $.extend(step, coord);\n this.manager.pushStep(this.capsule, step);\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'notify':\n if (step.v !== undefined) {\n var $row = this.$table.find('.mtbl-row').eq(step.x);\n var $col = $row.find('.mtbl-col').eq(step.y);\n $col.text(refineByType(step.v));\n }\n case 'denotify':\n case 'select':\n case 'deselect':\n var colorClass = step.type == 'select' || step.type == 'deselect' ? this.colorClass.selected : this.colorClass.notified;\n var addClass = step.type == 'select' || step.type == 'notify';\n var sx = step.sx;\n var sy = step.sy;\n var ex = step.ex;\n var ey = step.ey;\n if (sx === undefined) sx = step.x;\n if (sy === undefined) sy = step.y;\n if (ex === undefined) ex = step.x;\n if (ey === undefined) ey = step.y;\n this.paintColor(sx, sy, ex, ey, colorClass, addClass);\n break;\n case 'separate':\n this.deseparate(step.x, step.y);\n this.separate(step.x, step.y);\n break;\n case 'deseparate':\n this.deseparate(step.x, step.y);\n break;\n default:\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'setData',\n value: function setData(D) {\n this.viewX = this.viewY = 0;\n this.paddingH = 6;\n this.paddingV = 3;\n this.fontSize = 16;\n\n if (_get(Object.getPrototypeOf(Array2DTracer.prototype), 'setData', this).apply(this, arguments)) {\n this.$table.find('.mtbl-row').each(function (i) {\n $(this).find('.mtbl-col').each(function (j) {\n $(this).text(refineByType(D[i][j]));\n });\n });\n return true;\n }\n\n this.$table.empty();\n for (var i = 0; i < D.length; i++) {\n var $row = $('<div class=\"mtbl-row\">');\n this.$table.append($row);\n for (var j = 0; j < D[i].length; j++) {\n var $col = $('<div class=\"mtbl-col\">').css(this.getCellCss()).text(refineByType(D[i][j]));\n $row.append($col);\n }\n }\n this.resize();\n\n return false;\n }\n }, {\n key: 'resize',\n value: function resize() {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'resize', this).call(this);\n\n this.refresh();\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'clear', this).call(this);\n\n this.clearColor();\n this.deseparateAll();\n }\n }, {\n key: 'getCellCss',\n value: function getCellCss() {\n return {\n padding: this.paddingV.toFixed(1) + 'px ' + this.paddingH.toFixed(1) + 'px',\n 'font-size': this.fontSize.toFixed(1) + 'px'\n };\n }\n }, {\n key: 'refresh',\n value: function refresh() {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'refresh', this).call(this);\n\n var $parent = this.$table.parent();\n var top = $parent.height() / 2 - this.$table.height() / 2 + this.viewY;\n var left = $parent.width() / 2 - this.$table.width() / 2 + this.viewX;\n this.$table.css('margin-top', top);\n this.$table.css('margin-left', left);\n }\n }, {\n key: 'mousedown',\n value: function mousedown(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mousedown', this).call(this, e);\n\n this.dragX = e.pageX;\n this.dragY = e.pageY;\n this.dragging = true;\n }\n }, {\n key: 'mousemove',\n value: function mousemove(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mousemove', this).call(this, e);\n\n if (this.dragging) {\n this.viewX += e.pageX - this.dragX;\n this.viewY += e.pageY - this.dragY;\n this.dragX = e.pageX;\n this.dragY = e.pageY;\n this.refresh();\n }\n }\n }, {\n key: 'mouseup',\n value: function mouseup(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mouseup', this).call(this, e);\n\n this.dragging = false;\n }\n }, {\n key: 'mousewheel',\n value: function mousewheel(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mousewheel', this).call(this, e);\n\n e.preventDefault();\n e = e.originalEvent;\n var delta = e.wheelDelta !== undefined && e.wheelDelta || e.detail !== undefined && -e.detail;\n var weight = 1.01;\n var ratio = delta > 0 ? 1 / weight : weight;\n if (this.fontSize < 4 && ratio < 1) return;\n if (this.fontSize > 40 && ratio > 1) return;\n this.paddingV *= ratio;\n this.paddingH *= ratio;\n this.fontSize *= ratio;\n this.$table.find('.mtbl-col').css(this.getCellCss());\n this.refresh();\n }\n }, {\n key: 'paintColor',\n value: function paintColor(sx, sy, ex, ey, colorClass, addClass) {\n for (var i = sx; i <= ex; i++) {\n var $row = this.$table.find('.mtbl-row').eq(i);\n for (var j = sy; j <= ey; j++) {\n var $col = $row.find('.mtbl-col').eq(j);\n if (addClass) $col.addClass(colorClass);else $col.removeClass(colorClass);\n }\n }\n }\n }, {\n key: 'clearColor',\n value: function clearColor() {\n this.$table.find('.mtbl-col').removeClass(Object.keys(this.colorClass).join(' '));\n }\n }, {\n key: 'separate',\n value: function separate(x, y) {\n this.$table.find('.mtbl-row').each(function (i) {\n var $row = $(this);\n if (i == x) {\n $row.after($('<div class=\"mtbl-empty-row\">').attr('data-row', i));\n }\n $row.find('.mtbl-col').each(function (j) {\n var $col = $(this);\n if (j == y) {\n $col.after($('<div class=\"mtbl-empty-col\">').attr('data-col', j));\n }\n });\n });\n }\n }, {\n key: 'deseparate',\n value: function deseparate(x, y) {\n this.$table.find('[data-row=' + x + ']').remove();\n this.$table.find('[data-col=' + y + ']').remove();\n }\n }, {\n key: 'deseparateAll',\n value: function deseparateAll() {\n this.$table.find('.mtbl-empty-row, .mtbl-empty-col').remove();\n }\n }]);\n\n return Array2DTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.$table = tracer.capsule.$table = $('<div class=\"mtbl-table\">');\n tracer.$container.append(tracer.$table);\n};\n\nmodule.exports = Array2DTracer;\n\n},{\"../../tracer_manager/util/index\":67,\"./tracer\":47}],42:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar ChartTracer = function (_Tracer) {\n _inherits(ChartTracer, _Tracer);\n\n _createClass(ChartTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'ChartTracer';\n }\n }]);\n\n function ChartTracer(name) {\n _classCallCheck(this, ChartTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(ChartTracer).call(this, name));\n\n _this.color = {\n selected: 'rgb(0, 0, 255)',\n notified: 'rgb(255, 0, 0)',\n default: 'rgb(136, 136, 136)'\n };\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(ChartTracer, [{\n key: 'setData',\n value: function setData(C) {\n if (_get(Object.getPrototypeOf(ChartTracer.prototype), 'setData', this).apply(this, arguments)) {\n this.chart.config.data.datasets[0].data = C;\n this.chart.update();\n return true;\n }\n\n var color = [];\n for (var i = 0; i < C.length; i++) {\n color.push(this.color.default);\n }this.chart.config.data = {\n labels: C.map(String),\n datasets: [{\n backgroundColor: color,\n data: C\n }]\n };\n this.chart.update();\n }\n }, {\n key: '_notify',\n value: function _notify(s, v) {\n this.manager.pushStep(this.capsule, {\n type: 'notify',\n s: s,\n v: v\n });\n return this;\n }\n }, {\n key: '_denotify',\n value: function _denotify(s) {\n this.manager.pushStep(this.capsule, {\n type: 'denotify',\n s: s\n });\n return this;\n }\n }, {\n key: '_select',\n value: function _select(s, e) {\n this.manager.pushStep(this.capsule, {\n type: 'select',\n s: s,\n e: e\n });\n return this;\n }\n }, {\n key: '_deselect',\n value: function _deselect(s, e) {\n this.manager.pushStep(this.capsule, {\n type: 'deselect',\n s: s,\n e: e\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'notify':\n if (step.v !== undefined) {\n this.chart.config.data.datasets[0].data[step.s] = step.v;\n this.chart.config.data.labels[step.s] = step.v.toString();\n }\n case 'denotify':\n case 'select':\n case 'deselect':\n var color = step.type == 'notify' ? this.color.notified : step.type == 'select' ? this.color.selected : this.color.default;\n if (step.e !== undefined) for (var i = step.s; i <= step.e; i++) {\n this.chart.config.data.datasets[0].backgroundColor[i] = color;\n } else this.chart.config.data.datasets[0].backgroundColor[step.s] = color;\n this.chart.update();\n break;\n default:\n _get(Object.getPrototypeOf(ChartTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'resize',\n value: function resize() {\n _get(Object.getPrototypeOf(ChartTracer.prototype), 'resize', this).call(this);\n\n this.chart.resize();\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(ChartTracer.prototype), 'clear', this).call(this);\n\n var data = this.chart.config.data;\n if (data.datasets.length) {\n var backgroundColor = data.datasets[0].backgroundColor;\n for (var i = 0; i < backgroundColor.length; i++) {\n backgroundColor[i] = this.color.default;\n }\n this.chart.update();\n }\n }\n }]);\n\n return ChartTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.$wrapper = tracer.capsule.$wrapper = $('<canvas class=\"mchrt-chart\">');\n tracer.$container.append(tracer.$wrapper);\n tracer.chart = tracer.capsule.chart = new Chart(tracer.$wrapper, {\n type: 'bar',\n data: {\n labels: [],\n datasets: []\n },\n options: {\n scales: {\n yAxes: [{\n ticks: {\n beginAtZero: true\n }\n }]\n },\n animation: false,\n legend: false,\n responsive: true,\n maintainAspectRatio: false\n }\n });\n};\n\nmodule.exports = ChartTracer;\n\n},{\"./tracer\":47}],43:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar DirectedGraphTracer = require('./directed_graph');\n\nvar CoordinateSystemTracer = function (_DirectedGraphTracer) {\n _inherits(CoordinateSystemTracer, _DirectedGraphTracer);\n\n _createClass(CoordinateSystemTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'CoordinateSystemTracer';\n }\n }]);\n\n function CoordinateSystemTracer(name) {\n _classCallCheck(this, CoordinateSystemTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(CoordinateSystemTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(CoordinateSystemTracer, [{\n key: 'setData',\n value: function setData(C) {\n if (Tracer.prototype.setData.apply(this, arguments)) return true;\n\n this.graph.clear();\n var nodes = [];\n var edges = [];\n for (var i = 0; i < C.length; i++) {\n nodes.push({\n id: this.n(i),\n x: C[i][0],\n y: C[i][1],\n label: '' + i,\n size: 1,\n color: this.color.default\n });\n }this.graph.read({\n nodes: nodes,\n edges: edges\n });\n this.s.camera.goTo({\n x: 0,\n y: 0,\n angle: 0,\n ratio: 1\n });\n this.refresh();\n\n return false;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'visit':\n case 'leave':\n var visit = step.type == 'visit';\n var targetNode = this.graph.nodes(this.n(step.target));\n var color = visit ? this.color.visited : this.color.left;\n targetNode.color = color;\n if (step.source !== undefined) {\n var edgeId = this.e(step.source, step.target);\n if (this.graph.edges(edgeId)) {\n var edge = this.graph.edges(edgeId);\n edge.color = color;\n this.graph.dropEdge(edgeId).addEdge(edge);\n } else {\n this.graph.addEdge({\n id: this.e(step.target, step.source),\n source: this.n(step.source),\n target: this.n(step.target),\n color: color,\n size: 1\n });\n }\n }\n if (this.logTracer) {\n var source = step.source;\n if (source === undefined) source = '';\n this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n }\n break;\n default:\n _get(Object.getPrototypeOf(CoordinateSystemTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'e',\n value: function e(v1, v2) {\n if (v1 > v2) {\n var temp = v1;\n v1 = v2;\n v2 = temp;\n }\n return 'e' + v1 + '_' + v2;\n }\n }, {\n key: 'drawOnHover',\n value: function drawOnHover(node, context, settings, next) {\n var tracer = this;\n\n context.setLineDash([5, 5]);\n var nodeIdx = node.id.substring(1);\n this.graph.edges().forEach(function (edge) {\n var ends = edge.id.substring(1).split(\"_\");\n if (ends[0] == nodeIdx) {\n var color = '#0ff';\n var source = node;\n var target = tracer.graph.nodes('n' + ends[1]);\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n } else if (ends[1] == nodeIdx) {\n var color = '#0ff';\n var source = tracer.graph.nodes('n' + ends[0]);\n var target = node;\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n }\n });\n }\n }, {\n key: 'drawEdge',\n value: function drawEdge(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1;\n\n context.strokeStyle = color;\n context.lineWidth = size;\n context.beginPath();\n context.moveTo(source[prefix + 'x'], source[prefix + 'y']);\n context.lineTo(target[prefix + 'x'], target[prefix + 'y']);\n context.stroke();\n }\n }]);\n\n return CoordinateSystemTracer;\n}(DirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n defaultEdgeType: 'def',\n funcEdgesDef: function funcEdgesDef(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawEdge(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = CoordinateSystemTracer;\n\n},{\"./directed_graph\":44}],44:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar refineByType = _require.refineByType;\n\nvar DirectedGraphTracer = function (_Tracer) {\n _inherits(DirectedGraphTracer, _Tracer);\n\n _createClass(DirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'DirectedGraphTracer';\n }\n }]);\n\n function DirectedGraphTracer(name) {\n _classCallCheck(this, DirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(DirectedGraphTracer).call(this, name));\n\n _this.color = {\n selected: '#0f0',\n visited: '#f00',\n left: '#000',\n default: '#888'\n };\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(DirectedGraphTracer, [{\n key: '_setTreeData',\n value: function _setTreeData(G, root) {\n this.manager.pushStep(this.capsule, {\n type: 'setTreeData',\n arguments: arguments\n });\n return this;\n }\n }, {\n key: '_visit',\n value: function _visit(target, source) {\n this.manager.pushStep(this.capsule, {\n type: 'visit',\n target: target,\n source: source\n });\n return this;\n }\n }, {\n key: '_leave',\n value: function _leave(target, source) {\n this.manager.pushStep(this.capsule, {\n type: 'leave',\n target: target,\n source: source\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'setTreeData':\n this.setTreeData.apply(this, step.arguments);\n break;\n case 'visit':\n case 'leave':\n var visit = step.type == 'visit';\n var targetNode = this.graph.nodes(this.n(step.target));\n var color = visit ? this.color.visited : this.color.left;\n targetNode.color = color;\n if (step.source !== undefined) {\n var edgeId = this.e(step.source, step.target);\n var edge = this.graph.edges(edgeId);\n edge.color = color;\n this.graph.dropEdge(edgeId).addEdge(edge);\n }\n if (this.logTracer) {\n var source = step.source;\n if (source === undefined) source = '';\n this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n }\n break;\n default:\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'setTreeData',\n value: function setTreeData(G, root, undirected) {\n var tracer = this;\n\n root = root || 0;\n var maxDepth = -1;\n\n var chk = new Array(G.length);\n var getDepth = function getDepth(node, depth) {\n if (chk[node]) throw \"the given graph is not a tree because it forms a circuit\";\n chk[node] = true;\n if (maxDepth < depth) maxDepth = depth;\n for (var i = 0; i < G[node].length; i++) {\n if (G[node][i]) getDepth(i, depth + 1);\n }\n };\n getDepth(root, 1);\n\n if (this.setData(G, undirected)) return true;\n\n var place = function place(node, x, y) {\n var temp = tracer.graph.nodes(tracer.n(node));\n temp.x = x;\n temp.y = y;\n };\n\n var wgap = 1 / (maxDepth - 1);\n var dfs = function dfs(node, depth, top, bottom) {\n place(node, top + bottom, depth * wgap);\n var children = 0;\n for (var i = 0; i < G[node].length; i++) {\n if (G[node][i]) children++;\n }\n var vgap = (bottom - top) / children;\n var cnt = 0;\n for (var i = 0; i < G[node].length; i++) {\n if (G[node][i]) dfs(i, depth + 1, top + vgap * cnt, top + vgap * ++cnt);\n }\n };\n dfs(root, 0, 0, 1);\n\n this.refresh();\n }\n }, {\n key: 'setData',\n value: function setData(G, undirected) {\n if (_get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'setData', this).apply(this, arguments)) return true;\n\n this.graph.clear();\n var nodes = [];\n var edges = [];\n var unitAngle = 2 * Math.PI / G.length;\n var currentAngle = 0;\n for (var i = 0; i < G.length; i++) {\n currentAngle += unitAngle;\n nodes.push({\n id: this.n(i),\n label: '' + i,\n x: .5 + Math.sin(currentAngle) / 2,\n y: .5 + Math.cos(currentAngle) / 2,\n size: 1,\n color: this.color.default,\n weight: 0\n });\n\n if (undirected) {\n for (var j = 0; j <= i; j++) {\n var value = G[i][j] || G[j][i];\n if (value) {\n edges.push({\n id: this.e(i, j),\n source: this.n(i),\n target: this.n(j),\n color: this.color.default,\n size: 1,\n weight: refineByType(value)\n });\n }\n }\n } else {\n for (var _j = 0; _j < G[i].length; _j++) {\n if (G[i][_j]) {\n edges.push({\n id: this.e(i, _j),\n source: this.n(i),\n target: this.n(_j),\n color: this.color.default,\n size: 1,\n weight: refineByType(G[i][_j])\n });\n }\n }\n }\n }\n\n this.graph.read({\n nodes: nodes,\n edges: edges\n });\n this.s.camera.goTo({\n x: 0,\n y: 0,\n angle: 0,\n ratio: 1\n });\n this.refresh();\n\n return false;\n }\n }, {\n key: 'resize',\n value: function resize() {\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'resize', this).call(this);\n\n this.s.renderers[0].resize();\n this.refresh();\n }\n }, {\n key: 'refresh',\n value: function refresh() {\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'refresh', this).call(this);\n\n this.s.refresh();\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'clear', this).call(this);\n\n this.clearGraphColor();\n this.refresh();\n }\n }, {\n key: 'clearGraphColor',\n value: function clearGraphColor() {\n var tracer = this;\n\n this.graph.nodes().forEach(function (node) {\n node.color = tracer.color.default;\n });\n this.graph.edges().forEach(function (edge) {\n edge.color = tracer.color.default;\n });\n }\n }, {\n key: 'n',\n value: function n(v) {\n return 'n' + v;\n }\n }, {\n key: 'e',\n value: function e(v1, v2) {\n return 'e' + v1 + '_' + v2;\n }\n }, {\n key: 'getColor',\n value: function getColor(edge, source, target, settings) {\n var color = edge.color,\n edgeColor = settings('edgeColor'),\n defaultNodeColor = settings('defaultNodeColor'),\n defaultEdgeColor = settings('defaultEdgeColor');\n if (!color) switch (edgeColor) {\n case 'source':\n color = source.color || defaultNodeColor;\n break;\n case 'target':\n color = target.color || defaultNodeColor;\n break;\n default:\n color = defaultEdgeColor;\n break;\n }\n\n return color;\n }\n }, {\n key: 'drawLabel',\n value: function drawLabel(node, context, settings) {\n var fontSize,\n prefix = settings('prefix') || '',\n size = node[prefix + 'size'];\n\n if (size < settings('labelThreshold')) return;\n\n if (!node.label || typeof node.label !== 'string') return;\n\n fontSize = settings('labelSize') === 'fixed' ? settings('defaultLabelSize') : settings('labelSizeRatio') * size;\n\n context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') + fontSize + 'px ' + settings('font');\n context.fillStyle = settings('labelColor') === 'node' ? node.color || settings('defaultNodeColor') : settings('defaultLabelColor');\n\n context.textAlign = 'center';\n context.fillText(node.label, Math.round(node[prefix + 'x']), Math.round(node[prefix + 'y'] + fontSize / 3));\n }\n }, {\n key: 'drawArrow',\n value: function drawArrow(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1,\n tSize = target[prefix + 'size'],\n sX = source[prefix + 'x'],\n sY = source[prefix + 'y'],\n tX = target[prefix + 'x'],\n tY = target[prefix + 'y'],\n angle = Math.atan2(tY - sY, tX - sX),\n dist = 3;\n sX += Math.sin(angle) * dist;\n tX += Math.sin(angle) * dist;\n sY += -Math.cos(angle) * dist;\n tY += -Math.cos(angle) * dist;\n var aSize = Math.max(size * 2.5, settings('minArrowSize')),\n d = Math.sqrt(Math.pow(tX - sX, 2) + Math.pow(tY - sY, 2)),\n aX = sX + (tX - sX) * (d - aSize - tSize) / d,\n aY = sY + (tY - sY) * (d - aSize - tSize) / d,\n vX = (tX - sX) * aSize / d,\n vY = (tY - sY) * aSize / d;\n\n context.strokeStyle = color;\n context.lineWidth = size;\n context.beginPath();\n context.moveTo(sX, sY);\n context.lineTo(aX, aY);\n context.stroke();\n\n context.fillStyle = color;\n context.beginPath();\n context.moveTo(aX + vX, aY + vY);\n context.lineTo(aX + vY * 0.6, aY - vX * 0.6);\n context.lineTo(aX - vY * 0.6, aY + vX * 0.6);\n context.lineTo(aX + vX, aY + vY);\n context.closePath();\n context.fill();\n }\n }, {\n key: 'drawOnHover',\n value: function drawOnHover(node, context, settings, next) {\n var tracer = this;\n\n context.setLineDash([5, 5]);\n var nodeIdx = node.id.substring(1);\n this.graph.edges().forEach(function (edge) {\n var ends = edge.id.substring(1).split(\"_\");\n if (ends[0] == nodeIdx) {\n var color = '#0ff';\n var source = node;\n var target = tracer.graph.nodes('n' + ends[1]);\n tracer.drawArrow(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n } else if (ends[1] == nodeIdx) {\n var color = '#ff0';\n var source = tracer.graph.nodes('n' + ends[0]);\n var target = node;\n tracer.drawArrow(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n }\n });\n }\n }]);\n\n return DirectedGraphTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.s = tracer.capsule.s = new sigma({\n renderer: {\n container: tracer.$container[0],\n type: 'canvas'\n },\n settings: {\n minArrowSize: 8,\n defaultEdgeType: 'arrow',\n maxEdgeSize: 2.5,\n labelThreshold: 4,\n font: 'Roboto',\n defaultLabelColor: '#fff',\n zoomMin: 0.6,\n zoomMax: 1.2,\n skipErrors: true,\n minNodeSize: .5,\n maxNodeSize: 12,\n labelSize: 'proportional',\n labelSizeRatio: 1.3,\n funcLabelsDef: function funcLabelsDef(node, context, settings) {\n tracer.drawLabel(node, context, settings);\n },\n funcHoversDef: function funcHoversDef(node, context, settings, next) {\n tracer.drawOnHover(node, context, settings, next);\n },\n funcEdgesArrow: function funcEdgesArrow(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawArrow(edge, source, target, color, context, settings);\n }\n }\n });\n sigma.plugins.dragNodes(tracer.s, tracer.s.renderers[0]);\n tracer.graph = tracer.capsule.graph = tracer.s.graph;\n};\n\nsigma.canvas.labels.def = function (node, context, settings) {\n var func = settings('funcLabelsDef');\n if (func) {\n func(node, context, settings);\n }\n};\nsigma.canvas.hovers.def = function (node, context, settings) {\n var func = settings('funcHoversDef');\n if (func) {\n func(node, context, settings);\n }\n};\nsigma.canvas.edges.def = function (edge, source, target, context, settings) {\n var func = settings('funcEdgesDef');\n if (func) {\n func(edge, source, target, context, settings);\n }\n};\nsigma.canvas.edges.arrow = function (edge, source, target, context, settings) {\n var func = settings('funcEdgesArrow');\n if (func) {\n func(edge, source, target, context, settings);\n }\n};\n\nmodule.exports = DirectedGraphTracer;\n\n},{\"../../tracer_manager/util/index\":67,\"./tracer\":47}],45:[function(require,module,exports){\n'use strict';\n\nvar Tracer = require('./tracer');\nvar LogTracer = require('./log');\nvar Array1DTracer = require('./array1d');\nvar Array2DTracer = require('./array2d');\nvar ChartTracer = require('./chart');\nvar CoordinateSystemTracer = require('./coordinate_system');\nvar DirectedGraphTracer = require('./directed_graph');\nvar UndirectedGraphTracer = require('./undirected_graph');\nvar WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nvar WeightedUndirectedGraphTracer = require('./weighted_undirected_graph');\n\nmodule.exports = {\n Tracer: Tracer,\n LogTracer: LogTracer,\n Array1DTracer: Array1DTracer,\n Array2DTracer: Array2DTracer,\n ChartTracer: ChartTracer,\n CoordinateSystemTracer: CoordinateSystemTracer,\n DirectedGraphTracer: DirectedGraphTracer,\n UndirectedGraphTracer: UndirectedGraphTracer,\n WeightedDirectedGraphTracer: WeightedDirectedGraphTracer,\n WeightedUndirectedGraphTracer: WeightedUndirectedGraphTracer\n};\n\n},{\"./array1d\":40,\"./array2d\":41,\"./chart\":42,\"./coordinate_system\":43,\"./directed_graph\":44,\"./log\":46,\"./tracer\":47,\"./undirected_graph\":48,\"./weighted_directed_graph\":49,\"./weighted_undirected_graph\":50}],46:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar LogTracer = function (_Tracer) {\n _inherits(LogTracer, _Tracer);\n\n _createClass(LogTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'LogTracer';\n }\n }]);\n\n function LogTracer(name) {\n _classCallCheck(this, LogTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(LogTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(LogTracer, [{\n key: '_print',\n value: function _print(msg) {\n this.manager.pushStep(this.capsule, {\n type: 'print',\n msg: msg\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'print':\n this.print(step.msg);\n break;\n }\n }\n }, {\n key: 'refresh',\n value: function refresh() {\n this.scrollToEnd(Math.min(50, this.interval));\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(LogTracer.prototype), 'clear', this).call(this);\n\n this.$wrapper.empty();\n }\n }, {\n key: 'print',\n value: function print(message) {\n this.$wrapper.append($('<span>').append(message + '<br/>'));\n }\n }, {\n key: 'scrollToEnd',\n value: function scrollToEnd(duration) {\n this.$container.animate({\n scrollTop: this.$container[0].scrollHeight\n }, duration);\n }\n }]);\n\n return LogTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.$wrapper = tracer.capsule.$wrapper = $('<div class=\"wrapper\">');\n tracer.$container.append(tracer.$wrapper);\n};\n\nmodule.exports = LogTracer;\n\n},{\"./tracer\":47}],47:[function(require,module,exports){\n'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar app = require('../../app');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar toJSON = _require.toJSON;\nvar fromJSON = _require.fromJSON;\n\nvar Tracer = function () {\n _createClass(Tracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'Tracer';\n }\n }]);\n\n function Tracer(name) {\n _classCallCheck(this, Tracer);\n\n this.module = this.constructor;\n\n this.manager = app.getTracerManager();\n this.capsule = this.manager.allocate(this);\n $.extend(this, this.capsule);\n\n this.setName(name);\n }\n\n _createClass(Tracer, [{\n key: '_setData',\n value: function _setData() {\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n this.manager.pushStep(this.capsule, {\n type: 'setData',\n args: toJSON(args)\n });\n return this;\n }\n }, {\n key: '_clear',\n value: function _clear() {\n this.manager.pushStep(this.capsule, {\n type: 'clear'\n });\n return this;\n }\n }, {\n key: '_wait',\n value: function _wait(line) {\n this.manager.newStep(line);\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n var type = step.type;\n var args = step.args;\n\n\n switch (type) {\n case 'setData':\n this.setData.apply(this, _toConsumableArray(fromJSON(args)));\n break;\n case 'clear':\n this.clear();\n break;\n }\n }\n }, {\n key: 'setName',\n value: function setName(name) {\n var $name = void 0;\n if (this.isNew) {\n $name = $('<span class=\"name\">');\n this.$container.append($name);\n } else {\n $name = this.$container.find('span.name');\n }\n $name.text(name || this.defaultName);\n }\n }, {\n key: 'setData',\n value: function setData() {\n var data = toJSON(arguments);\n if (!this.isNew && this.lastData === data) {\n return true;\n }\n this.lastData = this.capsule.lastData = data;\n return false;\n }\n }, {\n key: 'resize',\n value: function resize() {}\n }, {\n key: 'refresh',\n value: function refresh() {}\n }, {\n key: 'clear',\n value: function clear() {}\n }, {\n key: 'attach',\n value: function attach(tracer) {\n switch (tracer.module) {\n case LogTracer:\n this.logTracer = tracer;\n break;\n case ChartTracer:\n this.chartTracer = tracer;\n break;\n }\n return this;\n }\n }, {\n key: 'mousedown',\n value: function mousedown(e) {}\n }, {\n key: 'mousemove',\n value: function mousemove(e) {}\n }, {\n key: 'mouseup',\n value: function mouseup(e) {}\n }, {\n key: 'mousewheel',\n value: function mousewheel(e) {}\n }]);\n\n return Tracer;\n}();\n\nmodule.exports = Tracer;\n\n},{\"../../app\":3,\"../../tracer_manager/util/index\":67}],48:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar DirectedGraphTracer = require('./directed_graph');\n\nvar UndirectedGraphTracer = function (_DirectedGraphTracer) {\n _inherits(UndirectedGraphTracer, _DirectedGraphTracer);\n\n _createClass(UndirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'UndirectedGraphTracer';\n }\n }]);\n\n function UndirectedGraphTracer(name) {\n _classCallCheck(this, UndirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(UndirectedGraphTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(UndirectedGraphTracer, [{\n key: 'setTreeData',\n value: function setTreeData(G, root) {\n return _get(Object.getPrototypeOf(UndirectedGraphTracer.prototype), 'setTreeData', this).call(this, G, root, true);\n }\n }, {\n key: 'setData',\n value: function setData(G) {\n return _get(Object.getPrototypeOf(UndirectedGraphTracer.prototype), 'setData', this).call(this, G, true);\n }\n }, {\n key: 'e',\n value: function e(v1, v2) {\n if (v1 > v2) {\n var temp = v1;\n v1 = v2;\n v2 = temp;\n }\n return 'e' + v1 + '_' + v2;\n }\n }, {\n key: 'drawOnHover',\n value: function drawOnHover(node, context, settings, next) {\n var tracer = this;\n\n context.setLineDash([5, 5]);\n var nodeIdx = node.id.substring(1);\n this.graph.edges().forEach(function (edge) {\n var ends = edge.id.substring(1).split(\"_\");\n if (ends[0] == nodeIdx) {\n var color = '#0ff';\n var source = node;\n var target = tracer.graph.nodes('n' + ends[1]);\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n } else if (ends[1] == nodeIdx) {\n var color = '#0ff';\n var source = tracer.graph.nodes('n' + ends[0]);\n var target = node;\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n }\n });\n }\n }, {\n key: 'drawEdge',\n value: function drawEdge(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1;\n\n context.strokeStyle = color;\n context.lineWidth = size;\n context.beginPath();\n context.moveTo(source[prefix + 'x'], source[prefix + 'y']);\n context.lineTo(target[prefix + 'x'], target[prefix + 'y']);\n context.stroke();\n }\n }]);\n\n return UndirectedGraphTracer;\n}(DirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n defaultEdgeType: 'def',\n funcEdgesDef: function funcEdgesDef(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawEdge(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = UndirectedGraphTracer;\n\n},{\"./directed_graph\":44}],49:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar DirectedGraphTracer = require('./directed_graph');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar refineByType = _require.refineByType;\n\nvar WeightedDirectedGraphTracer = function (_DirectedGraphTracer) {\n _inherits(WeightedDirectedGraphTracer, _DirectedGraphTracer);\n\n _createClass(WeightedDirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'WeightedDirectedGraphTracer';\n }\n }]);\n\n function WeightedDirectedGraphTracer(name) {\n _classCallCheck(this, WeightedDirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(WeightedDirectedGraphTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(WeightedDirectedGraphTracer, [{\n key: '_weight',\n value: function _weight(target, weight) {\n this.manager.pushStep(this.capsule, {\n type: 'weight',\n target: target,\n weight: weight\n });\n return this;\n }\n }, {\n key: '_visit',\n value: function _visit(target, source, weight) {\n this.manager.pushStep(this.capsule, {\n type: 'visit',\n target: target,\n source: source,\n weight: weight\n });\n return this;\n }\n }, {\n key: '_leave',\n value: function _leave(target, source, weight) {\n this.manager.pushStep(this.capsule, {\n type: 'leave',\n target: target,\n source: source,\n weight: weight\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'weight':\n var targetNode = this.graph.nodes(this.n(step.target));\n if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n break;\n case 'visit':\n case 'leave':\n var visit = step.type == 'visit';\n var targetNode = this.graph.nodes(this.n(step.target));\n var color = visit ? step.weight === undefined ? this.color.selected : this.color.visited : this.color.left;\n targetNode.color = color;\n if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n if (step.source !== undefined) {\n var edgeId = this.e(step.source, step.target);\n var edge = this.graph.edges(edgeId);\n edge.color = color;\n this.graph.dropEdge(edgeId).addEdge(edge);\n }\n if (this.logTracer) {\n var source = step.source;\n if (source === undefined) source = '';\n this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n }\n break;\n default:\n _get(Object.getPrototypeOf(WeightedDirectedGraphTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(WeightedDirectedGraphTracer.prototype), 'clear', this).call(this);\n\n this.clearWeights();\n }\n }, {\n key: 'clearWeights',\n value: function clearWeights() {\n this.graph.nodes().forEach(function (node) {\n node.weight = 0;\n });\n }\n }, {\n key: 'drawEdgeWeight',\n value: function drawEdgeWeight(edge, source, target, color, context, settings) {\n if (source == target) return;\n\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1;\n\n if (size < settings('edgeLabelThreshold')) return;\n\n if (0 === settings('edgeLabelSizePowRatio')) throw '\"edgeLabelSizePowRatio\" must not be 0.';\n\n var fontSize,\n x = (source[prefix + 'x'] + target[prefix + 'x']) / 2,\n y = (source[prefix + 'y'] + target[prefix + 'y']) / 2,\n dX = target[prefix + 'x'] - source[prefix + 'x'],\n dY = target[prefix + 'y'] - source[prefix + 'y'],\n angle = Math.atan2(dY, dX);\n\n fontSize = settings('edgeLabelSize') === 'fixed' ? settings('defaultEdgeLabelSize') : settings('defaultEdgeLabelSize') * size * Math.pow(size, -1 / settings('edgeLabelSizePowRatio'));\n\n context.save();\n\n if (edge.active) {\n context.font = [settings('activeFontStyle'), fontSize + 'px', settings('activeFont') || settings('font')].join(' ');\n\n context.fillStyle = color;\n } else {\n context.font = [settings('fontStyle'), fontSize + 'px', settings('font')].join(' ');\n\n context.fillStyle = color;\n }\n\n context.textAlign = 'center';\n context.textBaseline = 'alphabetic';\n\n context.translate(x, y);\n context.rotate(angle);\n context.fillText(edge.weight, 0, -size / 2 - 3);\n\n context.restore();\n }\n }, {\n key: 'drawNodeWeight',\n value: function drawNodeWeight(node, context, settings) {\n var fontSize,\n prefix = settings('prefix') || '',\n size = node[prefix + 'size'];\n\n if (size < settings('labelThreshold')) return;\n\n fontSize = settings('labelSize') === 'fixed' ? settings('defaultLabelSize') : settings('labelSizeRatio') * size;\n\n context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') + fontSize + 'px ' + settings('font');\n context.fillStyle = settings('labelColor') === 'node' ? node.color || settings('defaultNodeColor') : settings('defaultLabelColor');\n\n context.textAlign = 'left';\n context.fillText(node.weight, Math.round(node[prefix + 'x'] + size * 1.5), Math.round(node[prefix + 'y'] + fontSize / 3));\n }\n }]);\n\n return WeightedDirectedGraphTracer;\n}(DirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n edgeLabelSize: 'proportional',\n defaultEdgeLabelSize: 20,\n edgeLabelSizePowRatio: 0.8,\n funcLabelsDef: function funcLabelsDef(node, context, settings) {\n tracer.drawNodeWeight(node, context, settings);\n tracer.drawLabel(node, context, settings);\n },\n funcHoversDef: function funcHoversDef(node, context, settings) {\n tracer.drawOnHover(node, context, settings, tracer.drawEdgeWeight);\n },\n funcEdgesArrow: function funcEdgesArrow(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawArrow(edge, source, target, color, context, settings);\n tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = WeightedDirectedGraphTracer;\n\n},{\"../../tracer_manager/util/index\":67,\"./directed_graph\":44}],50:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nvar UndirectedGraphTracer = require('./undirected_graph');\n\nvar WeightedUndirectedGraphTracer = function (_WeightedDirectedGrap) {\n _inherits(WeightedUndirectedGraphTracer, _WeightedDirectedGrap);\n\n _createClass(WeightedUndirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'WeightedUndirectedGraphTracer';\n }\n }]);\n\n function WeightedUndirectedGraphTracer(name) {\n _classCallCheck(this, WeightedUndirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(WeightedUndirectedGraphTracer).call(this, name));\n\n _this.e = UndirectedGraphTracer.prototype.e;\n _this.drawOnHover = UndirectedGraphTracer.prototype.drawOnHover;\n _this.drawEdge = UndirectedGraphTracer.prototype.drawEdge;\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(WeightedUndirectedGraphTracer, [{\n key: 'setTreeData',\n value: function setTreeData(G, root) {\n return _get(Object.getPrototypeOf(WeightedUndirectedGraphTracer.prototype), 'setTreeData', this).call(this, G, root, true);\n }\n }, {\n key: 'setData',\n value: function setData(G) {\n return _get(Object.getPrototypeOf(WeightedUndirectedGraphTracer.prototype), 'setData', this).call(this, G, true);\n }\n }, {\n key: 'drawEdgeWeight',\n value: function drawEdgeWeight(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '';\n if (source[prefix + 'x'] > target[prefix + 'x']) {\n var temp = source;\n source = target;\n target = temp;\n }\n WeightedDirectedGraphTracer.prototype.drawEdgeWeight.call(this, edge, source, target, color, context, settings);\n }\n }]);\n\n return WeightedUndirectedGraphTracer;\n}(WeightedDirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n defaultEdgeType: 'def',\n funcEdgesDef: function funcEdgesDef(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawEdge(edge, source, target, color, context, settings);\n tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = WeightedUndirectedGraphTracer;\n\n},{\"./undirected_graph\":48,\"./weighted_directed_graph\":49}],51:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url) {\n return request(url, {\n type: 'GET'\n });\n};\n\n},{\"./request\":54}],52:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url) {\n return request(url, {\n dataType: 'json',\n type: 'GET'\n });\n};\n\n},{\"./request\":54}],53:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url, data) {\n return request(url, {\n dataType: 'json',\n type: 'POST',\n data: JSON.stringify(data)\n });\n};\n\n},{\"./request\":54}],54:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('../../app');\n\nvar _$ = $;\nvar ajax = _$.ajax;\nvar extend = _$.extend;\n\n\nvar defaults = {};\n\nmodule.exports = function (url) {\n var options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1];\n\n app.setIsLoading(true);\n\n return new RSVP.Promise(function (resolve, reject) {\n var callbacks = {\n success: function success(response) {\n app.setIsLoading(false);\n resolve(response);\n },\n error: function error(reason) {\n app.setIsLoading(false);\n reject(reason);\n }\n };\n\n var opts = extend({}, defaults, options, callbacks, {\n url: url\n });\n\n ajax(opts);\n });\n};\n\n},{\"../../app\":3,\"rsvp\":72}],55:[function(require,module,exports){\n'use strict';\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar app = require('../app');\nvar Toast = require('../dom/toast');\n\nvar checkLoading = function checkLoading() {\n if (app.getIsLoading()) {\n Toast.showErrorToast('Wait until it completes loading of previous file.');\n return true;\n }\n return false;\n};\n\nvar getParameterByName = function getParameterByName(name) {\n var url = window.location.href;\n var regex = new RegExp('[?&]' + name + '(=([^&#]*)|&|#|$)');\n\n var results = regex.exec(url);\n\n if (!results || results.length !== 3) {\n return null;\n }\n\n var _results = _slicedToArray(results, 3);\n\n var id = _results[2];\n\n\n return id;\n};\n\nvar getHashValue = function getHashValue(key) {\n if (!key) return null;\n var hash = window.location.hash.substr(1);\n var params = hash ? hash.split('&') : [];\n for (var i = 0; i < params.length; i++) {\n var pair = params[i].split('=');\n if (pair[0] === key) {\n return pair[1];\n }\n }\n return null;\n};\n\nvar setHashValue = function setHashValue(key, value) {\n if (!key || !value) return;\n var hash = window.location.hash.substr(1);\n var params = hash ? hash.split('&') : [];\n\n var found = false;\n for (var i = 0; i < params.length && !found; i++) {\n var pair = params[i].split('=');\n if (pair[0] === key) {\n pair[1] = value;\n params[i] = pair.join('=');\n found = true;\n }\n }\n if (!found) {\n params.push([key, value].join('='));\n }\n\n var newHash = params.join('&');\n window.location.hash = '#' + newHash;\n};\n\nvar removeHashValue = function removeHashValue(key) {\n if (!key) return;\n var hash = window.location.hash.substr(1);\n var params = hash ? hash.split('&') : [];\n\n for (var i = 0; i < params.length; i++) {\n var pair = params[i].split('=');\n if (pair[0] === key) {\n params.splice(i, 1);\n break;\n }\n }\n\n var newHash = params.join('&');\n window.location.hash = '#' + newHash;\n};\n\nvar setPath = function setPath(category, algorithm, file) {\n var path = category ? category + (algorithm ? '/' + algorithm + (file ? '/' + file : '') : '') : '';\n setHashValue('path', path);\n};\n\nvar getPath = function getPath() {\n var hash = getHashValue('path');\n if (hash) {\n var _hash$split = hash.split('/');\n\n var _hash$split2 = _slicedToArray(_hash$split, 3);\n\n var category = _hash$split2[0];\n var algorithm = _hash$split2[1];\n var file = _hash$split2[2];\n\n return { category: category, algorithm: algorithm, file: file };\n } else {\n return false;\n }\n};\n\nmodule.exports = {\n checkLoading: checkLoading,\n getParameterByName: getParameterByName,\n getHashValue: getHashValue,\n setHashValue: setHashValue,\n removeHashValue: removeHashValue,\n setPath: setPath,\n getPath: getPath\n};\n\n},{\"../app\":3,\"../dom/toast\":24}],56:[function(require,module,exports){\n'use strict';\n\nvar loadAlgorithm = require('./load_algorithm');\nvar loadCategories = require('./load_categories');\nvar loadFile = require('./load_file');\nvar loadScratchPaper = require('./load_scratch_paper');\nvar shareScratchPaper = require('./share_scratch_paper');\nvar loadWikiList = require('./load_wiki_list');\nvar loadWiki = require('./load_wiki');\n\nmodule.exports = {\n loadAlgorithm: loadAlgorithm,\n loadCategories: loadCategories,\n loadFile: loadFile,\n loadScratchPaper: loadScratchPaper,\n shareScratchPaper: shareScratchPaper,\n loadWikiList: loadWikiList,\n loadWiki: loadWiki\n};\n\n},{\"./load_algorithm\":57,\"./load_categories\":58,\"./load_file\":59,\"./load_scratch_paper\":60,\"./load_wiki\":61,\"./load_wiki_list\":62,\"./share_scratch_paper\":63}],57:[function(require,module,exports){\n'use strict';\n\nvar getJSON = require('./ajax/get_json');\n\nvar _require = require('../utils');\n\nvar getAlgorithmDir = _require.getAlgorithmDir;\n\n\nmodule.exports = function (category, algorithm) {\n var dir = getAlgorithmDir(category, algorithm);\n return getJSON(dir + 'desc.json');\n};\n\n},{\"../utils\":70,\"./ajax/get_json\":52}],58:[function(require,module,exports){\n'use strict';\n\nvar getJSON = require('./ajax/get_json');\n\nmodule.exports = function () {\n return getJSON('./algorithm/category.json');\n};\n\n},{\"./ajax/get_json\":52}],59:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\n\nvar app = require('../app');\n\nvar _require = require('../utils');\n\nvar getFileDir = _require.getFileDir;\nvar isScratchPaper = _require.isScratchPaper;\n\nvar _require2 = require('./helpers');\n\nvar checkLoading = _require2.checkLoading;\nvar setPath = _require2.setPath;\n\n\nvar get = require('./ajax/get');\n\nvar loadDataAndCode = function loadDataAndCode(dir) {\n return RSVP.hash({\n data: get(dir + 'data.js'),\n code: get(dir + 'code.js')\n });\n};\n\nvar loadFileAndUpdateContent = function loadFileAndUpdateContent(dir) {\n app.getEditor().clearContent();\n\n return loadDataAndCode(dir).then(function (content) {\n app.updateCachedFile(dir, content);\n app.getEditor().setContent(content);\n });\n};\n\nvar cachedContentExists = function cachedContentExists(cachedFile) {\n return cachedFile && cachedFile.data !== undefined && cachedFile.code !== undefined;\n};\n\nmodule.exports = function (category, algorithm, file, explanation) {\n return new RSVP.Promise(function (resolve, reject) {\n if (checkLoading()) {\n reject();\n } else {\n if (isScratchPaper(category)) {\n setPath(category, app.getLoadedScratch());\n } else {\n setPath(category, algorithm, file);\n }\n $('#explanation').html(explanation);\n\n var dir = getFileDir(category, algorithm, file);\n app.setLastFileUsed(dir);\n var cachedFile = app.getCachedFile(dir);\n\n if (cachedContentExists(cachedFile)) {\n app.getEditor().setContent(cachedFile);\n resolve();\n } else {\n loadFileAndUpdateContent(dir).then(resolve, reject);\n }\n }\n });\n};\n\n},{\"../app\":3,\"../utils\":70,\"./ajax/get\":51,\"./helpers\":55,\"rsvp\":72}],60:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('../app');\n\nvar _require = require('../utils');\n\nvar getFileDir = _require.getFileDir;\n\n\nvar getJSON = require('./ajax/get_json');\nvar loadAlgorithm = require('./load_algorithm');\n\nvar extractGistCode = function extractGistCode(files, name) {\n return files[name + '.js'].content;\n};\n\nmodule.exports = function (gistID) {\n return new RSVP.Promise(function (resolve, reject) {\n app.setLoadedScratch(gistID);\n\n getJSON('https://api.github.com/gists/' + gistID).then(function (_ref) {\n var files = _ref.files;\n\n\n var category = 'scratch';\n var algorithm = gistID;\n\n loadAlgorithm(category, algorithm).then(function (data) {\n\n var algoData = extractGistCode(files, 'data');\n var algoCode = extractGistCode(files, 'code');\n\n // update scratch paper algo code with the loaded gist code\n var dir = getFileDir(category, algorithm, 'scratch_paper');\n app.updateCachedFile(dir, {\n data: algoData,\n code: algoCode,\n 'CREDIT.md': 'Shared by an anonymous user from http://parkjs814.github.io/AlgorithmVisualizer'\n });\n\n resolve({\n category: category,\n algorithm: algorithm,\n data: data\n });\n });\n });\n });\n};\n\n},{\"../app\":3,\"../utils\":70,\"./ajax/get_json\":52,\"./load_algorithm\":57,\"rsvp\":72}],61:[function(require,module,exports){\n'use strict';\n\nvar get = require('./ajax/get');\n\nmodule.exports = function (wiki) {\n return get('./AlgorithmVisualizer.wiki/' + wiki + '.md');\n};\n\n},{\"./ajax/get\":51}],62:[function(require,module,exports){\n'use strict';\n\nvar getJSON = require('./ajax/get_json');\n\nmodule.exports = function () {\n return getJSON('./wiki.json');\n};\n\n},{\"./ajax/get_json\":52}],63:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('../app');\n\nvar postJSON = require('./ajax/post_json');\n\nvar _require = require('./helpers');\n\nvar setPath = _require.setPath;\n\n\nmodule.exports = function () {\n return new RSVP.Promise(function (resolve, reject) {\n var _app$getEditor = app.getEditor();\n\n var dataEditor = _app$getEditor.dataEditor;\n var codeEditor = _app$getEditor.codeEditor;\n\n\n var gist = {\n 'description': 'temp',\n 'public': true,\n 'files': {\n 'data.js': {\n 'content': dataEditor.getValue()\n },\n 'code.js': {\n 'content': codeEditor.getValue()\n }\n }\n };\n\n postJSON('https://api.github.com/gists', gist).then(function (_ref) {\n var id = _ref.id;\n\n app.setLoadedScratch(id);\n setPath('scratch', id);\n var _location = location;\n var href = _location.href;\n\n $('#algorithm').html('Shared');\n resolve(href);\n });\n });\n};\n\n},{\"../app\":3,\"./ajax/post_json\":53,\"./helpers\":55,\"rsvp\":72}],64:[function(require,module,exports){\n'use strict';\n\nvar TracerManager = require('./manager');\nvar Tracer = require('../module/tracer/tracer');\n\nmodule.exports = {\n init: function init() {\n var tm = new TracerManager();\n Tracer.prototype.manager = tm;\n return tm;\n }\n};\n\n},{\"../module/tracer/tracer\":47,\"./manager\":65}],65:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar ModuleContainer = require('../dom/module_container');\nvar TopMenu = require('../dom/top_menu');\n\nvar _$ = $;\nvar each = _$.each;\nvar extend = _$.extend;\nvar grep = _$.grep;\n\n\nvar stepLimit = 1e6;\n\nvar TracerManager = function TracerManager() {\n this.timer = null;\n this.pause = false;\n this.capsules = [];\n this.interval = 500;\n};\n\nTracerManager.prototype = {\n add: function add(tracer) {\n\n var $container = ModuleContainer.create();\n\n var capsule = {\n module: tracer.module,\n tracer: tracer,\n allocated: true,\n defaultName: null,\n $container: $container,\n isNew: true\n };\n\n this.capsules.push(capsule);\n return capsule;\n },\n allocate: function allocate(newTracer) {\n var selectedCapsule = null;\n var count = 0;\n\n each(this.capsules, function (i, capsule) {\n if (capsule.module === newTracer.module) {\n count++;\n if (!capsule.allocated) {\n capsule.tracer = newTracer;\n capsule.allocated = true;\n capsule.isNew = false;\n selectedCapsule = capsule;\n return false;\n }\n }\n });\n\n if (selectedCapsule === null) {\n count++;\n selectedCapsule = this.add(newTracer);\n }\n\n var className = newTracer.module.getClassName();\n selectedCapsule.defaultName = className + ' ' + count;\n selectedCapsule.order = this.order++;\n return selectedCapsule;\n },\n deallocateAll: function deallocateAll() {\n this.order = 0;\n this.reset();\n each(this.capsules, function (i, capsule) {\n capsule.allocated = false;\n });\n },\n removeUnallocated: function removeUnallocated() {\n var changed = false;\n\n this.capsules = grep(this.capsules, function (capsule) {\n var removed = !capsule.allocated;\n\n if (capsule.isNew || removed) {\n changed = true;\n }\n if (removed) {\n capsule.$container.remove();\n }\n\n return !removed;\n });\n\n if (changed) {\n this.place();\n }\n },\n place: function place() {\n var capsules = this.capsules;\n\n\n each(capsules, function (i, capsule) {\n var width = 100;\n var height = 100 / capsules.length;\n var top = height * capsule.order;\n\n capsule.$container.css({\n top: top + '%',\n width: width + '%',\n height: height + '%'\n });\n\n capsule.tracer.resize();\n });\n },\n resize: function resize() {\n this.command('resize');\n },\n isPause: function isPause() {\n return this.pause;\n },\n setInterval: function setInterval(interval) {\n TopMenu.setInterval(interval);\n },\n reset: function reset() {\n this.traces = [];\n this.traceIndex = -1;\n this.stepCnt = 0;\n if (this.timer) {\n clearTimeout(this.timer);\n }\n this.command('clear');\n },\n pushStep: function pushStep(capsule, step) {\n if (this.stepCnt++ > stepLimit) throw \"Tracer's stack overflow\";\n var len = this.traces.length;\n if (len == 0) len += this.newStep();\n var last = this.traces[len - 1];\n last.push(extend(step, {\n capsule: capsule\n }));\n },\n newStep: function newStep() {\n var line = arguments.length <= 0 || arguments[0] === undefined ? -1 : arguments[0];\n\n var len = this.traces.length;\n if (len > 0 && ~line) {\n this.traces[len - 1].push(line);\n }\n return this.traces.push([]);\n },\n pauseStep: function pauseStep() {\n if (this.traceIndex < 0) return;\n this.pause = true;\n if (this.timer) {\n clearTimeout(this.timer);\n }\n TopMenu.activateBtnPause();\n },\n resumeStep: function resumeStep() {\n this.pause = false;\n this.step(this.traceIndex + 1);\n TopMenu.deactivateBtnPause();\n },\n step: function step(i) {\n var options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1];\n\n var tracer = this;\n\n if (isNaN(i) || i >= this.traces.length || i < 0) return;\n\n this.traceIndex = i;\n var trace = this.traces[i];\n trace.forEach(function (step) {\n if (typeof step === 'number') {\n app.getEditor().highlightLine(step);\n return;\n }\n step.capsule.tracer.processStep(step, options);\n });\n\n if (!options.virtual) {\n this.command('refresh');\n }\n\n if (this.pause) return;\n\n this.timer = setTimeout(function () {\n if (!tracer.nextStep(options)) {\n TopMenu.resetTopMenuButtons();\n }\n }, this.interval);\n },\n prevStep: function prevStep() {\n var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n this.command('clear');\n\n var finalIndex = this.traceIndex - 1;\n if (finalIndex < 0) {\n this.traceIndex = -1;\n this.command('refresh');\n return false;\n }\n\n for (var i = 0; i < finalIndex; i++) {\n this.step(i, extend(options, {\n virtual: true\n }));\n }\n\n this.step(finalIndex);\n return true;\n },\n nextStep: function nextStep() {\n var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n var finalIndex = this.traceIndex + 1;\n if (finalIndex >= this.traces.length) {\n this.traceIndex = this.traces.length - 1;\n return false;\n }\n\n this.step(finalIndex, options);\n return true;\n },\n visualize: function visualize() {\n this.traceIndex = -1;\n this.resumeStep();\n },\n command: function command() {\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var functionName = args.shift();\n each(this.capsules, function (i, capsule) {\n if (capsule.allocated) {\n capsule.tracer.module.prototype[functionName].apply(capsule.tracer, args);\n }\n });\n },\n findOwner: function findOwner(container) {\n var selectedCapsule = null;\n each(this.capsules, function (i, capsule) {\n if (capsule.$container[0] === container) {\n selectedCapsule = capsule;\n return false;\n }\n });\n return selectedCapsule.tracer;\n }\n};\n\nmodule.exports = TracerManager;\n\n},{\"../app\":3,\"../dom/module_container\":8,\"../dom/top_menu\":25}],66:[function(require,module,exports){\n'use strict';\n\nvar parse = JSON.parse;\n\n\nvar fromJSON = function fromJSON(obj) {\n return parse(obj, function (key, value) {\n return value === 'Infinity' ? Infinity : value;\n });\n};\n\nmodule.exports = fromJSON;\n\n},{}],67:[function(require,module,exports){\n'use strict';\n\nvar toJSON = require('./to_json');\nvar fromJSON = require('./from_json');\nvar refineByType = require('./refine_by_type');\n\nmodule.exports = {\n toJSON: toJSON,\n fromJSON: fromJSON,\n refineByType: refineByType\n};\n\n},{\"./from_json\":66,\"./refine_by_type\":68,\"./to_json\":69}],68:[function(require,module,exports){\n'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol ? \"symbol\" : typeof obj; };\n\nvar refineByType = function refineByType(item) {\n switch (typeof item === 'undefined' ? 'undefined' : _typeof(item)) {\n case 'number':\n return refineNumber(item);\n case 'boolean':\n return refineBoolean(item);\n default:\n return refineString(item);\n }\n};\n\nvar refineString = function refineString(str) {\n return str === '' ? ' ' : str;\n};\n\nvar refineNumber = function refineNumber(num) {\n return num === Infinity ? '∞' : num;\n};\n\nvar refineBoolean = function refineBoolean(bool) {\n return bool ? 'T' : 'F';\n};\n\nmodule.exports = refineByType;\n\n},{}],69:[function(require,module,exports){\n'use strict';\n\nvar stringify = JSON.stringify;\n\n\nvar toJSON = function toJSON(obj) {\n return stringify(obj, function (key, value) {\n return value === Infinity ? 'Infinity' : value;\n });\n};\n\nmodule.exports = toJSON;\n\n},{}],70:[function(require,module,exports){\n'use strict';\n\nvar isScratchPaper = function isScratchPaper(category, algorithm) {\n return category == 'scratch';\n};\n\nvar getAlgorithmDir = function getAlgorithmDir(category, algorithm) {\n if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n return './algorithm/' + category + '/' + algorithm + '/';\n};\n\nvar getFileDir = function getFileDir(category, algorithm, file) {\n if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n return './algorithm/' + category + '/' + algorithm + '/' + file + '/';\n};\n\nmodule.exports = {\n isScratchPaper: isScratchPaper,\n getAlgorithmDir: getAlgorithmDir,\n getFileDir: getFileDir\n};\n\n},{}],71:[function(require,module,exports){\n// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = setTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n clearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n setTimeout(drainQueue, 0);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\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\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n\n},{}],72:[function(require,module,exports){\n(function (process,global){\n/*!\n * @overview RSVP - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors\n * @license Licensed under MIT license\n * See https://raw.githubusercontent.com/tildeio/rsvp.js/master/LICENSE\n * @version 3.2.1\n */\n\n(function() {\n \"use strict\";\n function lib$rsvp$utils$$objectOrFunction(x) {\n return typeof x === 'function' || (typeof x === 'object' && x !== null);\n }\n\n function lib$rsvp$utils$$isFunction(x) {\n return typeof x === 'function';\n }\n\n function lib$rsvp$utils$$isMaybeThenable(x) {\n return typeof x === 'object' && x !== null;\n }\n\n var lib$rsvp$utils$$_isArray;\n if (!Array.isArray) {\n lib$rsvp$utils$$_isArray = function (x) {\n return Object.prototype.toString.call(x) === '[object Array]';\n };\n } else {\n lib$rsvp$utils$$_isArray = Array.isArray;\n }\n\n var lib$rsvp$utils$$isArray = lib$rsvp$utils$$_isArray;\n\n var lib$rsvp$utils$$now = Date.now || function() { return new Date().getTime(); };\n\n function lib$rsvp$utils$$F() { }\n\n var lib$rsvp$utils$$o_create = (Object.create || function (o) {\n if (arguments.length > 1) {\n throw new Error('Second argument not supported');\n }\n if (typeof o !== 'object') {\n throw new TypeError('Argument must be an object');\n }\n lib$rsvp$utils$$F.prototype = o;\n return new lib$rsvp$utils$$F();\n });\n function lib$rsvp$events$$indexOf(callbacks, callback) {\n for (var i=0, l=callbacks.length; i<l; i++) {\n if (callbacks[i] === callback) { return i; }\n }\n\n return -1;\n }\n\n function lib$rsvp$events$$callbacksFor(object) {\n var callbacks = object._promiseCallbacks;\n\n if (!callbacks) {\n callbacks = object._promiseCallbacks = {};\n }\n\n return callbacks;\n }\n\n var lib$rsvp$events$$default = {\n\n /**\n `RSVP.EventTarget.mixin` extends an object with EventTarget methods. For\n Example:\n\n ```javascript\n var object = {};\n\n RSVP.EventTarget.mixin(object);\n\n object.on('finished', function(event) {\n // handle event\n });\n\n object.trigger('finished', { detail: value });\n ```\n\n `EventTarget.mixin` also works with prototypes:\n\n ```javascript\n var Person = function() {};\n RSVP.EventTarget.mixin(Person.prototype);\n\n var yehuda = new Person();\n var tom = new Person();\n\n yehuda.on('poke', function(event) {\n console.log('Yehuda says OW');\n });\n\n tom.on('poke', function(event) {\n console.log('Tom says OW');\n });\n\n yehuda.trigger('poke');\n tom.trigger('poke');\n ```\n\n @method mixin\n @for RSVP.EventTarget\n @private\n @param {Object} object object to extend with EventTarget methods\n */\n 'mixin': function(object) {\n object['on'] = this['on'];\n object['off'] = this['off'];\n object['trigger'] = this['trigger'];\n object._promiseCallbacks = undefined;\n return object;\n },\n\n /**\n Registers a callback to be executed when `eventName` is triggered\n\n ```javascript\n object.on('event', function(eventInfo){\n // handle the event\n });\n\n object.trigger('event');\n ```\n\n @method on\n @for RSVP.EventTarget\n @private\n @param {String} eventName name of the event to listen for\n @param {Function} callback function to be called when the event is triggered.\n */\n 'on': function(eventName, callback) {\n if (typeof callback !== 'function') {\n throw new TypeError('Callback must be a function');\n }\n\n var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks;\n\n callbacks = allCallbacks[eventName];\n\n if (!callbacks) {\n callbacks = allCallbacks[eventName] = [];\n }\n\n if (lib$rsvp$events$$indexOf(callbacks, callback) === -1) {\n callbacks.push(callback);\n }\n },\n\n /**\n You can use `off` to stop firing a particular callback for an event:\n\n ```javascript\n function doStuff() { // do stuff! }\n object.on('stuff', doStuff);\n\n object.trigger('stuff'); // doStuff will be called\n\n // Unregister ONLY the doStuff callback\n object.off('stuff', doStuff);\n object.trigger('stuff'); // doStuff will NOT be called\n ```\n\n If you don't pass a `callback` argument to `off`, ALL callbacks for the\n event will not be executed when the event fires. For example:\n\n ```javascript\n var callback1 = function(){};\n var callback2 = function(){};\n\n object.on('stuff', callback1);\n object.on('stuff', callback2);\n\n object.trigger('stuff'); // callback1 and callback2 will be executed.\n\n object.off('stuff');\n object.trigger('stuff'); // callback1 and callback2 will not be executed!\n ```\n\n @method off\n @for RSVP.EventTarget\n @private\n @param {String} eventName event to stop listening to\n @param {Function} callback optional argument. If given, only the function\n given will be removed from the event's callback queue. If no `callback`\n argument is given, all callbacks will be removed from the event's callback\n queue.\n */\n 'off': function(eventName, callback) {\n var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, index;\n\n if (!callback) {\n allCallbacks[eventName] = [];\n return;\n }\n\n callbacks = allCallbacks[eventName];\n\n index = lib$rsvp$events$$indexOf(callbacks, callback);\n\n if (index !== -1) { callbacks.splice(index, 1); }\n },\n\n /**\n Use `trigger` to fire custom events. For example:\n\n ```javascript\n object.on('foo', function(){\n console.log('foo event happened!');\n });\n object.trigger('foo');\n // 'foo event happened!' logged to the console\n ```\n\n You can also pass a value as a second argument to `trigger` that will be\n passed as an argument to all event listeners for the event:\n\n ```javascript\n object.on('foo', function(value){\n console.log(value.name);\n });\n\n object.trigger('foo', { name: 'bar' });\n // 'bar' logged to the console\n ```\n\n @method trigger\n @for RSVP.EventTarget\n @private\n @param {String} eventName name of the event to be triggered\n @param {*} options optional value to be passed to any event handlers for\n the given `eventName`\n */\n 'trigger': function(eventName, options, label) {\n var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, callback;\n\n if (callbacks = allCallbacks[eventName]) {\n // Don't cache the callbacks.length since it may grow\n for (var i=0; i<callbacks.length; i++) {\n callback = callbacks[i];\n\n callback(options, label);\n }\n }\n }\n };\n\n var lib$rsvp$config$$config = {\n instrument: false\n };\n\n lib$rsvp$events$$default['mixin'](lib$rsvp$config$$config);\n\n function lib$rsvp$config$$configure(name, value) {\n if (name === 'onerror') {\n // handle for legacy users that expect the actual\n // error to be passed to their function added via\n // `RSVP.configure('onerror', someFunctionHere);`\n lib$rsvp$config$$config['on']('error', value);\n return;\n }\n\n if (arguments.length === 2) {\n lib$rsvp$config$$config[name] = value;\n } else {\n return lib$rsvp$config$$config[name];\n }\n }\n\n var lib$rsvp$instrument$$queue = [];\n\n function lib$rsvp$instrument$$scheduleFlush() {\n setTimeout(function() {\n var entry;\n for (var i = 0; i < lib$rsvp$instrument$$queue.length; i++) {\n entry = lib$rsvp$instrument$$queue[i];\n\n var payload = entry.payload;\n\n payload.guid = payload.key + payload.id;\n payload.childGuid = payload.key + payload.childId;\n if (payload.error) {\n payload.stack = payload.error.stack;\n }\n\n lib$rsvp$config$$config['trigger'](entry.name, entry.payload);\n }\n lib$rsvp$instrument$$queue.length = 0;\n }, 50);\n }\n\n function lib$rsvp$instrument$$instrument(eventName, promise, child) {\n if (1 === lib$rsvp$instrument$$queue.push({\n name: eventName,\n payload: {\n key: promise._guidKey,\n id: promise._id,\n eventName: eventName,\n detail: promise._result,\n childId: child && child._id,\n label: promise._label,\n timeStamp: lib$rsvp$utils$$now(),\n error: lib$rsvp$config$$config[\"instrument-with-stack\"] ? new Error(promise._label) : null\n }})) {\n lib$rsvp$instrument$$scheduleFlush();\n }\n }\n var lib$rsvp$instrument$$default = lib$rsvp$instrument$$instrument;\n function lib$rsvp$then$$then(onFulfillment, onRejection, label) {\n var parent = this;\n var state = parent._state;\n\n if (state === lib$rsvp$$internal$$FULFILLED && !onFulfillment || state === lib$rsvp$$internal$$REJECTED && !onRejection) {\n lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, parent);\n return parent;\n }\n\n parent._onError = null;\n\n var child = new parent.constructor(lib$rsvp$$internal$$noop, label);\n var result = parent._result;\n\n lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, child);\n\n if (state) {\n var callback = arguments[state - 1];\n lib$rsvp$config$$config.async(function(){\n lib$rsvp$$internal$$invokeCallback(state, child, callback, result);\n });\n } else {\n lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection);\n }\n\n return child;\n }\n var lib$rsvp$then$$default = lib$rsvp$then$$then;\n function lib$rsvp$promise$resolve$$resolve(object, label) {\n /*jshint validthis:true */\n var Constructor = this;\n\n if (object && typeof object === 'object' && object.constructor === Constructor) {\n return object;\n }\n\n var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n lib$rsvp$$internal$$resolve(promise, object);\n return promise;\n }\n var lib$rsvp$promise$resolve$$default = lib$rsvp$promise$resolve$$resolve;\n function lib$rsvp$enumerator$$makeSettledResult(state, position, value) {\n if (state === lib$rsvp$$internal$$FULFILLED) {\n return {\n state: 'fulfilled',\n value: value\n };\n } else {\n return {\n state: 'rejected',\n reason: value\n };\n }\n }\n\n function lib$rsvp$enumerator$$Enumerator(Constructor, input, abortOnReject, label) {\n this._instanceConstructor = Constructor;\n this.promise = new Constructor(lib$rsvp$$internal$$noop, label);\n this._abortOnReject = abortOnReject;\n\n if (this._validateInput(input)) {\n this._input = input;\n this.length = input.length;\n this._remaining = input.length;\n\n this._init();\n\n if (this.length === 0) {\n lib$rsvp$$internal$$fulfill(this.promise, this._result);\n } else {\n this.length = this.length || 0;\n this._enumerate();\n if (this._remaining === 0) {\n lib$rsvp$$internal$$fulfill(this.promise, this._result);\n }\n }\n } else {\n lib$rsvp$$internal$$reject(this.promise, this._validationError());\n }\n }\n\n var lib$rsvp$enumerator$$default = lib$rsvp$enumerator$$Enumerator;\n\n lib$rsvp$enumerator$$Enumerator.prototype._validateInput = function(input) {\n return lib$rsvp$utils$$isArray(input);\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._validationError = function() {\n return new Error('Array Methods must be provided an Array');\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._init = function() {\n this._result = new Array(this.length);\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._enumerate = function() {\n var length = this.length;\n var promise = this.promise;\n var input = this._input;\n\n for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n this._eachEntry(input[i], i);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._settleMaybeThenable = function(entry, i) {\n var c = this._instanceConstructor;\n var resolve = c.resolve;\n\n if (resolve === lib$rsvp$promise$resolve$$default) {\n var then = lib$rsvp$$internal$$getThen(entry);\n\n if (then === lib$rsvp$then$$default &&\n entry._state !== lib$rsvp$$internal$$PENDING) {\n entry._onError = null;\n this._settledAt(entry._state, i, entry._result);\n } else if (typeof then !== 'function') {\n this._remaining--;\n this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n } else if (c === lib$rsvp$promise$$default) {\n var promise = new c(lib$rsvp$$internal$$noop);\n lib$rsvp$$internal$$handleMaybeThenable(promise, entry, then);\n this._willSettleAt(promise, i);\n } else {\n this._willSettleAt(new c(function(resolve) { resolve(entry); }), i);\n }\n } else {\n this._willSettleAt(resolve(entry), i);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._eachEntry = function(entry, i) {\n if (lib$rsvp$utils$$isMaybeThenable(entry)) {\n this._settleMaybeThenable(entry, i);\n } else {\n this._remaining--;\n this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._settledAt = function(state, i, value) {\n var promise = this.promise;\n\n if (promise._state === lib$rsvp$$internal$$PENDING) {\n this._remaining--;\n\n if (this._abortOnReject && state === lib$rsvp$$internal$$REJECTED) {\n lib$rsvp$$internal$$reject(promise, value);\n } else {\n this._result[i] = this._makeResult(state, i, value);\n }\n }\n\n if (this._remaining === 0) {\n lib$rsvp$$internal$$fulfill(promise, this._result);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._makeResult = function(state, i, value) {\n return value;\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._willSettleAt = function(promise, i) {\n var enumerator = this;\n\n lib$rsvp$$internal$$subscribe(promise, undefined, function(value) {\n enumerator._settledAt(lib$rsvp$$internal$$FULFILLED, i, value);\n }, function(reason) {\n enumerator._settledAt(lib$rsvp$$internal$$REJECTED, i, reason);\n });\n };\n function lib$rsvp$promise$all$$all(entries, label) {\n return new lib$rsvp$enumerator$$default(this, entries, true /* abort on reject */, label).promise;\n }\n var lib$rsvp$promise$all$$default = lib$rsvp$promise$all$$all;\n function lib$rsvp$promise$race$$race(entries, label) {\n /*jshint validthis:true */\n var Constructor = this;\n\n var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n\n if (!lib$rsvp$utils$$isArray(entries)) {\n lib$rsvp$$internal$$reject(promise, new TypeError('You must pass an array to race.'));\n return promise;\n }\n\n var length = entries.length;\n\n function onFulfillment(value) {\n lib$rsvp$$internal$$resolve(promise, value);\n }\n\n function onRejection(reason) {\n lib$rsvp$$internal$$reject(promise, reason);\n }\n\n for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n lib$rsvp$$internal$$subscribe(Constructor.resolve(entries[i]), undefined, onFulfillment, onRejection);\n }\n\n return promise;\n }\n var lib$rsvp$promise$race$$default = lib$rsvp$promise$race$$race;\n function lib$rsvp$promise$reject$$reject(reason, label) {\n /*jshint validthis:true */\n var Constructor = this;\n var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n lib$rsvp$$internal$$reject(promise, reason);\n return promise;\n }\n var lib$rsvp$promise$reject$$default = lib$rsvp$promise$reject$$reject;\n\n var lib$rsvp$promise$$guidKey = 'rsvp_' + lib$rsvp$utils$$now() + '-';\n var lib$rsvp$promise$$counter = 0;\n\n function lib$rsvp$promise$$needsResolver() {\n throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n }\n\n function lib$rsvp$promise$$needsNew() {\n throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n }\n\n function lib$rsvp$promise$$Promise(resolver, label) {\n this._id = lib$rsvp$promise$$counter++;\n this._label = label;\n this._state = undefined;\n this._result = undefined;\n this._subscribers = [];\n\n lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('created', this);\n\n if (lib$rsvp$$internal$$noop !== resolver) {\n typeof resolver !== 'function' && lib$rsvp$promise$$needsResolver();\n this instanceof lib$rsvp$promise$$Promise ? lib$rsvp$$internal$$initializePromise(this, resolver) : lib$rsvp$promise$$needsNew();\n }\n }\n\n var lib$rsvp$promise$$default = lib$rsvp$promise$$Promise;\n\n // deprecated\n lib$rsvp$promise$$Promise.cast = lib$rsvp$promise$resolve$$default;\n lib$rsvp$promise$$Promise.all = lib$rsvp$promise$all$$default;\n lib$rsvp$promise$$Promise.race = lib$rsvp$promise$race$$default;\n lib$rsvp$promise$$Promise.resolve = lib$rsvp$promise$resolve$$default;\n lib$rsvp$promise$$Promise.reject = lib$rsvp$promise$reject$$default;\n\n lib$rsvp$promise$$Promise.prototype = {\n constructor: lib$rsvp$promise$$Promise,\n\n _guidKey: lib$rsvp$promise$$guidKey,\n\n _onError: function (reason) {\n var promise = this;\n lib$rsvp$config$$config.after(function() {\n if (promise._onError) {\n lib$rsvp$config$$config['trigger']('error', reason, promise._label);\n }\n });\n },\n\n /**\n The primary way of interacting with a promise is through its `then` method,\n which registers callbacks to receive either a promise's eventual value or the\n reason why the promise cannot be fulfilled.\n\n ```js\n findUser().then(function(user){\n // user is available\n }, function(reason){\n // user is unavailable, and you are given the reason why\n });\n ```\n\n Chaining\n --------\n\n The return value of `then` is itself a promise. This second, 'downstream'\n promise is resolved with the return value of the first promise's fulfillment\n or rejection handler, or rejected if the handler throws an exception.\n\n ```js\n findUser().then(function (user) {\n return user.name;\n }, function (reason) {\n return 'default name';\n }).then(function (userName) {\n // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n // will be `'default name'`\n });\n\n findUser().then(function (user) {\n throw new Error('Found user, but still unhappy');\n }, function (reason) {\n throw new Error('`findUser` rejected and we're unhappy');\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n });\n ```\n If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n\n ```js\n findUser().then(function (user) {\n throw new PedagogicalException('Upstream error');\n }).then(function (value) {\n // never reached\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // The `PedgagocialException` is propagated all the way down to here\n });\n ```\n\n Assimilation\n ------------\n\n Sometimes the value you want to propagate to a downstream promise can only be\n retrieved asynchronously. This can be achieved by returning a promise in the\n fulfillment or rejection handler. The downstream promise will then be pending\n until the returned promise is settled. This is called *assimilation*.\n\n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // The user's comments are now available\n });\n ```\n\n If the assimliated promise rejects, then the downstream promise will also reject.\n\n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // If `findCommentsByAuthor` fulfills, we'll have the value here\n }, function (reason) {\n // If `findCommentsByAuthor` rejects, we'll have the reason here\n });\n ```\n\n Simple Example\n --------------\n\n Synchronous Example\n\n ```javascript\n var result;\n\n try {\n result = findResult();\n // success\n } catch(reason) {\n // failure\n }\n ```\n\n Errback Example\n\n ```js\n findResult(function(result, err){\n if (err) {\n // failure\n } else {\n // success\n }\n });\n ```\n\n Promise Example;\n\n ```javascript\n findResult().then(function(result){\n // success\n }, function(reason){\n // failure\n });\n ```\n\n Advanced Example\n --------------\n\n Synchronous Example\n\n ```javascript\n var author, books;\n\n try {\n author = findAuthor();\n books = findBooksByAuthor(author);\n // success\n } catch(reason) {\n // failure\n }\n ```\n\n Errback Example\n\n ```js\n\n function foundBooks(books) {\n\n }\n\n function failure(reason) {\n\n }\n\n findAuthor(function(author, err){\n if (err) {\n failure(err);\n // failure\n } else {\n try {\n findBoooksByAuthor(author, function(books, err) {\n if (err) {\n failure(err);\n } else {\n try {\n foundBooks(books);\n } catch(reason) {\n failure(reason);\n }\n }\n });\n } catch(error) {\n failure(err);\n }\n // success\n }\n });\n ```\n\n Promise Example;\n\n ```javascript\n findAuthor().\n then(findBooksByAuthor).\n then(function(books){\n // found books\n }).catch(function(reason){\n // something went wrong\n });\n ```\n\n @method then\n @param {Function} onFulfillment\n @param {Function} onRejection\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise}\n */\n then: lib$rsvp$then$$default,\n\n /**\n `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n as the catch block of a try/catch statement.\n\n ```js\n function findAuthor(){\n throw new Error('couldn't find that author');\n }\n\n // synchronous\n try {\n findAuthor();\n } catch(reason) {\n // something went wrong\n }\n\n // async with promises\n findAuthor().catch(function(reason){\n // something went wrong\n });\n ```\n\n @method catch\n @param {Function} onRejection\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise}\n */\n 'catch': function(onRejection, label) {\n return this.then(undefined, onRejection, label);\n },\n\n /**\n `finally` will be invoked regardless of the promise's fate just as native\n try/catch/finally behaves\n\n Synchronous example:\n\n ```js\n findAuthor() {\n if (Math.random() > 0.5) {\n throw new Error();\n }\n return new Author();\n }\n\n try {\n return findAuthor(); // succeed or fail\n } catch(error) {\n return findOtherAuther();\n } finally {\n // always runs\n // doesn't affect the return value\n }\n ```\n\n Asynchronous example:\n\n ```js\n findAuthor().catch(function(reason){\n return findOtherAuther();\n }).finally(function(){\n // author was either found, or not\n });\n ```\n\n @method finally\n @param {Function} callback\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise}\n */\n 'finally': function(callback, label) {\n var promise = this;\n var constructor = promise.constructor;\n\n return promise.then(function(value) {\n return constructor.resolve(callback()).then(function() {\n return value;\n });\n }, function(reason) {\n return constructor.resolve(callback()).then(function() {\n return constructor.reject(reason);\n });\n }, label);\n }\n };\n function lib$rsvp$$internal$$withOwnPromise() {\n return new TypeError('A promises callback cannot return that same promise.');\n }\n\n function lib$rsvp$$internal$$noop() {}\n\n var lib$rsvp$$internal$$PENDING = void 0;\n var lib$rsvp$$internal$$FULFILLED = 1;\n var lib$rsvp$$internal$$REJECTED = 2;\n\n var lib$rsvp$$internal$$GET_THEN_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n function lib$rsvp$$internal$$getThen(promise) {\n try {\n return promise.then;\n } catch(error) {\n lib$rsvp$$internal$$GET_THEN_ERROR.error = error;\n return lib$rsvp$$internal$$GET_THEN_ERROR;\n }\n }\n\n function lib$rsvp$$internal$$tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n try {\n then.call(value, fulfillmentHandler, rejectionHandler);\n } catch(e) {\n return e;\n }\n }\n\n function lib$rsvp$$internal$$handleForeignThenable(promise, thenable, then) {\n lib$rsvp$config$$config.async(function(promise) {\n var sealed = false;\n var error = lib$rsvp$$internal$$tryThen(then, thenable, function(value) {\n if (sealed) { return; }\n sealed = true;\n if (thenable !== value) {\n lib$rsvp$$internal$$resolve(promise, value, undefined);\n } else {\n lib$rsvp$$internal$$fulfill(promise, value);\n }\n }, function(reason) {\n if (sealed) { return; }\n sealed = true;\n\n lib$rsvp$$internal$$reject(promise, reason);\n }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n if (!sealed && error) {\n sealed = true;\n lib$rsvp$$internal$$reject(promise, error);\n }\n }, promise);\n }\n\n function lib$rsvp$$internal$$handleOwnThenable(promise, thenable) {\n if (thenable._state === lib$rsvp$$internal$$FULFILLED) {\n lib$rsvp$$internal$$fulfill(promise, thenable._result);\n } else if (thenable._state === lib$rsvp$$internal$$REJECTED) {\n thenable._onError = null;\n lib$rsvp$$internal$$reject(promise, thenable._result);\n } else {\n lib$rsvp$$internal$$subscribe(thenable, undefined, function(value) {\n if (thenable !== value) {\n lib$rsvp$$internal$$resolve(promise, value, undefined);\n } else {\n lib$rsvp$$internal$$fulfill(promise, value);\n }\n }, function(reason) {\n lib$rsvp$$internal$$reject(promise, reason);\n });\n }\n }\n\n function lib$rsvp$$internal$$handleMaybeThenable(promise, maybeThenable, then) {\n if (maybeThenable.constructor === promise.constructor &&\n then === lib$rsvp$then$$default &&\n constructor.resolve === lib$rsvp$promise$resolve$$default) {\n lib$rsvp$$internal$$handleOwnThenable(promise, maybeThenable);\n } else {\n if (then === lib$rsvp$$internal$$GET_THEN_ERROR) {\n lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$GET_THEN_ERROR.error);\n } else if (then === undefined) {\n lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n } else if (lib$rsvp$utils$$isFunction(then)) {\n lib$rsvp$$internal$$handleForeignThenable(promise, maybeThenable, then);\n } else {\n lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n }\n }\n }\n\n function lib$rsvp$$internal$$resolve(promise, value) {\n if (promise === value) {\n lib$rsvp$$internal$$fulfill(promise, value);\n } else if (lib$rsvp$utils$$objectOrFunction(value)) {\n lib$rsvp$$internal$$handleMaybeThenable(promise, value, lib$rsvp$$internal$$getThen(value));\n } else {\n lib$rsvp$$internal$$fulfill(promise, value);\n }\n }\n\n function lib$rsvp$$internal$$publishRejection(promise) {\n if (promise._onError) {\n promise._onError(promise._result);\n }\n\n lib$rsvp$$internal$$publish(promise);\n }\n\n function lib$rsvp$$internal$$fulfill(promise, value) {\n if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n\n promise._result = value;\n promise._state = lib$rsvp$$internal$$FULFILLED;\n\n if (promise._subscribers.length === 0) {\n if (lib$rsvp$config$$config.instrument) {\n lib$rsvp$instrument$$default('fulfilled', promise);\n }\n } else {\n lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, promise);\n }\n }\n\n function lib$rsvp$$internal$$reject(promise, reason) {\n if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n promise._state = lib$rsvp$$internal$$REJECTED;\n promise._result = reason;\n lib$rsvp$config$$config.async(lib$rsvp$$internal$$publishRejection, promise);\n }\n\n function lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection) {\n var subscribers = parent._subscribers;\n var length = subscribers.length;\n\n parent._onError = null;\n\n subscribers[length] = child;\n subscribers[length + lib$rsvp$$internal$$FULFILLED] = onFulfillment;\n subscribers[length + lib$rsvp$$internal$$REJECTED] = onRejection;\n\n if (length === 0 && parent._state) {\n lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, parent);\n }\n }\n\n function lib$rsvp$$internal$$publish(promise) {\n var subscribers = promise._subscribers;\n var settled = promise._state;\n\n if (lib$rsvp$config$$config.instrument) {\n lib$rsvp$instrument$$default(settled === lib$rsvp$$internal$$FULFILLED ? 'fulfilled' : 'rejected', promise);\n }\n\n if (subscribers.length === 0) { return; }\n\n var child, callback, detail = promise._result;\n\n for (var i = 0; i < subscribers.length; i += 3) {\n child = subscribers[i];\n callback = subscribers[i + settled];\n\n if (child) {\n lib$rsvp$$internal$$invokeCallback(settled, child, callback, detail);\n } else {\n callback(detail);\n }\n }\n\n promise._subscribers.length = 0;\n }\n\n function lib$rsvp$$internal$$ErrorObject() {\n this.error = null;\n }\n\n var lib$rsvp$$internal$$TRY_CATCH_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n function lib$rsvp$$internal$$tryCatch(callback, detail) {\n try {\n return callback(detail);\n } catch(e) {\n lib$rsvp$$internal$$TRY_CATCH_ERROR.error = e;\n return lib$rsvp$$internal$$TRY_CATCH_ERROR;\n }\n }\n\n function lib$rsvp$$internal$$invokeCallback(settled, promise, callback, detail) {\n var hasCallback = lib$rsvp$utils$$isFunction(callback),\n value, error, succeeded, failed;\n\n if (hasCallback) {\n value = lib$rsvp$$internal$$tryCatch(callback, detail);\n\n if (value === lib$rsvp$$internal$$TRY_CATCH_ERROR) {\n failed = true;\n error = value.error;\n value = null;\n } else {\n succeeded = true;\n }\n\n if (promise === value) {\n lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$withOwnPromise());\n return;\n }\n\n } else {\n value = detail;\n succeeded = true;\n }\n\n if (promise._state !== lib$rsvp$$internal$$PENDING) {\n // noop\n } else if (hasCallback && succeeded) {\n lib$rsvp$$internal$$resolve(promise, value);\n } else if (failed) {\n lib$rsvp$$internal$$reject(promise, error);\n } else if (settled === lib$rsvp$$internal$$FULFILLED) {\n lib$rsvp$$internal$$fulfill(promise, value);\n } else if (settled === lib$rsvp$$internal$$REJECTED) {\n lib$rsvp$$internal$$reject(promise, value);\n }\n }\n\n function lib$rsvp$$internal$$initializePromise(promise, resolver) {\n var resolved = false;\n try {\n resolver(function resolvePromise(value){\n if (resolved) { return; }\n resolved = true;\n lib$rsvp$$internal$$resolve(promise, value);\n }, function rejectPromise(reason) {\n if (resolved) { return; }\n resolved = true;\n lib$rsvp$$internal$$reject(promise, reason);\n });\n } catch(e) {\n lib$rsvp$$internal$$reject(promise, e);\n }\n }\n\n function lib$rsvp$all$settled$$AllSettled(Constructor, entries, label) {\n this._superConstructor(Constructor, entries, false /* don't abort on reject */, label);\n }\n\n lib$rsvp$all$settled$$AllSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n lib$rsvp$all$settled$$AllSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n lib$rsvp$all$settled$$AllSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n lib$rsvp$all$settled$$AllSettled.prototype._validationError = function() {\n return new Error('allSettled must be called with an array');\n };\n\n function lib$rsvp$all$settled$$allSettled(entries, label) {\n return new lib$rsvp$all$settled$$AllSettled(lib$rsvp$promise$$default, entries, label).promise;\n }\n var lib$rsvp$all$settled$$default = lib$rsvp$all$settled$$allSettled;\n function lib$rsvp$all$$all(array, label) {\n return lib$rsvp$promise$$default.all(array, label);\n }\n var lib$rsvp$all$$default = lib$rsvp$all$$all;\n var lib$rsvp$asap$$len = 0;\n var lib$rsvp$asap$$toString = {}.toString;\n var lib$rsvp$asap$$vertxNext;\n function lib$rsvp$asap$$asap(callback, arg) {\n lib$rsvp$asap$$queue[lib$rsvp$asap$$len] = callback;\n lib$rsvp$asap$$queue[lib$rsvp$asap$$len + 1] = arg;\n lib$rsvp$asap$$len += 2;\n if (lib$rsvp$asap$$len === 2) {\n // If len is 1, that means that we need to schedule an async flush.\n // If additional callbacks are queued before the queue is flushed, they\n // will be processed by this flush that we are scheduling.\n lib$rsvp$asap$$scheduleFlush();\n }\n }\n\n var lib$rsvp$asap$$default = lib$rsvp$asap$$asap;\n\n var lib$rsvp$asap$$browserWindow = (typeof window !== 'undefined') ? window : undefined;\n var lib$rsvp$asap$$browserGlobal = lib$rsvp$asap$$browserWindow || {};\n var lib$rsvp$asap$$BrowserMutationObserver = lib$rsvp$asap$$browserGlobal.MutationObserver || lib$rsvp$asap$$browserGlobal.WebKitMutationObserver;\n var lib$rsvp$asap$$isNode = typeof self === 'undefined' &&\n typeof process !== 'undefined' && {}.toString.call(process) === '[object process]';\n\n // test for web worker but not in IE10\n var lib$rsvp$asap$$isWorker = typeof Uint8ClampedArray !== 'undefined' &&\n typeof importScripts !== 'undefined' &&\n typeof MessageChannel !== 'undefined';\n\n // node\n function lib$rsvp$asap$$useNextTick() {\n var nextTick = process.nextTick;\n // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n // setImmediate should be used instead instead\n var version = process.versions.node.match(/^(?:(\\d+)\\.)?(?:(\\d+)\\.)?(\\*|\\d+)$/);\n if (Array.isArray(version) && version[1] === '0' && version[2] === '10') {\n nextTick = setImmediate;\n }\n return function() {\n nextTick(lib$rsvp$asap$$flush);\n };\n }\n\n // vertx\n function lib$rsvp$asap$$useVertxTimer() {\n return function() {\n lib$rsvp$asap$$vertxNext(lib$rsvp$asap$$flush);\n };\n }\n\n function lib$rsvp$asap$$useMutationObserver() {\n var iterations = 0;\n var observer = new lib$rsvp$asap$$BrowserMutationObserver(lib$rsvp$asap$$flush);\n var node = document.createTextNode('');\n observer.observe(node, { characterData: true });\n\n return function() {\n node.data = (iterations = ++iterations % 2);\n };\n }\n\n // web worker\n function lib$rsvp$asap$$useMessageChannel() {\n var channel = new MessageChannel();\n channel.port1.onmessage = lib$rsvp$asap$$flush;\n return function () {\n channel.port2.postMessage(0);\n };\n }\n\n function lib$rsvp$asap$$useSetTimeout() {\n return function() {\n setTimeout(lib$rsvp$asap$$flush, 1);\n };\n }\n\n var lib$rsvp$asap$$queue = new Array(1000);\n function lib$rsvp$asap$$flush() {\n for (var i = 0; i < lib$rsvp$asap$$len; i+=2) {\n var callback = lib$rsvp$asap$$queue[i];\n var arg = lib$rsvp$asap$$queue[i+1];\n\n callback(arg);\n\n lib$rsvp$asap$$queue[i] = undefined;\n lib$rsvp$asap$$queue[i+1] = undefined;\n }\n\n lib$rsvp$asap$$len = 0;\n }\n\n function lib$rsvp$asap$$attemptVertex() {\n try {\n var r = require;\n var vertx = r('vertx');\n lib$rsvp$asap$$vertxNext = vertx.runOnLoop || vertx.runOnContext;\n return lib$rsvp$asap$$useVertxTimer();\n } catch(e) {\n return lib$rsvp$asap$$useSetTimeout();\n }\n }\n\n var lib$rsvp$asap$$scheduleFlush;\n // Decide what async method to use to triggering processing of queued callbacks:\n if (lib$rsvp$asap$$isNode) {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useNextTick();\n } else if (lib$rsvp$asap$$BrowserMutationObserver) {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMutationObserver();\n } else if (lib$rsvp$asap$$isWorker) {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMessageChannel();\n } else if (lib$rsvp$asap$$browserWindow === undefined && typeof require === 'function') {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$attemptVertex();\n } else {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useSetTimeout();\n }\n function lib$rsvp$defer$$defer(label) {\n var deferred = {};\n\n deferred['promise'] = new lib$rsvp$promise$$default(function(resolve, reject) {\n deferred['resolve'] = resolve;\n deferred['reject'] = reject;\n }, label);\n\n return deferred;\n }\n var lib$rsvp$defer$$default = lib$rsvp$defer$$defer;\n function lib$rsvp$filter$$filter(promises, filterFn, label) {\n return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n if (!lib$rsvp$utils$$isFunction(filterFn)) {\n throw new TypeError(\"You must pass a function as filter's second argument.\");\n }\n\n var length = values.length;\n var filtered = new Array(length);\n\n for (var i = 0; i < length; i++) {\n filtered[i] = filterFn(values[i]);\n }\n\n return lib$rsvp$promise$$default.all(filtered, label).then(function(filtered) {\n var results = new Array(length);\n var newLength = 0;\n\n for (var i = 0; i < length; i++) {\n if (filtered[i]) {\n results[newLength] = values[i];\n newLength++;\n }\n }\n\n results.length = newLength;\n\n return results;\n });\n });\n }\n var lib$rsvp$filter$$default = lib$rsvp$filter$$filter;\n\n function lib$rsvp$promise$hash$$PromiseHash(Constructor, object, label) {\n this._superConstructor(Constructor, object, true, label);\n }\n\n var lib$rsvp$promise$hash$$default = lib$rsvp$promise$hash$$PromiseHash;\n\n lib$rsvp$promise$hash$$PromiseHash.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n lib$rsvp$promise$hash$$PromiseHash.prototype._superConstructor = lib$rsvp$enumerator$$default;\n lib$rsvp$promise$hash$$PromiseHash.prototype._init = function() {\n this._result = {};\n };\n\n lib$rsvp$promise$hash$$PromiseHash.prototype._validateInput = function(input) {\n return input && typeof input === 'object';\n };\n\n lib$rsvp$promise$hash$$PromiseHash.prototype._validationError = function() {\n return new Error('Promise.hash must be called with an object');\n };\n\n lib$rsvp$promise$hash$$PromiseHash.prototype._enumerate = function() {\n var enumerator = this;\n var promise = enumerator.promise;\n var input = enumerator._input;\n var results = [];\n\n for (var key in input) {\n if (promise._state === lib$rsvp$$internal$$PENDING && Object.prototype.hasOwnProperty.call(input, key)) {\n results.push({\n position: key,\n entry: input[key]\n });\n }\n }\n\n var length = results.length;\n enumerator._remaining = length;\n var result;\n\n for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n result = results[i];\n enumerator._eachEntry(result.entry, result.position);\n }\n };\n\n function lib$rsvp$hash$settled$$HashSettled(Constructor, object, label) {\n this._superConstructor(Constructor, object, false, label);\n }\n\n lib$rsvp$hash$settled$$HashSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$promise$hash$$default.prototype);\n lib$rsvp$hash$settled$$HashSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n lib$rsvp$hash$settled$$HashSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n\n lib$rsvp$hash$settled$$HashSettled.prototype._validationError = function() {\n return new Error('hashSettled must be called with an object');\n };\n\n function lib$rsvp$hash$settled$$hashSettled(object, label) {\n return new lib$rsvp$hash$settled$$HashSettled(lib$rsvp$promise$$default, object, label).promise;\n }\n var lib$rsvp$hash$settled$$default = lib$rsvp$hash$settled$$hashSettled;\n function lib$rsvp$hash$$hash(object, label) {\n return new lib$rsvp$promise$hash$$default(lib$rsvp$promise$$default, object, label).promise;\n }\n var lib$rsvp$hash$$default = lib$rsvp$hash$$hash;\n function lib$rsvp$map$$map(promises, mapFn, label) {\n return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n if (!lib$rsvp$utils$$isFunction(mapFn)) {\n throw new TypeError(\"You must pass a function as map's second argument.\");\n }\n\n var length = values.length;\n var results = new Array(length);\n\n for (var i = 0; i < length; i++) {\n results[i] = mapFn(values[i]);\n }\n\n return lib$rsvp$promise$$default.all(results, label);\n });\n }\n var lib$rsvp$map$$default = lib$rsvp$map$$map;\n\n function lib$rsvp$node$$Result() {\n this.value = undefined;\n }\n\n var lib$rsvp$node$$ERROR = new lib$rsvp$node$$Result();\n var lib$rsvp$node$$GET_THEN_ERROR = new lib$rsvp$node$$Result();\n\n function lib$rsvp$node$$getThen(obj) {\n try {\n return obj.then;\n } catch(error) {\n lib$rsvp$node$$ERROR.value= error;\n return lib$rsvp$node$$ERROR;\n }\n }\n\n\n function lib$rsvp$node$$tryApply(f, s, a) {\n try {\n f.apply(s, a);\n } catch(error) {\n lib$rsvp$node$$ERROR.value = error;\n return lib$rsvp$node$$ERROR;\n }\n }\n\n function lib$rsvp$node$$makeObject(_, argumentNames) {\n var obj = {};\n var name;\n var i;\n var length = _.length;\n var args = new Array(length);\n\n for (var x = 0; x < length; x++) {\n args[x] = _[x];\n }\n\n for (i = 0; i < argumentNames.length; i++) {\n name = argumentNames[i];\n obj[name] = args[i + 1];\n }\n\n return obj;\n }\n\n function lib$rsvp$node$$arrayResult(_) {\n var length = _.length;\n var args = new Array(length - 1);\n\n for (var i = 1; i < length; i++) {\n args[i - 1] = _[i];\n }\n\n return args;\n }\n\n function lib$rsvp$node$$wrapThenable(then, promise) {\n return {\n then: function(onFulFillment, onRejection) {\n return then.call(promise, onFulFillment, onRejection);\n }\n };\n }\n\n function lib$rsvp$node$$denodeify(nodeFunc, options) {\n var fn = function() {\n var self = this;\n var l = arguments.length;\n var args = new Array(l + 1);\n var arg;\n var promiseInput = false;\n\n for (var i = 0; i < l; ++i) {\n arg = arguments[i];\n\n if (!promiseInput) {\n // TODO: clean this up\n promiseInput = lib$rsvp$node$$needsPromiseInput(arg);\n if (promiseInput === lib$rsvp$node$$GET_THEN_ERROR) {\n var p = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n lib$rsvp$$internal$$reject(p, lib$rsvp$node$$GET_THEN_ERROR.value);\n return p;\n } else if (promiseInput && promiseInput !== true) {\n arg = lib$rsvp$node$$wrapThenable(promiseInput, arg);\n }\n }\n args[i] = arg;\n }\n\n var promise = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n\n args[l] = function(err, val) {\n if (err)\n lib$rsvp$$internal$$reject(promise, err);\n else if (options === undefined)\n lib$rsvp$$internal$$resolve(promise, val);\n else if (options === true)\n lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$arrayResult(arguments));\n else if (lib$rsvp$utils$$isArray(options))\n lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$makeObject(arguments, options));\n else\n lib$rsvp$$internal$$resolve(promise, val);\n };\n\n if (promiseInput) {\n return lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self);\n } else {\n return lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self);\n }\n };\n\n fn.__proto__ = nodeFunc;\n\n return fn;\n }\n\n var lib$rsvp$node$$default = lib$rsvp$node$$denodeify;\n\n function lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self) {\n var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n if (result === lib$rsvp$node$$ERROR) {\n lib$rsvp$$internal$$reject(promise, result.value);\n }\n return promise;\n }\n\n function lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self){\n return lib$rsvp$promise$$default.all(args).then(function(args){\n var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n if (result === lib$rsvp$node$$ERROR) {\n lib$rsvp$$internal$$reject(promise, result.value);\n }\n return promise;\n });\n }\n\n function lib$rsvp$node$$needsPromiseInput(arg) {\n if (arg && typeof arg === 'object') {\n if (arg.constructor === lib$rsvp$promise$$default) {\n return true;\n } else {\n return lib$rsvp$node$$getThen(arg);\n }\n } else {\n return false;\n }\n }\n var lib$rsvp$platform$$platform;\n\n /* global self */\n if (typeof self === 'object') {\n lib$rsvp$platform$$platform = self;\n\n /* global global */\n } else if (typeof global === 'object') {\n lib$rsvp$platform$$platform = global;\n } else {\n throw new Error('no global: `self` or `global` found');\n }\n\n var lib$rsvp$platform$$default = lib$rsvp$platform$$platform;\n function lib$rsvp$race$$race(array, label) {\n return lib$rsvp$promise$$default.race(array, label);\n }\n var lib$rsvp$race$$default = lib$rsvp$race$$race;\n function lib$rsvp$reject$$reject(reason, label) {\n return lib$rsvp$promise$$default.reject(reason, label);\n }\n var lib$rsvp$reject$$default = lib$rsvp$reject$$reject;\n function lib$rsvp$resolve$$resolve(value, label) {\n return lib$rsvp$promise$$default.resolve(value, label);\n }\n var lib$rsvp$resolve$$default = lib$rsvp$resolve$$resolve;\n function lib$rsvp$rethrow$$rethrow(reason) {\n setTimeout(function() {\n throw reason;\n });\n throw reason;\n }\n var lib$rsvp$rethrow$$default = lib$rsvp$rethrow$$rethrow;\n\n // defaults\n lib$rsvp$config$$config.async = lib$rsvp$asap$$default;\n lib$rsvp$config$$config.after = function(cb) {\n setTimeout(cb, 0);\n };\n var lib$rsvp$$cast = lib$rsvp$resolve$$default;\n function lib$rsvp$$async(callback, arg) {\n lib$rsvp$config$$config.async(callback, arg);\n }\n\n function lib$rsvp$$on() {\n lib$rsvp$config$$config['on'].apply(lib$rsvp$config$$config, arguments);\n }\n\n function lib$rsvp$$off() {\n lib$rsvp$config$$config['off'].apply(lib$rsvp$config$$config, arguments);\n }\n\n // Set up instrumentation through `window.__PROMISE_INTRUMENTATION__`\n if (typeof window !== 'undefined' && typeof window['__PROMISE_INSTRUMENTATION__'] === 'object') {\n var lib$rsvp$$callbacks = window['__PROMISE_INSTRUMENTATION__'];\n lib$rsvp$config$$configure('instrument', true);\n for (var lib$rsvp$$eventName in lib$rsvp$$callbacks) {\n if (lib$rsvp$$callbacks.hasOwnProperty(lib$rsvp$$eventName)) {\n lib$rsvp$$on(lib$rsvp$$eventName, lib$rsvp$$callbacks[lib$rsvp$$eventName]);\n }\n }\n }\n\n var lib$rsvp$umd$$RSVP = {\n 'race': lib$rsvp$race$$default,\n 'Promise': lib$rsvp$promise$$default,\n 'allSettled': lib$rsvp$all$settled$$default,\n 'hash': lib$rsvp$hash$$default,\n 'hashSettled': lib$rsvp$hash$settled$$default,\n 'denodeify': lib$rsvp$node$$default,\n 'on': lib$rsvp$$on,\n 'off': lib$rsvp$$off,\n 'map': lib$rsvp$map$$default,\n 'filter': lib$rsvp$filter$$default,\n 'resolve': lib$rsvp$resolve$$default,\n 'reject': lib$rsvp$reject$$default,\n 'all': lib$rsvp$all$$default,\n 'rethrow': lib$rsvp$rethrow$$default,\n 'defer': lib$rsvp$defer$$default,\n 'EventTarget': lib$rsvp$events$$default,\n 'configure': lib$rsvp$config$$configure,\n 'async': lib$rsvp$$async\n };\n\n /* global define:true module:true window: true */\n if (typeof define === 'function' && define['amd']) {\n define(function() { return lib$rsvp$umd$$RSVP; });\n } else if (typeof module !== 'undefined' && module['exports']) {\n module['exports'] = lib$rsvp$umd$$RSVP;\n } else if (typeof lib$rsvp$platform$$default !== 'undefined') {\n lib$rsvp$platform$$default['RSVP'] = lib$rsvp$umd$$RSVP;\n }\n}).call(this);\n\n\n}).call(this,require('_process'),typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n\n},{\"_process\":71}]},{},[29])\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","js/app/cache.js","js/app/constructor.js","js/app/index.js","js/dom/add_categories.js","js/dom/add_files.js","js/dom/index.js","js/dom/loading_slider.js","js/dom/module_container.js","js/dom/setup/index.js","js/dom/setup/setup_dividers.js","js/dom/setup/setup_document.js","js/dom/setup/setup_files_bar.js","js/dom/setup/setup_interval.js","js/dom/setup/setup_module_container.js","js/dom/setup/setup_side_menu.js","js/dom/setup/setup_tab_container.js","js/dom/setup/setup_top_menu.js","js/dom/setup/setup_window.js","js/dom/show_algorithm.js","js/dom/show_description.js","js/dom/show_first_algorithm.js","js/dom/show_requested_algorithm.js","js/dom/show_wiki.js","js/dom/toast.js","js/dom/top_menu.js","js/editor/create.js","js/editor/executor.js","js/editor/index.js","js/index.js","js/module/data/array1d.js","js/module/data/array2d.js","js/module/data/coordinate_system.js","js/module/data/directed_graph.js","js/module/data/index.js","js/module/data/integer.js","js/module/data/undirected_graph.js","js/module/data/weighted_directed_graph.js","js/module/data/weighted_undirected_graph.js","js/module/index.js","js/module/tracer/array1d.js","js/module/tracer/array2d.js","js/module/tracer/chart.js","js/module/tracer/coordinate_system.js","js/module/tracer/directed_graph.js","js/module/tracer/index.js","js/module/tracer/log.js","js/module/tracer/tracer.js","js/module/tracer/undirected_graph.js","js/module/tracer/weighted_directed_graph.js","js/module/tracer/weighted_undirected_graph.js","js/server/ajax/get.js","js/server/ajax/get_json.js","js/server/ajax/post_json.js","js/server/ajax/request.js","js/server/helpers.js","js/server/index.js","js/server/load_algorithm.js","js/server/load_categories.js","js/server/load_file.js","js/server/load_scratch_paper.js","js/server/load_wiki.js","js/server/load_wiki_list.js","js/server/share_scratch_paper.js","js/tracer_manager/index.js","js/tracer_manager/manager.js","js/tracer_manager/util/from_json.js","js/tracer_manager/util/index.js","js/tracer_manager/util/refine_by_type.js","js/tracer_manager/util/to_json.js","js/utils/index.js","node_modules/process/browser.js","node_modules/rsvp/dist/rsvp.js"],"names":[],"mappings":"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lB,eAAkB,CAAC,QAAD,EAAW,SAAX,EAAyB;AAC/C,MAAI,eAAe,QAAf,CAAJ,EAA8B,OAAO,4BAAP;AAC9B,0BAAsB,QAAtB,SAAkC,SAAlC;AACD,CAHD;;AAKA,IAAM,aAAa,SAAb,UAAa,CAAC,QAAD,EAAW,SAAX,EAAsB,IAAtB,EAA+B;AAChD,MAAI,eAAe,QAAf,CAAJ,EAA8B,OAAO,4BAAP;AAC9B,0BAAsB,QAAtB,SAAkC,SAAlC,SAA+C,IAA/C;AACD,CAHD;;AAKA,OAAO,OAAP,GAAiB;AACf,gCADe;AAEf,kCAFe;AAGf;AAHe,CAAjB;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC9FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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})","'use strict';\n\nconst {\n  extend\n} = $;\n\nconst cache = {\n  lastFileUsed: '',\n  files: {}\n};\n\nconst assertFileName = (name) => {\n  if (!name) {\n    throw 'Missing file name';\n  }\n};\n\n\n/**\n * Global application cache\n */\nmodule.exports = {\n\n  getCachedFile(name) {\n    assertFileName(name);\n    return cache.files[name];\n  },\n\n  updateCachedFile(name, updates) {\n    assertFileName(name);\n    if (!cache.files[name]) {\n      cache.files[name] = {};\n    }\n    extend(cache.files[name], updates);\n  },\n\n  getLastFileUsed() {\n    return cache.lastFileUsed;\n  },\n\n  setLastFileUsed(file) {\n    cache.lastFileUsed = file;\n  }\n};","'use strict';\n\nconst Editor = require('../editor');\nconst TracerManager = require('../tracer_manager');\nconst DOM = require('../dom/setup');\n\nconst {\n  showLoadingSlider,\n  hideLoadingSlider\n} = require('../dom/loading_slider');\n\nconst Cache = require('./cache');\n\nconst state = {\n  isLoading: null,\n  editor: null,\n  tracerManager: null,\n  categories: null,\n  loadedScratch: null,\n  wikiList: null\n};\n\nconst initState = (tracerManager) => {\n  state.isLoading = false;\n  state.editor = new Editor(tracerManager);\n  state.tracerManager = tracerManager;\n  state.categories = {};\n  state.loadedScratch = null;\n  state.wikiList = [];\n};\n\n/**\n * Global application singleton.\n */\nconst App = function () {\n\n  this.getIsLoading = () => {\n    return state.isLoading;\n  };\n\n  this.setIsLoading = (loading) => {\n    state.isLoading = loading;\n    if (loading) {\n      showLoadingSlider();\n    } else {\n      hideLoadingSlider();\n    }\n  };\n\n  this.getEditor = () => {\n    return state.editor;\n  };\n\n  this.getCategories = () => {\n    return state.categories;\n  };\n\n  this.getCategory = (name) => {\n    return state.categories[name];\n  };\n\n  this.setCategories = (categories) => {\n    state.categories = categories;\n  };\n\n  this.updateCategory = (name, updates) => {\n    $.extend(state.categories[name], updates);\n  };\n\n  this.getTracerManager = () => {\n    return state.tracerManager;\n  };\n\n  this.getLoadedScratch = () => {\n    return state.loadedScratch;\n  };\n\n  this.setLoadedScratch = (loadedScratch) => {\n    state.loadedScratch = loadedScratch;\n  };\n\n  this.getWikiList = () => {\n    return state.wikiList;\n  };\n\n  this.setWikiList = (wikiList) => {\n    state.wikiList = wikiList;\n  };\n\n  this.hasWiki = (wiki) => {\n    return ~state.wikiList.indexOf(wiki);\n  };\n\n  const tracerManager = TracerManager.init();\n\n  initState(tracerManager);\n  DOM.setup(tracerManager);\n\n};\n\nApp.prototype = Cache;\n\nmodule.exports = App;\n","'use strict';\n\n/**\n * This is the main application instance.\n * Gets populated on page load. \n */\nmodule.exports = {};","'use strict';\n\nconst app = require('../app');\nconst Server = require('../server');\nconst showAlgorithm = require('./show_algorithm');\n\nconst {\n  each\n} = $;\n\nconst getAlgorithmDOM = (category, subList, algorithm) => {\n  return $('<button class=\"indent\">')\n    .append(subList[algorithm])\n    .attr('data-algorithm', algorithm)\n    .attr('data-category', category)\n    .click(function () {\n      Server.loadAlgorithm(category, algorithm).then((data) => {\n        showAlgorithm(category, algorithm, data);\n      });\n    });\n\n  $('#list').append($algorithm);\n};\n\nconst addCategoryToDOM = (category) => {\n\n  const {\n    name: categoryName,\n    list: categorySubList\n  } = app.getCategory(category);\n\n  const $category = $('<button class=\"category\">')\n    .append('<i class=\"fa fa-fw fa-caret-right\">')\n    .append(categoryName)\n    .attr('data-category', category);\n\n  $category.click(function () {\n    const $self = $(this);\n    $self.toggleClass('open');\n    $self.next().toggleClass('collapse');\n    $self.find('i.fa').toggleClass('fa-caret-right fa-caret-down');\n  });\n\n  const $algorithms = $('<div class=\"algorithms collapse\">');\n  $('#list').append($category).append($algorithms);\n\n  each(categorySubList, (algorithm) => {\n    const $algorithm = getAlgorithmDOM(category, categorySubList, algorithm);\n    $algorithms.append($algorithm);\n  });\n};\n\nmodule.exports = () => {\n  each(app.getCategories(), addCategoryToDOM);\n};\n","'use strict';\n\nconst Server = require('../server');\n\nconst {\n  each\n} = $;\n\nconst addFileToDOM = (category, algorithm, file, explanation) => {\n  var $file = $('<button>')\n    .append(file)\n    .attr('data-file', file)\n    .click(function () {\n      Server.loadFile(category, algorithm, file, explanation);\n      $('.files_bar > .wrapper > button').removeClass('active');\n      $(this).addClass('active');\n    });\n  $('.files_bar > .wrapper').append($file);\n  return $file;\n};\n\nmodule.exports = (category, algorithm, files, requestedFile) => {\n  $('.files_bar > .wrapper').empty();\n\n  each(files, (file, explanation) => {\n    var $file = addFileToDOM(category, algorithm, file, explanation);\n    if (requestedFile && requestedFile == file) $file.click();\n  });\n\n  if (!requestedFile) $('.files_bar > .wrapper > button').first().click();\n  $('.files_bar > .wrapper').scroll();\n};","'use strict';\n\nconst showAlgorithm = require('./show_algorithm');\nconst addCategories = require('./add_categories');\nconst showDescription = require('./show_description');\nconst addFiles = require('./add_files');\nconst showFirstAlgorithm = require('./show_first_algorithm');\nconst showRequestedAlgorithm = require('./show_requested_algorithm');\nconst showWiki = require('./show_wiki');\n\nmodule.exports = {\n  showAlgorithm,\n  addCategories,\n  showDescription,\n  addFiles,\n  showFirstAlgorithm,\n  showRequestedAlgorithm,\n  showWiki\n};","'use strict';\n\nconst showLoadingSlider = () => {\n  $('#loading-slider').removeClass('loaded');\n};\n\nconst hideLoadingSlider = () => {\n  $('#loading-slider').addClass('loaded');\n};\n\nmodule.exports = {\n  showLoadingSlider,\n  hideLoadingSlider\n};\n","'use strict';\n\nconst create = () => {\n  const $container = $('<section class=\"module_wrapper\">');\n  $('.module_container').append($container);\n  return $container;\n};\n\nmodule.exports = {\n  create\n};\n","'use strict';\n\nconst setupDividers = require('./setup_dividers');\nconst setupDocument = require('./setup_document');\nconst setupFilesBar = require('./setup_files_bar');\nconst setupInterval = require('./setup_interval');\nconst setupModuleContainer = require('./setup_module_container');\nconst setupTabContainer = require('./setup_tab_container');\nconst setupSideMenu = require('./setup_side_menu');\nconst setupTopMenu = require('./setup_top_menu');\nconst setupWindow = require('./setup_window');\n\n/**\n * Initializes elements once the app loads in the DOM.\n */\nconst setup = () => {\n\n  $('.btn input').click((e) => {\n    e.stopPropagation();\n  });\n\n  // dividers\n  setupDividers();\n\n  // document\n  setupDocument();\n\n  // files bar\n  setupFilesBar();\n\n  // interval\n  setupInterval();\n\n  // module container\n  setupModuleContainer();\n\n  // tab container\n  setupTabContainer();\n\n  // side menu\n  setupSideMenu();\n\n  // top menu\n  setupTopMenu();\n\n  // window\n  setupWindow();\n\n};\n\nmodule.exports = {\n  setup\n};\n","'use strict';\n\nconst app = require('../../app');\n\nconst addDividerToDom = (divider) => {\n  const [vertical, $first, $second] = divider;\n  const $parent = $first.parent();\n  const thickness = 5;\n\n  const $divider = $('<div class=\"divider\">');\n\n  let dragging = false;\n  if (vertical) {\n    $divider.addClass('vertical');\n\n    let _left = -thickness / 2;\n    $divider.css({\n      top: 0,\n      bottom: 0,\n      left: _left,\n      width: thickness\n    });\n\n    let x;\n    $divider.mousedown(({\n      pageX\n    }) => {\n      x = pageX;\n      dragging = true;\n    });\n\n    $(document).mousemove(({\n      pageX\n    }) => {\n      if (dragging) {\n        const new_left = $second.position().left + pageX - x;\n        let percent = new_left / $parent.width() * 100;\n        percent = Math.min(90, Math.max(10, percent));\n        $first.css('right', (100 - percent) + '%');\n        $second.css('left', percent + '%');\n        x = pageX;\n        app.getTracerManager().resize();\n        $('.files_bar > .wrapper').scroll();\n      }\n    });\n\n    $(document).mouseup(function(e) {\n      dragging = false;\n    });\n\n  } else {\n\n    $divider.addClass('horizontal');\n    const _top = -thickness / 2;\n    $divider.css({\n      top: _top,\n      height: thickness,\n      left: 0,\n      right: 0\n    });\n\n    let y;\n    $divider.mousedown(function({\n      pageY\n    }) {\n      y = pageY;\n      dragging = true;\n    });\n\n    $(document).mousemove(function({\n      pageY\n    }) {\n      if (dragging) {\n        const new_top = $second.position().top + pageY - y;\n        let percent = new_top / $parent.height() * 100;\n        percent = Math.min(90, Math.max(10, percent));\n        $first.css('bottom', (100 - percent) + '%');\n        $second.css('top', percent + '%');\n        y = pageY;\n        app.getTracerManager().resize();\n      }\n    });\n\n    $(document).mouseup(function(e) {\n      dragging = false;\n    });\n  }\n\n  $second.append($divider);\n};\n\nmodule.exports = () => {\n  const dividers = [\n    ['v', $('.sidemenu'), $('.workspace')],\n    ['v', $('.viewer_container'), $('.editor_container')],\n    ['h', $('.data_container'), $('.code_container')]\n  ];\n  for (let i = 0; i < dividers.length; i++) {\n    addDividerToDom(dividers[i]);\n  }\n};","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = () => {\n  $(document).on('click', 'a', function (e) {\n    const href = $(this).attr('href');\n    if (/^(https?:\\/\\/).+/.test(href)) {\n      e.preventDefault();\n      if (!window.open(href, '_blank')) {\n        alert('Please allow popups for this site');\n      }\n    }\n  });\n\n  $(document).mouseup(function (e) {\n    app.getTracerManager().command('mouseup', e);\n  });\n};\n","'use strict';\n\nconst definitelyBigger = (x, y) => x > (y + 2);\n\nmodule.exports = () => {\n\n  $('.files_bar > .btn-left').click(() => {\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const scrollLeft = $wrapper.scrollLeft();\n\n    $($wrapper.children('button').get().reverse()).each(function() {\n      const left = $(this).position().left;\n      const right = left + $(this).outerWidth();\n      if (0 > left) {\n        $wrapper.scrollLeft(scrollLeft + right - clipWidth);\n        return false;\n      }\n    });\n  });\n\n  $('.files_bar > .btn-right').click(() => {\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const scrollLeft = $wrapper.scrollLeft();\n\n    $wrapper.children('button').each(function() {\n      const left = $(this).position().left;\n      const right = left + $(this).outerWidth();\n      if (clipWidth < right) {\n        $wrapper.scrollLeft(scrollLeft + left);\n        return false;\n      }\n    });\n  });\n\n  $('.files_bar > .wrapper').scroll(function() {\n\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const $left = $wrapper.children('button:first-child');\n    const $right = $wrapper.children('button:last-child');\n    const left = $left.position().left;\n    const right = $right.position().left + $right.outerWidth();\n\n    if (definitelyBigger(0, left) && definitelyBigger(clipWidth, right)) {\n      const scrollLeft = $wrapper.scrollLeft();\n      $wrapper.scrollLeft(scrollLeft + clipWidth - right);\n      return;\n    }\n\n    const lefter = definitelyBigger(0, left);\n    const righter = definitelyBigger(right, clipWidth);\n    $wrapper.toggleClass('shadow-left', lefter);\n    $wrapper.toggleClass('shadow-right', righter);\n    $('.files_bar > .btn-left').attr('disabled', !lefter);\n    $('.files_bar > .btn-right').attr('disabled', !righter);\n  });\n}\n","'use strict';\n\nconst app = require('../../app');\nconst Toast = require('../toast');\n\nconst {\n  parseFloat\n} = Number;\n\nconst minInterval = 0.1;\nconst maxInterval = 10;\nconst startInterval = 0.5;\nconst stepInterval = 0.1;\n\nconst normalize = (sec) => {\n\n\n  let interval;\n  let message;\n  if (sec < minInterval) {\n    interval = minInterval;\n    message = `Interval of ${sec} seconds is too low. Setting to min allowed interval of ${minInterval} second(s).`;\n  } else if (sec > maxInterval) {\n    interval = maxInterval;\n    message = `Interval of ${sec} seconds is too high. Setting to max allowed interval of ${maxInterval} second(s).`;\n  } else {\n    interval = sec;\n    message = `Interval has been set to ${sec} second(s).`\n  }\n\n  return [interval, message];\n};\n\nmodule.exports = () => {\n\n  const $interval = $('#interval');\n  $interval.val(startInterval);\n  $interval.attr({\n    max: maxInterval,\n    min: minInterval,\n    step: stepInterval\n  });\n\n  $('#interval').on('change', function() {\n    const tracerManager = app.getTracerManager();\n    const [seconds, message] = normalize(parseFloat($(this).val()));\n\n    $(this).val(seconds);\n    tracerManager.interval = seconds * 1000;\n    Toast.showInfoToast(message);\n  });\n};\n","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = () => {\n\n  const $module_container = $('.module_container');\n\n  $module_container.on('mousedown', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousedown(e);\n  });\n\n  $module_container.on('mousemove', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousemove(e);\n  });\n\n  $module_container.on('DOMMouseScroll mousewheel', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousewheel(e);\n  });\n}\n","'use strict';\n\nconst app = require('../../app');\nconst Server = require('../../server');\nconst showAlgorithm = require('../show_algorithm');\n\nlet sidemenu_percent;\n\nmodule.exports = () => {\n  $('#navigation').click(() => {\n    const $sidemenu = $('.sidemenu');\n    const $workspace = $('.workspace');\n\n    $sidemenu.toggleClass('active');\n    $('.nav-dropdown').toggleClass('fa-caret-down fa-caret-up');\n\n    if ($sidemenu.hasClass('active')) {\n      $sidemenu.css('right', (100 - sidemenu_percent) + '%');\n      $workspace.css('left', sidemenu_percent + '%');\n\n    } else {\n      sidemenu_percent = $workspace.position().left / $('body').width() * 100;\n      $sidemenu.css('right', 0);\n      $workspace.css('left', 0);\n    }\n\n    app.getTracerManager().resize();\n  });\n\n  $('#documentation').click(function () {\n    $('#btn_doc').click();\n  });\n\n  $('#powered-by').click(() => {\n    $('#powered-by-list button').toggleClass('collapse');\n  });\n\n  $('#scratch-paper').click(() => {\n    const category = 'scratch';\n    const algorithm = app.getLoadedScratch();\n    Server.loadAlgorithm(category, algorithm).then((data) => {\n      showAlgorithm(category, algorithm, data);\n    });\n  });\n};","'use strict';\n\nmodule.exports = () => {\n  $('.tab_bar > button').click(function () {\n    $('.tab_bar > button').removeClass('active');\n    $('.tab_container > .tab').removeClass('active');\n    $(this).addClass('active');\n    $($(this).attr('data-target')).addClass('active');\n  });\n};","'use strict';\n\nconst app = require('../../app');\nconst Server = require('../../server');\nconst Toast = require('../toast');\nconst TopMenu = require('../top_menu');\n\nmodule.exports = () => {\n\n  // shared\n  $('#shared').mouseup(function () {\n    $(this).select();\n  });\n\n  $('#btn_share').click(function () {\n\n    const $icon = $(this).find('.fa-share');\n    $icon.addClass('fa-spin fa-spin-faster');\n\n    Server.shareScratchPaper().then((url) => {\n      $icon.removeClass('fa-spin fa-spin-faster');\n      $('#shared').removeClass('collapse');\n      $('#shared').val(url);\n      Toast.showInfoToast('Shareable link is created.');\n    });\n  });\n\n  // control\n\n  const $btnRun = $('#btn_run');\n  const $btnTrace = $('#btn_trace');\n  const $btnPause = $('#btn_pause');\n  const $btnPrev = $('#btn_prev');\n  const $btnNext = $('#btn_next');\n\n  // initially, control buttons are disabled\n  TopMenu.disableFlowControl();\n\n  $btnRun.click(() => {\n    $btnTrace.click();\n    $btnPause.removeClass('active');\n    $btnRun.addClass('active');\n    TopMenu.enableFlowControl();\n    var err = app.getEditor().execute();\n    if (err) {\n      console.error(err);\n      Toast.showErrorToast(err);\n      TopMenu.resetTopMenuButtons();\n    }\n  });\n\n  $btnPause.click(() => {\n    $btnRun.toggleClass('active');\n    $btnPause.toggleClass('active');\n    if (app.getTracerManager().isPause()) {\n      app.getTracerManager().resumeStep();\n    } else {\n      app.getTracerManager().pauseStep();\n    }\n  });\n\n  $btnPrev.click(() => {\n    $btnRun.removeClass('active');\n    $btnPause.addClass('active');\n    app.getTracerManager().pauseStep();\n    app.getTracerManager().prevStep();\n  });\n\n  $btnNext.click(() => {\n    $btnRun.removeClass('active');\n    $btnPause.addClass('active');\n    app.getTracerManager().pauseStep();\n    app.getTracerManager().nextStep();\n  });\n\n};\n","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = function() {\n  $(window).resize(function() {\n    app.getTracerManager().resize();\n  });\n};\n","'use strict';\n\nconst app = require('../app');\n\nconst {\n  isScratchPaper\n} = require('../utils');\n\nconst showDescription = require('./show_description');\nconst addFiles = require('./add_files');\n\nmodule.exports = (category, algorithm, data, requestedFile) => {\n  let $menu;\n  let category_name;\n  let algorithm_name;\n\n  if (isScratchPaper(category)) {\n    $menu = $('#scratch-paper');\n    category_name = 'Scratch Paper';\n    algorithm_name = algorithm ? 'Shared' : 'Temporary';\n  } else {\n    $menu = $(`[data-category=\"${category}\"][data-algorithm=\"${algorithm}\"]`);\n    const categoryObj = app.getCategory(category);\n    category_name = categoryObj.name;\n    algorithm_name = categoryObj.list[algorithm];\n  }\n\n  $('.sidemenu button').removeClass('active');\n  $menu.addClass('active');\n\n  $('#category').html(category_name);\n  $('#algorithm').html(algorithm_name);\n  $('#tab_desc > .wrapper').empty();\n  $('.files_bar > .wrapper').empty();\n  $('#explanation').html('');\n\n  app.setLastFileUsed(null);\n  app.getEditor().clearContent();\n\n  const {\n    files\n  } = data;\n\n  delete data.files;\n\n  showDescription(data);\n  addFiles(category, algorithm, files, requestedFile);\n};","'use strict';\n\nconst {\n  isArray\n} = Array;\n\nconst {\n  each\n} = $;\n\nmodule.exports = (data) => {\n  const $container = $('#tab_desc > .wrapper');\n  $container.empty();\n\n  each(data, (key, value) => {\n\n    if (key) {\n      $container.append($('<h3>').html(key));\n    }\n\n    if (typeof value === 'string') {\n      $container.append($('<p>').html(value));\n\n    } else if (isArray(value)) {\n\n      const $ul = $('<ul class=\"applications\">');\n      $container.append($ul);\n\n      value.forEach((li) => {\n        $ul.append($('<li>').html(li));\n      });\n\n    } else if (typeof value === 'object') {\n\n      const $ul = $('<ul class=\"complexities\">');\n      $container.append($ul);\n\n      each(value, (prop) => {\n        const $wrapper = $('<div class=\"complexity\">');\n        const $type = $('<span class=\"complexity-type\">').html(`${prop}: `);\n        const $value = $('<span class=\"complexity-value\">').html(`${value[prop]}`);\n\n        $wrapper.append($type).append($value);\n\n        $ul.append($('<li>').append($wrapper));\n      });\n    }\n  });\n};\n","'use strict';\n\n// click the first algorithm in the first category\nmodule.exports = () => {\n  $('#list .category').first().click();\n  $('#list .category + .algorithms > .indent').first().click();\n};\n","'use strict';\n\nconst Server = require('../server');\nconst showAlgorithm = require('./show_algorithm');\n\nmodule.exports = (category, algorithm, file) => {\n  $(`.category[data-category=\"${category}\"]`).click();\n  Server.loadAlgorithm(category, algorithm).then((data) => {\n    showAlgorithm(category, algorithm, data, file);\n  });\n};\n","'use strict';\n\nconst app = require('../app');\nconst Server = require('../server');\nconst converter = new showdown.Converter({tables: true});\n\nmodule.exports = (wiki) => {\n  Server.loadWiki(wiki).then((data) => {\n    $('#tab_doc > .wrapper').html(converter.makeHtml(`#${wiki}\\n${data}`));\n    $('#tab_doc').scrollTop(0);\n    $('#tab_doc > .wrapper a').click(function (e) {\n      const href = $(this).attr('href');\n      if (app.hasWiki(href)) {\n        e.preventDefault();\n        module.exports(href);\n      }\n    });\n  });\n};","'use strict';\n\nconst showToast = (data, type) => {\n  const $toast = $(`<div class=\"toast ${type}\">`).append(data);\n\n  $('.toast_container').append($toast);\n  setTimeout(() => {\n    $toast.fadeOut(() => {\n      $toast.remove();\n    });\n  }, 3000);\n};\n\nconst showErrorToast = (err) => {\n  showToast(err, 'error');\n};\n\nconst showInfoToast = (err) => {\n  showToast(err, 'info');\n};\n\nmodule.exports = {\n  showErrorToast,\n  showInfoToast\n};","'use strict';\n\nconst app = require('../app');\n\nconst flowControlBtns = [ $('#btn_pause'), $('#btn_prev'), $('#btn_next') ];\nconst setFlowControlState = (isDisabled) => {\n  flowControlBtns.forEach($btn => $btn.attr('disabled', isDisabled));\n};\n\nconst enableFlowControl = () => {\n  setFlowControlState(false);\n};\n\nconst disableFlowControl = () => {\n  setFlowControlState(true);\n};\n\nconst resetTopMenuButtons = () => {\n  $('.top-menu-buttons button').removeClass('active');\n  disableFlowControl();\n  app.getEditor().unhighlightLine();\n};\n\nconst setInterval = (val) => {\n  $('#interval').val(interval);\n};\n\nconst activateBtnPause = () => {\n  $('#btn_pause').addClass('active');\n};\n\nconst deactivateBtnPause = () => {\n  $('#btn_pause').removeClass('active');\n};\n\nmodule.exports = {\n  enableFlowControl,\n  disableFlowControl,\n  resetTopMenuButtons,\n  setInterval,\n  activateBtnPause,\n  deactivateBtnPause\n};\n","'use strict';\n\nmodule.exports = function(id) {\n  const editor = ace.edit(id);\n\n  editor.setOptions({\n    enableBasicAutocompletion: true,\n    enableSnippets: true,\n    enableLiveAutocompletion: true\n  });\n\n  editor.setTheme('ace/theme/tomorrow_night_eighties');\n  editor.session.setMode('ace/mode/javascript');\n  editor.$blockScrolling = Infinity;\n\n  return editor;\n};","'use strict';\n\nconst execute = (tracerManager, code, dataLines) => {\n  // all modules available to eval are obtained from window\n  try {\n    tracerManager.deallocateAll();\n    const lines = code.split('\\n');\n    const newLines = [];\n    lines.forEach((line, i) => {\n      newLines.push(line.replace(/(.+\\. *_wait *)(\\( *\\))/g, `$1(${i - dataLines})`));\n    });\n    eval(newLines.join('\\n'));\n    tracerManager.visualize();\n  } catch (err) {\n    return err;\n  } finally {\n    tracerManager.removeUnallocated();\n  }\n};\n\nconst executeData = (tracerManager, algoData) => {\n  return execute(tracerManager, algoData);\n};\n\nconst executeDataAndCode = (tracerManager, algoData, algoCode) => {\n  const dataLines = algoData.split('\\n').length;\n  return execute(tracerManager, `${algoData}\\n${algoCode}`, dataLines);\n};\n\nmodule.exports = {\n  executeData,\n  executeDataAndCode\n};","'use strict';\n\nconst app = require('../app');\nconst createEditor = require('./create');\nconst Executor = require('./executor');\nconst TopMenu = require('../dom/top_menu');\n\nfunction Editor(tracerManager) {\n  if (!tracerManager) {\n    throw 'Cannot create Editor. Missing the tracerManager';\n  }\n\n  ace.require('ace/ext/language_tools');\n  const Range = ace.require(\"ace/range\").Range;\n\n  this.dataEditor = createEditor('data');\n  this.codeEditor = createEditor('code');\n\n  // Setting data\n\n  this.setData = (data) => {\n    this.dataEditor.setValue(data, -1);\n  };\n\n  this.setCode = (code) => {\n    this.codeEditor.setValue(code, -1);\n  };\n\n  this.setContent = (({\n    data,\n    code\n  }) => {\n    this.setData(data);\n    this.setCode(code);\n  });\n\n  // Clearing data\n\n  this.clearData = () => {\n    this.dataEditor.setValue('');\n  };\n\n  this.clearCode = () => {\n    this.codeEditor.setValue('');\n  };\n\n  this.clearContent = () => {\n    this.clearData();\n    this.clearCode();\n  };\n\n  this.execute = () => {\n    const data = this.dataEditor.getValue();\n    const code = this.codeEditor.getValue();\n    return Executor.executeDataAndCode(tracerManager, data, code);\n  };\n\n  this.highlightLine = (lineNumber) => {\n    const session = this.codeEditor.getSession();\n    if (this.marker) session.removeMarker(this.marker);\n    this.marker = session.addMarker(new Range(lineNumber, 0, lineNumber, Infinity), \"executing\", \"line\", true);\n  };\n\n  this.unhighlightLine = () => {\n    const session = this.codeEditor.getSession();\n    if (this.marker) session.removeMarker(this.marker);\n  };\n\n  // listeners\n\n  this.dataEditor.on('change', () => {\n    const data = this.dataEditor.getValue();\n    const lastFileUsed = app.getLastFileUsed();\n    if (lastFileUsed) {\n      app.updateCachedFile(lastFileUsed, {\n        data\n      });\n    }\n    Executor.executeData(tracerManager, data);\n    TopMenu.resetTopMenuButtons();\n  });\n\n  this.codeEditor.on('change', () => {\n    const code = this.codeEditor.getValue();\n    const lastFileUsed = app.getLastFileUsed();\n    if (lastFileUsed) {\n      app.updateCachedFile(lastFileUsed, {\n        code\n      });\n    }\n    tracerManager.reset();\n    TopMenu.resetTopMenuButtons();\n  });\n}\n\nmodule.exports = Editor;","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('./app');\nconst AppConstructor = require('./app/constructor');\nconst DOM = require('./dom');\nconst Server = require('./server');\n\nconst modules = require('./module');\n\nconst {\n  extend\n} = $;\n\n$.ajaxSetup({\n  cache: false,\n  dataType: 'text'\n});\n\nconst {\n  isScratchPaper\n} = require('./utils');\n\nconst {\n  getPath\n} = require('./server/helpers');\n\n// set global promise error handler\nRSVP.on('error', function (reason) {\n  console.assert(false, reason);\n});\n\n$(() => {\n\n  // initialize the application and attach in to the instance module\n  const appConstructor = new AppConstructor();\n  extend(true, app, appConstructor);\n\n  // load modules to the global scope so they can be evaled\n  extend(true, window, modules);\n\n  Server.loadCategories().then((data) => {\n    app.setCategories(data);\n    DOM.addCategories();\n\n    // determine if the app is loading a pre-existing scratch-pad\n    // or the home page\n    const {\n      category,\n      algorithm,\n      file\n    } = getPath();\n    if (isScratchPaper(category)) {\n      if (algorithm) {\n        Server.loadScratchPaper(algorithm).then(({category, algorithm, data}) => {\n          DOM.showAlgorithm(category, algorithm, data);\n        });\n      } else {\n        Server.loadAlgorithm(category).then((data) => {\n          DOM.showAlgorithm(category, null, data);\n        });\n      }\n    } else if (category && algorithm) {\n      DOM.showRequestedAlgorithm(category, algorithm, file);\n    } else {\n      DOM.showFirstAlgorithm();\n    }\n  });\n\n  Server.loadWikiList().then((data) => {\n    app.setWikiList(data.wikis);\n\n    DOM.showWiki('Tracer');\n  })\n});","'use strict';\n\nconst Array2D = require('./array2d');\n\nconst random = (N, min, max) => {\n  return Array2D.random(1, N, min, max)[0];\n};\n\nconst randomSorted = (N, min, max)=> {\n  return Array2D.randomSorted(1, N, min, max)[0];\n};\n\nmodule.exports = {\n  random,\n  randomSorted\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, M, min, max) => {\n  if (!N) N = 10;\n  if (!M) M = 10;\n  if (min === undefined) min = 1;\n  if (max === undefined) max = 9;\n  var D = [];\n  for (var i = 0; i < N; i++) {\n    D.push([]);\n    for (var j = 0; j < M; j++) {\n      D[i].push(Integer.random(min, max));\n    }\n  }\n  return D;\n};\n\nconst randomSorted = (N, M, min, max) => {\n  return random(N, M, min, max).map(function (arr) {\n    return arr.sort(function (a, b) {\n      return a - b;\n    });\n  });\n};\n\nmodule.exports = {\n  random,\n  randomSorted\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, min, max) => {\n  if (!N) N = 7;\n  if (!min) min = 1;\n  if (!max) max = 10;\n  var C = new Array(N);\n  for (var i = 0; i < N; i++) C[i] = new Array(2);\n  for (var i = 0; i < N; i++)\n    for (var j = 0; j < C[i].length; j++)\n      C[i][j] = Integer.random(min, max);\n  return C;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst random = (N, ratio) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) {\n    G[i] = new Array(N);\n    for (var j = 0; j < N; j++) {\n      if (i != j) {\n        G[i][j] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\nconst Array1D = require('./array1d');\nconst Array2D = require('./array2d');\nconst CoordinateSystem = require('./coordinate_system');\nconst DirectedGraph = require('./directed_graph');\nconst UndirectedGraph = require('./undirected_graph');\nconst WeightedDirectedGraph = require('./weighted_directed_graph');\nconst WeightedUndirectedGraph = require('./weighted_undirected_graph');\n\nmodule.exports = {\n  Integer,\n  Array1D,\n  Array2D,\n  CoordinateSystem,\n  DirectedGraph,\n  UndirectedGraph,\n  WeightedDirectedGraph,\n  WeightedUndirectedGraph\n};","'use strict';\n\nconst random = (min, max) => {\n  return (Math.random() * (max - min + 1) | 0) + min;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst random = (N, ratio) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) G[i] = new Array(N);\n  for (var i = 0; i < N; i++) {\n    for (var j = 0; j < N; j++) {\n      if (i > j) {\n        G[i][j] = G[j][i] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, ratio, min, max) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  if (!min) min = 1;\n  if (!max) max = 5;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) {\n    G[i] = new Array(N);\n    for (var j = 0; j < N; j++) {\n      if (i != j && (Math.random() * (1 / ratio) | 0) == 0) {\n        G[i][j] = Integer.random(min, max);\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, ratio, min, max) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  if (!min) min = 1;\n  if (!max) max = 5;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) G[i] = new Array(N);\n  for (var i = 0; i < N; i++) {\n    for (var j = 0; j < N; j++) {\n      if (i > j && (Math.random() * (1 / ratio) | 0) == 0) {\n        G[i][j] = G[j][i] = Integer.random(min, max);\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nvar tracers = require('./tracer');\nvar datas = require('./data');\n\nconst {\n  extend\n} = $;\n\nmodule.exports = extend(true, {}, tracers, datas);","'use strict';\n\nconst Array2DTracer = require('./array2d');\n\nclass Array1DTracer extends Array2DTracer {\n  static getClassName() {\n    return 'Array1DTracer';\n  }\n\n  constructor(name) {\n    super(name);\n  }\n\n  _notify(idx, v) {\n    super._notify(0, idx, v);\n    return this;\n  }\n\n  _denotify(idx) {\n    super._denotify(0, idx);\n    return this;\n  }\n\n  _select(s, e) {\n    if (e === undefined) {\n      super._select(0, s);\n    } else {\n      super._selectRow(0, s, e);\n    }\n    return this;\n  }\n\n  _deselect(s, e) {\n    if (e === undefined) {\n      super._deselect(0, s);\n    } else {\n      super._deselectRow(0, s, e);\n    }\n    return this;\n  }\n\n  processStep(step, options) {\n    super.processStep(step, options);\n    if (this.chartTracer) {\n      const newStep = $.extend(true, {}, step);\n      newStep.capsule = this.chartTracer.capsule;\n      newStep.s = newStep.sy;\n      newStep.e = newStep.ey;\n      if (newStep.s === undefined) newStep.s = newStep.y;\n      delete newStep.x;\n      delete newStep.y;\n      delete newStep.sx;\n      delete newStep.sy;\n      delete newStep.ex;\n      delete newStep.ey;\n      this.chartTracer.processStep(newStep, options);\n    }\n  }\n\n  setData(D) {\n    return super.setData([D]);\n  }\n}\n\nmodule.exports = Array1DTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass Array2DTracer extends Tracer {\n  static getClassName() {\n    return 'Array2DTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.colorClass = {\n      selected: 'selected',\n      notified: 'notified'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  _notify(x, y, v) {\n    this.manager.pushStep(this.capsule, {\n      type: 'notify',\n      x: x,\n      y: y,\n      v: v\n    });\n    return this;\n  }\n\n  _denotify(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'denotify',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _select(sx, sy, ex, ey) {\n    this.pushSelectingStep('select', null, arguments);\n    return this;\n  }\n\n  _selectRow(x, sy, ey) {\n    this.pushSelectingStep('select', 'row', arguments);\n    return this;\n  }\n\n  _selectCol(y, sx, ex) {\n    this.pushSelectingStep('select', 'col', arguments);\n    return this;\n  }\n\n  _deselect(sx, sy, ex, ey) {\n    this.pushSelectingStep('deselect', null, arguments);\n    return this;\n  }\n\n  _deselectRow(x, sy, ey) {\n    this.pushSelectingStep('deselect', 'row', arguments);\n    return this;\n  }\n\n  _deselectCol(y, sx, ex) {\n    this.pushSelectingStep('deselect', 'col', arguments);\n    return this;\n  }\n\n  _separate(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'separate',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _separateRow(x) {\n    this._separate(x, -1);\n    return this;\n  }\n\n  _separateCol(y) {\n    this._separate(-1, y);\n    return this;\n  }\n\n  _deseparate(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'deseparate',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _deseparateRow(x) {\n    this._deseparate(x, -1);\n    return this;\n  }\n\n  _deseparateCol(y) {\n    this._deseparate(-1, y);\n    return this;\n  }\n\n  pushSelectingStep() {\n    var args = Array.prototype.slice.call(arguments);\n    var type = args.shift();\n    var mode = args.shift();\n    args = Array.prototype.slice.call(args.shift());\n    var coord;\n    switch (mode) {\n      case 'row':\n        coord = {\n          x: args[0],\n          sy: args[1],\n          ey: args[2]\n        };\n        break;\n      case 'col':\n        coord = {\n          y: args[0],\n          sx: args[1],\n          ex: args[2]\n        };\n        break;\n      default:\n        if (args[2] === undefined && args[3] === undefined) {\n          coord = {\n            x: args[0],\n            y: args[1]\n          };\n        } else {\n          coord = {\n            sx: args[0],\n            sy: args[1],\n            ex: args[2],\n            ey: args[3]\n          };\n        }\n    }\n    var step = {\n      type: type\n    };\n    $.extend(step, coord);\n    this.manager.pushStep(this.capsule, step);\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'notify':\n        if (step.v !== undefined) {\n          var $row = this.$table.find('.mtbl-row').eq(step.x);\n          var $col = $row.find('.mtbl-col').eq(step.y);\n          $col.text(refineByType(step.v));\n        }\n      case 'denotify':\n      case 'select':\n      case 'deselect':\n        var colorClass = step.type == 'select' || step.type == 'deselect' ? this.colorClass.selected : this.colorClass.notified;\n        var addClass = step.type == 'select' || step.type == 'notify';\n        var sx = step.sx;\n        var sy = step.sy;\n        var ex = step.ex;\n        var ey = step.ey;\n        if (sx === undefined) sx = step.x;\n        if (sy === undefined) sy = step.y;\n        if (ex === undefined) ex = step.x;\n        if (ey === undefined) ey = step.y;\n        this.paintColor(sx, sy, ex, ey, colorClass, addClass);\n        break;\n      case 'separate':\n        this.deseparate(step.x, step.y);\n        this.separate(step.x, step.y);\n        break;\n      case 'deseparate':\n        this.deseparate(step.x, step.y);\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  setData(D) {\n    this.viewX = this.viewY = 0;\n    this.paddingH = 6;\n    this.paddingV = 3;\n    this.fontSize = 16;\n\n    if (super.setData.apply(this, arguments)) {\n      this.$table.find('.mtbl-row').each(function (i) {\n        $(this).find('.mtbl-col').each(function (j) {\n          $(this).text(refineByType(D[i][j]));\n        });\n      });\n      return true;\n    }\n\n    this.$table.empty();\n    for (var i = 0; i < D.length; i++) {\n      var $row = $('<div class=\"mtbl-row\">');\n      this.$table.append($row);\n      for (var j = 0; j < D[i].length; j++) {\n        var $col = $('<div class=\"mtbl-col\">')\n          .css(this.getCellCss())\n          .text(refineByType(D[i][j]));\n        $row.append($col);\n      }\n    }\n    this.resize();\n\n    return false;\n  }\n\n  resize() {\n    super.resize();\n\n    this.refresh();\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearColor();\n    this.deseparateAll();\n  }\n\n  getCellCss() {\n    return {\n      padding: this.paddingV.toFixed(1) + 'px ' + this.paddingH.toFixed(1) + 'px',\n      'font-size': this.fontSize.toFixed(1) + 'px'\n    };\n  }\n\n  refresh() {\n    super.refresh();\n\n    var $parent = this.$table.parent();\n    var top = $parent.height() / 2 - this.$table.height() / 2 + this.viewY;\n    var left = $parent.width() / 2 - this.$table.width() / 2 + this.viewX;\n    this.$table.css('margin-top', top);\n    this.$table.css('margin-left', left);\n  }\n\n  mousedown(e) {\n    super.mousedown(e);\n\n    this.dragX = e.pageX;\n    this.dragY = e.pageY;\n    this.dragging = true;\n  }\n\n  mousemove(e) {\n    super.mousemove(e);\n\n    if (this.dragging) {\n      this.viewX += e.pageX - this.dragX;\n      this.viewY += e.pageY - this.dragY;\n      this.dragX = e.pageX;\n      this.dragY = e.pageY;\n      this.refresh();\n    }\n  }\n\n  mouseup(e) {\n    super.mouseup(e);\n\n    this.dragging = false;\n  }\n\n  mousewheel(e) {\n    super.mousewheel(e);\n\n    e.preventDefault();\n    e = e.originalEvent;\n    var delta = (e.wheelDelta !== undefined && e.wheelDelta) ||\n      (e.detail !== undefined && -e.detail);\n    var weight = 1.01;\n    var ratio = delta > 0 ? 1 / weight : weight;\n    if (this.fontSize < 4 && ratio < 1) return;\n    if (this.fontSize > 40 && ratio > 1) return;\n    this.paddingV *= ratio;\n    this.paddingH *= ratio;\n    this.fontSize *= ratio;\n    this.$table.find('.mtbl-col').css(this.getCellCss());\n    this.refresh();\n  }\n\n  paintColor(sx, sy, ex, ey, colorClass, addClass) {\n    for (var i = sx; i <= ex; i++) {\n      var $row = this.$table.find('.mtbl-row').eq(i);\n      for (var j = sy; j <= ey; j++) {\n        var $col = $row.find('.mtbl-col').eq(j);\n        if (addClass) $col.addClass(colorClass);\n        else $col.removeClass(colorClass);\n      }\n    }\n  }\n\n  clearColor() {\n    this.$table.find('.mtbl-col').removeClass(Object.keys(this.colorClass).join(' '));\n  }\n\n  separate(x, y) {\n    this.$table.find('.mtbl-row').each(function (i) {\n      var $row = $(this);\n      if (i == x) {\n        $row.after($('<div class=\"mtbl-empty-row\">').attr('data-row', i))\n      }\n      $row.find('.mtbl-col').each(function (j) {\n        var $col = $(this);\n        if (j == y) {\n          $col.after($('<div class=\"mtbl-empty-col\">').attr('data-col', j));\n        }\n      });\n    });\n  }\n\n  deseparate(x, y) {\n    this.$table.find('[data-row=' + x + ']').remove();\n    this.$table.find('[data-col=' + y + ']').remove();\n  }\n\n  deseparateAll() {\n    this.$table.find('.mtbl-empty-row, .mtbl-empty-col').remove();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$table = tracer.capsule.$table = $('<div class=\"mtbl-table\">');\n  tracer.$container.append(tracer.$table);\n};\n\nmodule.exports = Array2DTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nclass ChartTracer extends Tracer {\n  static getClassName() {\n    return 'ChartTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.color = {\n      selected: 'rgb(0, 0, 255)',\n      notified: 'rgb(255, 0, 0)',\n      default: 'rgb(136, 136, 136)'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (super.setData.apply(this, arguments)) {\n      this.chart.config.data.datasets[0].data = C;\n      this.chart.update();\n      return true;\n    }\n\n    var color = [];\n    for (var i = 0; i < C.length; i++) color.push(this.color.default);\n    this.chart.config.data = {\n      labels: C.map(String),\n      datasets: [{\n        backgroundColor: color,\n        data: C\n      }]\n    };\n    this.chart.update();\n  }\n\n  _notify(s, v) {\n    this.manager.pushStep(this.capsule, {\n      type: 'notify',\n      s: s,\n      v: v\n    });\n    return this;\n  }\n\n  _denotify(s) {\n    this.manager.pushStep(this.capsule, {\n      type: 'denotify',\n      s: s\n    });\n    return this;\n  }\n\n  _select(s, e) {\n    this.manager.pushStep(this.capsule, {\n      type: 'select',\n      s: s,\n      e: e\n    });\n    return this;\n  }\n\n  _deselect(s, e) {\n    this.manager.pushStep(this.capsule, {\n      type: 'deselect',\n      s: s,\n      e: e\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'notify':\n        if (step.v !== undefined) {\n          this.chart.config.data.datasets[0].data[step.s] = step.v;\n          this.chart.config.data.labels[step.s] = step.v.toString();\n        }\n      case 'denotify':\n      case 'select':\n      case 'deselect':\n        let color = step.type == 'notify' ? this.color.notified : step.type == 'select' ? this.color.selected : this.color.default;\n        if (step.e !== undefined)\n          for (var i = step.s; i <= step.e; i++)\n            this.chart.config.data.datasets[0].backgroundColor[i] = color;\n        else\n          this.chart.config.data.datasets[0].backgroundColor[step.s] = color;\n        this.chart.update();\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  resize() {\n    super.resize();\n\n    this.chart.resize();\n  }\n\n  clear() {\n    super.clear();\n\n    const data = this.chart.config.data;\n    if (data.datasets.length) {\n      const backgroundColor = data.datasets[0].backgroundColor;\n      for (let i = 0; i < backgroundColor.length; i++) {\n        backgroundColor[i] = this.color.default;\n      }\n      this.chart.update();\n    }\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$wrapper = tracer.capsule.$wrapper = $('<canvas class=\"mchrt-chart\">');\n  tracer.$container.append(tracer.$wrapper);\n  tracer.chart = tracer.capsule.chart = new Chart(tracer.$wrapper, {\n    type: 'bar',\n    data: {\n      labels: [],\n      datasets: []\n    },\n    options: {\n      scales: {\n        yAxes: [{\n          ticks: {\n            beginAtZero: true\n          }\n        }]\n      },\n      animation: false,\n      legend: false,\n      responsive: true,\n      maintainAspectRatio: false\n    }\n  });\n};\n\nmodule.exports = ChartTracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nclass CoordinateSystemTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'CoordinateSystemTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (Tracer.prototype.setData.apply(this, arguments)) return true;\n\n    this.graph.clear();\n    var nodes = [];\n    var edges = [];\n    for (var i = 0; i < C.length; i++)\n      nodes.push({\n        id: this.n(i),\n        x: C[i][0],\n        y: C[i][1],\n        label: '' + i,\n        size: 1,\n        color: this.color.default\n      });\n    this.graph.read({\n      nodes: nodes,\n      edges: edges\n    });\n    this.s.camera.goTo({\n      x: 0,\n      y: 0,\n      angle: 0,\n      ratio: 1\n    });\n    this.refresh();\n\n    return false;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          if (this.graph.edges(edgeId)) {\n            var edge = this.graph.edges(edgeId);\n            edge.color = color;\n            this.graph.dropEdge(edgeId).addEdge(edge);\n          } else {\n            this.graph.addEdge({\n              id: this.e(step.target, step.source),\n              source: this.n(step.source),\n              target: this.n(step.target),\n              color: color,\n              size: 1\n            });\n          }\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  e(v1, v2) {\n    if (v1 > v2) {\n      var temp = v1;\n      v1 = v2;\n      v2 = temp;\n    }\n    return 'e' + v1 + '_' + v2;\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#0ff';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n\n  drawEdge(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(\n      source[prefix + 'x'],\n      source[prefix + 'y']\n    );\n    context.lineTo(\n      target[prefix + 'x'],\n      target[prefix + 'y']\n    );\n    context.stroke();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = CoordinateSystemTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass DirectedGraphTracer extends Tracer {\n  static getClassName() {\n    return 'DirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.color = {\n      selected: '#0f0',\n      visited: '#f00',\n      left: '#000',\n      default: '#888'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  _setTreeData(G, root) {\n    this.manager.pushStep(this.capsule, {\n      type: 'setTreeData',\n      arguments: arguments\n    });\n    return this;\n  }\n\n  _visit(target, source) {\n    this.manager.pushStep(this.capsule, {\n      type: 'visit',\n      target: target,\n      source: source\n    });\n    return this;\n  }\n\n  _leave(target, source) {\n    this.manager.pushStep(this.capsule, {\n      type: 'leave',\n      target: target,\n      source: source\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'setTreeData':\n        this.setTreeData.apply(this, step.arguments);\n        break;\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          var edge = this.graph.edges(edgeId);\n          edge.color = color;\n          this.graph.dropEdge(edgeId).addEdge(edge);\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  setTreeData(G, root, undirected) {\n    var tracer = this;\n\n    root = root || 0;\n    var maxDepth = -1;\n\n    var chk = new Array(G.length);\n    var getDepth = function (node, depth) {\n      if (chk[node]) throw \"the given graph is not a tree because it forms a circuit\";\n      chk[node] = true;\n      if (maxDepth < depth) maxDepth = depth;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) getDepth(i, depth + 1);\n      }\n    };\n    getDepth(root, 1);\n\n    if (this.setData(G, undirected)) return true;\n\n    var place = function (node, x, y) {\n      var temp = tracer.graph.nodes(tracer.n(node));\n      temp.x = x;\n      temp.y = y;\n    };\n\n    var wgap = 1 / (maxDepth - 1);\n    var dfs = function (node, depth, top, bottom) {\n      place(node, top + bottom, depth * wgap);\n      var children = 0;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) children++;\n      }\n      var vgap = (bottom - top) / children;\n      var cnt = 0;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) dfs(i, depth + 1, top + vgap * cnt, top + vgap * ++cnt);\n      }\n    };\n    dfs(root, 0, 0, 1);\n\n    this.refresh();\n  }\n\n  setData(G, undirected) {\n    if (super.setData.apply(this, arguments)) return true;\n\n    this.graph.clear();\n    const nodes = [];\n    const edges = [];\n    const unitAngle = 2 * Math.PI / G.length;\n    let currentAngle = 0;\n    for (let i = 0; i < G.length; i++) {\n      currentAngle += unitAngle;\n      nodes.push({\n        id: this.n(i),\n        label: '' + i,\n        x: .5 + Math.sin(currentAngle) / 2,\n        y: .5 + Math.cos(currentAngle) / 2,\n        size: 1,\n        color: this.color.default,\n        weight: 0\n      });\n\n      if (undirected) {\n        for (let j = 0; j <= i; j++) {\n          const value = G[i][j] || G[j][i];\n          if (value) {\n            edges.push({\n              id: this.e(i, j),\n              source: this.n(i),\n              target: this.n(j),\n              color: this.color.default,\n              size: 1,\n              weight: refineByType(value)\n            });\n          }\n        }\n      } else {\n        for (let j = 0; j < G[i].length; j++) {\n          if (G[i][j]) {\n            edges.push({\n              id: this.e(i, j),\n              source: this.n(i),\n              target: this.n(j),\n              color: this.color.default,\n              size: 1,\n              weight: refineByType(G[i][j])\n            });\n          }\n        }\n      }\n    }\n\n    this.graph.read({\n      nodes: nodes,\n      edges: edges\n    });\n    this.s.camera.goTo({\n      x: 0,\n      y: 0,\n      angle: 0,\n      ratio: 1\n    });\n    this.refresh();\n\n    return false;\n  }\n\n  resize() {\n    super.resize();\n\n    this.s.renderers[0].resize();\n    this.refresh();\n  }\n\n  refresh() {\n    super.refresh();\n\n    this.s.refresh();\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearGraphColor();\n    this.refresh();\n  }\n\n  clearGraphColor() {\n    var tracer = this;\n\n    this.graph.nodes().forEach(function (node) {\n      node.color = tracer.color.default;\n    });\n    this.graph.edges().forEach(function (edge) {\n      edge.color = tracer.color.default;\n    });\n  }\n\n  n(v) {\n    return 'n' + v;\n  }\n\n  e(v1, v2) {\n    return 'e' + v1 + '_' + v2;\n  }\n\n  getColor(edge, source, target, settings) {\n    var color = edge.color,\n      edgeColor = settings('edgeColor'),\n      defaultNodeColor = settings('defaultNodeColor'),\n      defaultEdgeColor = settings('defaultEdgeColor');\n    if (!color)\n      switch (edgeColor) {\n        case 'source':\n          color = source.color || defaultNodeColor;\n          break;\n        case 'target':\n          color = target.color || defaultNodeColor;\n          break;\n        default:\n          color = defaultEdgeColor;\n          break;\n      }\n\n    return color;\n  }\n\n  drawLabel(node, context, settings) {\n    var fontSize,\n      prefix = settings('prefix') || '',\n      size = node[prefix + 'size'];\n\n    if (size < settings('labelThreshold'))\n      return;\n\n    if (!node.label || typeof node.label !== 'string')\n      return;\n\n    fontSize = (settings('labelSize') === 'fixed') ?\n      settings('defaultLabelSize') :\n    settings('labelSizeRatio') * size;\n\n    context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') +\n      fontSize + 'px ' + settings('font');\n    context.fillStyle = (settings('labelColor') === 'node') ?\n      (node.color || settings('defaultNodeColor')) :\n      settings('defaultLabelColor');\n\n    context.textAlign = 'center';\n    context.fillText(\n      node.label,\n      Math.round(node[prefix + 'x']),\n      Math.round(node[prefix + 'y'] + fontSize / 3)\n    );\n  }\n\n  drawArrow(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1,\n      tSize = target[prefix + 'size'],\n      sX = source[prefix + 'x'],\n      sY = source[prefix + 'y'],\n      tX = target[prefix + 'x'],\n      tY = target[prefix + 'y'],\n      angle = Math.atan2(tY - sY, tX - sX),\n      dist = 3;\n    sX += Math.sin(angle) * dist;\n    tX += Math.sin(angle) * dist;\n    sY += -Math.cos(angle) * dist;\n    tY += -Math.cos(angle) * dist;\n    var aSize = Math.max(size * 2.5, settings('minArrowSize')),\n      d = Math.sqrt(Math.pow(tX - sX, 2) + Math.pow(tY - sY, 2)),\n      aX = sX + (tX - sX) * (d - aSize - tSize) / d,\n      aY = sY + (tY - sY) * (d - aSize - tSize) / d,\n      vX = (tX - sX) * aSize / d,\n      vY = (tY - sY) * aSize / d;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(sX, sY);\n    context.lineTo(\n      aX,\n      aY\n    );\n    context.stroke();\n\n    context.fillStyle = color;\n    context.beginPath();\n    context.moveTo(aX + vX, aY + vY);\n    context.lineTo(aX + vY * 0.6, aY - vX * 0.6);\n    context.lineTo(aX - vY * 0.6, aY + vX * 0.6);\n    context.lineTo(aX + vX, aY + vY);\n    context.closePath();\n    context.fill();\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawArrow(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#ff0';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawArrow(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s = tracer.capsule.s = new sigma({\n    renderer: {\n      container: tracer.$container[0],\n      type: 'canvas'\n    },\n    settings: {\n      minArrowSize: 8,\n      defaultEdgeType: 'arrow',\n      maxEdgeSize: 2.5,\n      labelThreshold: 4,\n      font: 'Roboto',\n      defaultLabelColor: '#fff',\n      zoomMin: 0.6,\n      zoomMax: 1.2,\n      skipErrors: true,\n      minNodeSize: .5,\n      maxNodeSize: 12,\n      labelSize: 'proportional',\n      labelSizeRatio: 1.3,\n      funcLabelsDef(node, context, settings) {\n        tracer.drawLabel(node, context, settings);\n      },\n      funcHoversDef(node, context, settings, next) {\n        tracer.drawOnHover(node, context, settings, next);\n      },\n      funcEdgesArrow(edge, source, target, context, settings) {\n        var color = tracer.getColor(edge, source, target, settings);\n        tracer.drawArrow(edge, source, target, color, context, settings);\n      }\n    }\n  });\n  sigma.plugins.dragNodes(tracer.s, tracer.s.renderers[0]);\n  tracer.graph = tracer.capsule.graph = tracer.s.graph;\n};\n\nsigma.canvas.labels.def = function (node, context, settings) {\n  var func = settings('funcLabelsDef');\n  if (func) {\n    func(node, context, settings);\n  }\n};\nsigma.canvas.hovers.def = function (node, context, settings) {\n  var func = settings('funcHoversDef');\n  if (func) {\n    func(node, context, settings);\n  }\n};\nsigma.canvas.edges.def = function (edge, source, target, context, settings) {\n  var func = settings('funcEdgesDef');\n  if (func) {\n    func(edge, source, target, context, settings);\n  }\n};\nsigma.canvas.edges.arrow = function (edge, source, target, context, settings) {\n  var func = settings('funcEdgesArrow');\n  if (func) {\n    func(edge, source, target, context, settings);\n  }\n};\n\nmodule.exports = DirectedGraphTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\nconst LogTracer = require('./log');\nconst Array1DTracer = require('./array1d');\nconst Array2DTracer = require('./array2d');\nconst ChartTracer = require('./chart');\nconst CoordinateSystemTracer = require('./coordinate_system');\nconst DirectedGraphTracer = require('./directed_graph');\nconst UndirectedGraphTracer = require('./undirected_graph');\nconst WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nconst WeightedUndirectedGraphTracer = require('./weighted_undirected_graph');\n\nmodule.exports = {\n  Tracer,\n  LogTracer,\n  Array1DTracer,\n  Array2DTracer,\n  ChartTracer,\n  CoordinateSystemTracer,\n  DirectedGraphTracer,\n  UndirectedGraphTracer,\n  WeightedDirectedGraphTracer,\n  WeightedUndirectedGraphTracer\n};","'use strict';\n\nconst Tracer = require('./tracer');\n\nclass LogTracer extends Tracer {\n  static getClassName() {\n    return 'LogTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  _print(msg) {\n    this.manager.pushStep(this.capsule, {\n      type: 'print',\n      msg: msg\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'print':\n        this.print(step.msg);\n        break;\n    }\n  }\n\n  refresh() {\n    this.scrollToEnd(Math.min(50, this.interval));\n  }\n\n  clear() {\n    super.clear();\n\n    this.$wrapper.empty();\n  }\n\n  print(message) {\n    this.$wrapper.append($('<span>').append(message + '<br/>'));\n  }\n\n  scrollToEnd(duration) {\n    this.$container.animate({\n      scrollTop: this.$container[0].scrollHeight\n    }, duration);\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$wrapper = tracer.capsule.$wrapper = $('<div class=\"wrapper\">');\n  tracer.$container.append(tracer.$wrapper);\n};\n\nmodule.exports = LogTracer;\n","'use strict';\n\nconst app = require('../../app');\n\nconst {\n  toJSON,\n  fromJSON\n} = require('../../tracer_manager/util/index');\n\nclass Tracer {\n  static getClassName() {\n    return 'Tracer';\n  }\n\n  constructor(name) {\n    this.module = this.constructor;\n\n    this.manager = app.getTracerManager();\n    this.capsule = this.manager.allocate(this);\n    $.extend(this, this.capsule);\n\n    this.setName(name);\n  }\n\n  _setData(...args) {\n    this.manager.pushStep(this.capsule, {\n      type: 'setData',\n      args: toJSON(args)\n    });\n    return this;\n  }\n\n  _clear() {\n    this.manager.pushStep(this.capsule, {\n      type: 'clear'\n    });\n    return this;\n  }\n\n  _wait(line) {\n    this.manager.newStep(line);\n    return this;\n  }\n\n  processStep(step, options) {\n    const {\n      type,\n      args\n    } = step;\n\n    switch (type) {\n      case 'setData':\n        this.setData(...fromJSON(args));\n        break;\n      case 'clear':\n        this.clear();\n        break;\n    }\n  }\n\n  setName(name) {\n    let $name;\n    if (this.isNew) {\n      $name = $('<span class=\"name\">');\n      this.$container.append($name);\n    } else {\n      $name = this.$container.find('span.name');\n    }\n    $name.text(name || this.defaultName);\n  }\n\n  setData() {\n    const data = toJSON(arguments);\n    if (!this.isNew && this.lastData === data) {\n      return true;\n    }\n    this.lastData = this.capsule.lastData = data;\n    return false;\n  }\n\n  resize() {\n  }\n\n  refresh() {\n  }\n\n  clear() {\n  }\n\n  attach(tracer) {\n    switch (tracer.module) {\n      case LogTracer:\n        this.logTracer = tracer;\n        break;\n      case ChartTracer:\n        this.chartTracer = tracer;\n        break;\n    }\n    return this;\n  }\n\n  mousedown(e) {\n  }\n\n  mousemove(e) {\n  }\n\n  mouseup(e) {\n  }\n\n  mousewheel(e) {\n  }\n}\n\nmodule.exports = Tracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nclass UndirectedGraphTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'UndirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  setTreeData(G, root) {\n    return super.setTreeData(G, root, true);\n  }\n\n  setData(G) {\n    return super.setData(G, true);\n  }\n\n  e(v1, v2) {\n    if (v1 > v2) {\n      var temp = v1;\n      v1 = v2;\n      v2 = temp;\n    }\n    return 'e' + v1 + '_' + v2;\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#0ff';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n\n  drawEdge(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(\n      source[prefix + 'x'],\n      source[prefix + 'y']\n    );\n    context.lineTo(\n      target[prefix + 'x'],\n      target[prefix + 'y']\n    );\n    context.stroke();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = UndirectedGraphTracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass WeightedDirectedGraphTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'WeightedDirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  _weight(target, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'weight',\n      target: target,\n      weight: weight\n    });\n    return this;\n  }\n\n  _visit(target, source, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'visit',\n      target: target,\n      source: source,\n      weight: weight\n    });\n    return this;\n  }\n\n  _leave(target, source, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'leave',\n      target: target,\n      source: source,\n      weight: weight\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'weight':\n        var targetNode = this.graph.nodes(this.n(step.target));\n        if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n        break;\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? step.weight === undefined ? this.color.selected : this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          var edge = this.graph.edges(edgeId);\n          edge.color = color;\n          this.graph.dropEdge(edgeId).addEdge(edge);\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearWeights();\n  }\n\n  clearWeights() {\n    this.graph.nodes().forEach(function (node) {\n      node.weight = 0;\n    });\n  }\n\n  drawEdgeWeight(edge, source, target, color, context, settings) {\n    if (source == target)\n      return;\n\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    if (size < settings('edgeLabelThreshold'))\n      return;\n\n    if (0 === settings('edgeLabelSizePowRatio'))\n      throw '\"edgeLabelSizePowRatio\" must not be 0.';\n\n    var fontSize,\n      x = (source[prefix + 'x'] + target[prefix + 'x']) / 2,\n      y = (source[prefix + 'y'] + target[prefix + 'y']) / 2,\n      dX = target[prefix + 'x'] - source[prefix + 'x'],\n      dY = target[prefix + 'y'] - source[prefix + 'y'],\n      angle = Math.atan2(dY, dX);\n\n    fontSize = (settings('edgeLabelSize') === 'fixed') ?\n      settings('defaultEdgeLabelSize') :\n    settings('defaultEdgeLabelSize') *\n    size *\n    Math.pow(size, -1 / settings('edgeLabelSizePowRatio'));\n\n    context.save();\n\n    if (edge.active) {\n      context.font = [\n        settings('activeFontStyle'),\n        fontSize + 'px',\n        settings('activeFont') || settings('font')\n      ].join(' ');\n\n      context.fillStyle = color;\n    } else {\n      context.font = [\n        settings('fontStyle'),\n        fontSize + 'px',\n        settings('font')\n      ].join(' ');\n\n      context.fillStyle = color;\n    }\n\n    context.textAlign = 'center';\n    context.textBaseline = 'alphabetic';\n\n    context.translate(x, y);\n    context.rotate(angle);\n    context.fillText(\n      edge.weight,\n      0,\n      (-size / 2) - 3\n    );\n\n    context.restore();\n  }\n\n  drawNodeWeight(node, context, settings) {\n    var fontSize,\n      prefix = settings('prefix') || '',\n      size = node[prefix + 'size'];\n\n    if (size < settings('labelThreshold'))\n      return;\n\n    fontSize = (settings('labelSize') === 'fixed') ?\n      settings('defaultLabelSize') :\n    settings('labelSizeRatio') * size;\n\n    context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') +\n      fontSize + 'px ' + settings('font');\n    context.fillStyle = (settings('labelColor') === 'node') ?\n      (node.color || settings('defaultNodeColor')) :\n      settings('defaultLabelColor');\n\n    context.textAlign = 'left';\n    context.fillText(\n      node.weight,\n      Math.round(node[prefix + 'x'] + size * 1.5),\n      Math.round(node[prefix + 'y'] + fontSize / 3)\n    );\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    edgeLabelSize: 'proportional',\n    defaultEdgeLabelSize: 20,\n    edgeLabelSizePowRatio: 0.8,\n    funcLabelsDef(node, context, settings) {\n      tracer.drawNodeWeight(node, context, settings);\n      tracer.drawLabel(node, context, settings);\n    },\n    funcHoversDef(node, context, settings) {\n      tracer.drawOnHover(node, context, settings, tracer.drawEdgeWeight);\n    },\n    funcEdgesArrow(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawArrow(edge, source, target, color, context, settings);\n      tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = WeightedDirectedGraphTracer;\n","'use strict';\n\nconst WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nconst UndirectedGraphTracer = require('./undirected_graph');\n\nclass WeightedUndirectedGraphTracer extends WeightedDirectedGraphTracer {\n  static getClassName() {\n    return 'WeightedUndirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.e = UndirectedGraphTracer.prototype.e;\n    this.drawOnHover = UndirectedGraphTracer.prototype.drawOnHover;\n    this.drawEdge = UndirectedGraphTracer.prototype.drawEdge;\n\n    if (this.isNew) initView(this);\n  }\n\n  setTreeData(G, root) {\n    return super.setTreeData(G, root, true);\n  }\n\n  setData(G) {\n    return super.setData(G, true);\n  }\n\n  drawEdgeWeight(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '';\n    if (source[prefix + 'x'] > target[prefix + 'x']) {\n      var temp = source;\n      source = target;\n      target = temp;\n    }\n    WeightedDirectedGraphTracer.prototype.drawEdgeWeight.call(this, edge, source, target, color, context, settings);\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n      tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = WeightedUndirectedGraphTracer;\n","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = (url) => {\n  return request(url, {\n    type: 'GET'\n  });\n};","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = function(url) {\n  return request(url, {\n    dataType: 'json',\n    type: 'GET'\n  });\n};","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = function(url, data) {\n  return request(url, {\n    dataType: 'json',\n    type: 'POST',\n    data: JSON.stringify(data),\n  });\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../../app');\n\nconst {\n  ajax,\n  extend\n} = $;\n\nconst defaults = {\n\n};\n\nmodule.exports = function(url, options = {}) {\n  app.setIsLoading(true);\n\n  return new RSVP.Promise((resolve, reject) => {\n    const callbacks = {\n      success(response) {\n        app.setIsLoading(false);\n        resolve(response);\n      },\n      error(reason) {\n        app.setIsLoading(false);\n        reject(reason);\n      }\n    };\n\n    const opts = extend({}, defaults, options, callbacks, {\n      url\n    });\n\n    ajax(opts);\n  });\n};","'use strict';\n\nconst app = require('../app');\nconst Toast = require('../dom/toast');\n\nconst checkLoading = () => {\n  if (app.getIsLoading()) {\n    Toast.showErrorToast('Wait until it completes loading of previous file.');\n    return true;\n  }\n  return false;\n};\n\nconst getParameterByName = (name) => {\n  const url = window.location.href;\n  const regex = new RegExp(`[?&]${name}(=([^&#]*)|&|#|$)`);\n\n  const results = regex.exec(url);\n\n  if (!results || results.length !== 3) {\n    return null;\n  }\n\n  const [, , id] = results;\n\n  return id;\n};\n\nconst getHashValue = (key)=> {\n  if (!key) return null;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n  for (let i = 0; i < params.length; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      return pair[1];\n    }\n  }\n  return null;\n};\n\nconst setHashValue = (key, value)=> {\n  if (!key || !value) return;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n\n  let found = false;\n  for (let i = 0; i < params.length && !found; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      pair[1] = value;\n      params[i] = pair.join('=');\n      found = true;\n    }\n  }\n  if (!found) {\n    params.push([key, value].join('='));\n  }\n\n  const newHash = params.join('&');\n  window.location.hash = `#${newHash}`;\n};\n\nconst removeHashValue = (key) => {\n  if (!key) return;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n\n  for (let i = 0; i < params.length; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      params.splice(i, 1);\n      break;\n    }\n  }\n\n  const newHash = params.join('&');\n  window.location.hash = `#${newHash}`;\n};\n\nconst setPath = (category, algorithm, file) => {\n  const path = category ? category + (algorithm ? `/${algorithm}` + (file ? `/${file}` : '') : '') : '';\n  setHashValue('path', path);\n};\n\nconst getPath = () => {\n  const hash = getHashValue('path');\n  if (hash) {\n    const [ category, algorithm, file ] = hash.split('/');\n    return { category, algorithm, file };\n  } else {\n    return false;\n  }\n};\n\nmodule.exports = {\n  checkLoading,\n  getParameterByName,\n  getHashValue,\n  setHashValue,\n  removeHashValue,\n  setPath,\n  getPath\n};\n","'use strict';\n\nconst loadAlgorithm = require('./load_algorithm');\nconst loadCategories = require('./load_categories');\nconst loadFile = require('./load_file');\nconst loadScratchPaper = require('./load_scratch_paper');\nconst shareScratchPaper = require('./share_scratch_paper');\nconst loadWikiList = require('./load_wiki_list');\nconst loadWiki = require('./load_wiki');\n\nmodule.exports = {\n  loadAlgorithm,\n  loadCategories,\n  loadFile,\n  loadScratchPaper,\n  shareScratchPaper,\n  loadWikiList,\n  loadWiki\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nconst {\n  getAlgorithmDir\n} = require('../utils');\n\nmodule.exports = (category, algorithm) => {\n  const dir = getAlgorithmDir(category, algorithm);\n  return getJSON(`${dir}desc.json`);\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nmodule.exports = () => {\n  return getJSON('./algorithm/category.json');\n};","'use strict';\n\nconst RSVP = require('rsvp');\n\nconst app = require('../app');\n\nconst {\n  getFileDir,\n  isScratchPaper\n} = require('../utils');\n\nconst {\n  checkLoading,\n  setPath\n} = require('./helpers');\n\nconst get = require('./ajax/get');\n\nconst loadDataAndCode = (dir) => {\n  return RSVP.hash({\n    data: get(`${dir}data.js`),\n    code: get(`${dir}code.js`)\n  });\n};\n\nconst loadFileAndUpdateContent = (dir) => {\n  app.getEditor().clearContent();\n\n  return loadDataAndCode(dir).then((content) => {\n    app.updateCachedFile(dir, content);\n    app.getEditor().setContent(content);\n  });\n};\n\nconst cachedContentExists = (cachedFile) => {\n  return cachedFile &&\n    cachedFile.data !== undefined &&\n    cachedFile.code !== undefined;\n};\n\nmodule.exports = (category, algorithm, file, explanation) => {\n  return new RSVP.Promise((resolve, reject) => {\n    if (checkLoading()) {\n      reject();\n    } else {\n      if (isScratchPaper(category)) {\n        setPath(category, app.getLoadedScratch());\n      } else {\n        setPath(category, algorithm, file);\n      }\n      $('#explanation').html(explanation);\n\n      let dir = getFileDir(category, algorithm, file);\n      app.setLastFileUsed(dir);\n      const cachedFile = app.getCachedFile(dir);\n\n      if (cachedContentExists(cachedFile)) {\n        app.getEditor().setContent(cachedFile);\n        resolve();\n      } else {\n        loadFileAndUpdateContent(dir).then(resolve, reject);\n      }\n    }\n  });\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../app');\n\nconst {\n  getFileDir\n} = require('../utils');\n\nconst getJSON = require('./ajax/get_json');\nconst loadAlgorithm = require('./load_algorithm');\n\nconst extractGistCode = (files, name) => files[`${name}.js`].content;\n\nmodule.exports = (gistID) => {\n  return new RSVP.Promise((resolve, reject) => {\n    app.setLoadedScratch(gistID);\n\n    getJSON(`https://api.github.com/gists/${gistID}`).then(({\n      files\n    }) => {\n\n      const category = 'scratch';\n      const algorithm = gistID;\n\n      loadAlgorithm(category, algorithm).then((data) => {\n\n        const algoData = extractGistCode(files, 'data');\n        const algoCode = extractGistCode(files, 'code');\n\n        // update scratch paper algo code with the loaded gist code\n        const dir = getFileDir(category, algorithm, 'scratch_paper');\n        app.updateCachedFile(dir, {\n          data: algoData,\n          code: algoCode,\n          'CREDIT.md': 'Shared by an anonymous user from http://parkjs814.github.io/AlgorithmVisualizer'\n        });\n\n        resolve({\n          category,\n          algorithm,\n          data\n        });\n      });\n    });\n  });\n\n};","'use strict';\n\nconst get = require('./ajax/get');\n\nmodule.exports = (wiki) => {\n  return get(`./AlgorithmVisualizer.wiki/${wiki}.md`);\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nmodule.exports = () => {\n  return getJSON('./wiki.json');\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../app');\n\nconst postJSON = require('./ajax/post_json');\n\nconst {\n  setPath\n} = require('./helpers');\n\nmodule.exports = () => {\n  return new RSVP.Promise((resolve, reject) => {\n\n    const {\n      dataEditor,\n      codeEditor\n    } = app.getEditor();\n\n    const gist = {\n      'description': 'temp',\n      'public': true,\n      'files': {\n        'data.js': {\n          'content': dataEditor.getValue()\n        },\n        'code.js': {\n          'content': codeEditor.getValue()\n        }\n      }\n    };\n\n    postJSON('https://api.github.com/gists', gist).then(({\n      id\n    }) => {\n      app.setLoadedScratch(id);\n      setPath('scratch', id);\n      const {\n        href\n      } = location;\n      $('#algorithm').html('Shared');\n      resolve(href);\n    });\n  });\n};","'use strict';\n\nconst TracerManager = require('./manager');\nconst Tracer = require('../module/tracer/tracer');\n\nmodule.exports = {\n\n  init() {\n    const tm = new TracerManager();\n    Tracer.prototype.manager = tm;\n    return tm;\n  }\n\n};","'use strict';\n\nconst app = require('../app');\nconst ModuleContainer = require('../dom/module_container');\nconst TopMenu = require('../dom/top_menu');\n\nconst {\n  each,\n  extend,\n  grep\n} = $;\n\nconst stepLimit = 1e6;\n\nconst TracerManager = function () {\n  this.timer = null;\n  this.pause = false;\n  this.capsules = [];\n  this.interval = 500;\n};\n\nTracerManager.prototype = {\n\n  add(tracer) {\n\n    const $container = ModuleContainer.create();\n\n    const capsule = {\n      module: tracer.module,\n      tracer,\n      allocated: true,\n      defaultName: null,\n      $container,\n      isNew: true\n    };\n\n    this.capsules.push(capsule);\n    return capsule;\n  },\n\n  allocate(newTracer) {\n    let selectedCapsule = null;\n    let count = 0;\n\n    each(this.capsules, (i, capsule) => {\n      if (capsule.module === newTracer.module) {\n        count++;\n        if (!capsule.allocated) {\n          capsule.tracer = newTracer;\n          capsule.allocated = true;\n          capsule.isNew = false;\n          selectedCapsule = capsule;\n          return false;\n        }\n      }\n    });\n\n    if (selectedCapsule === null) {\n      count++;\n      selectedCapsule = this.add(newTracer);\n    }\n\n    const className = newTracer.module.getClassName();\n    selectedCapsule.defaultName = `${className} ${count}`;\n    selectedCapsule.order = this.order++;\n    return selectedCapsule;\n  },\n\n  deallocateAll() {\n    this.order = 0;\n    this.reset();\n    each(this.capsules, (i, capsule) => {\n      capsule.allocated = false;\n    });\n  },\n\n  removeUnallocated() {\n    let changed = false;\n\n    this.capsules = grep(this.capsules, (capsule) => {\n      let removed = !capsule.allocated;\n\n      if (capsule.isNew || removed) {\n        changed = true;\n      }\n      if (removed) {\n        capsule.$container.remove();\n      }\n\n      return !removed;\n    });\n\n    if (changed) {\n      this.place();\n    }\n  },\n\n  place() {\n    const {\n      capsules\n    } = this;\n\n    each(capsules, (i, capsule) => {\n      let width = 100;\n      let height = (100 / capsules.length);\n      let top = height * capsule.order;\n\n      capsule.$container.css({\n        top: `${top}%`,\n        width: `${width}%`,\n        height: `${height}%`\n      });\n\n      capsule.tracer.resize();\n    });\n  },\n\n  resize() {\n    this.command('resize');\n  },\n\n  isPause() {\n    return this.pause;\n  },\n\n  setInterval(interval) {\n    TopMenu.setInterval(interval);\n  },\n\n  reset() {\n    this.traces = [];\n    this.traceIndex = -1;\n    this.stepCnt = 0;\n    if (this.timer) {\n      clearTimeout(this.timer);\n    }\n    this.command('clear');\n  },\n\n  pushStep(capsule, step) {\n    if (this.stepCnt++ > stepLimit) throw \"Tracer's stack overflow\";\n    let len = this.traces.length;\n    if (len == 0) len += this.newStep();\n    const last = this.traces[len - 1];\n    last.push(extend(step, {\n      capsule\n    }));\n  },\n\n  newStep(line = -1) {\n    let len = this.traces.length;\n    if (len > 0 && ~line) {\n      this.traces[len - 1].push(line);\n    }\n    return this.traces.push([]);\n  },\n\n  pauseStep() {\n    if (this.traceIndex < 0) return;\n    this.pause = true;\n    if (this.timer) {\n      clearTimeout(this.timer);\n    }\n    TopMenu.activateBtnPause();\n  },\n\n  resumeStep() {\n    this.pause = false;\n    this.step(this.traceIndex + 1);\n    TopMenu.deactivateBtnPause();\n  },\n\n  step(i, options = {}) {\n    const tracer = this;\n\n    if (isNaN(i) || i >= this.traces.length || i < 0) return;\n\n    this.traceIndex = i;\n    const trace = this.traces[i];\n    trace.forEach((step) => {\n      if (typeof step === 'number') {\n        app.getEditor().highlightLine(step);\n        return;\n      }\n      step.capsule.tracer.processStep(step, options);\n    });\n\n    if (!options.virtual) {\n      this.command('refresh');\n    }\n\n    if (this.pause) return;\n\n    this.timer = setTimeout(() => {\n      if (!tracer.nextStep(options)) {\n        TopMenu.resetTopMenuButtons();\n      }\n    }, this.interval);\n  },\n\n  prevStep(options = {}) {\n    this.command('clear');\n\n    const finalIndex = this.traceIndex - 1;\n    if (finalIndex < 0) {\n      this.traceIndex = -1;\n      this.command('refresh');\n      return false;\n    }\n\n    for (let i = 0; i < finalIndex; i++) {\n      this.step(i, extend(options, {\n        virtual: true\n      }));\n    }\n\n    this.step(finalIndex);\n    return true;\n  },\n\n  nextStep(options = {}) {\n    const finalIndex = this.traceIndex + 1;\n    if (finalIndex >= this.traces.length) {\n      this.traceIndex = this.traces.length - 1;\n      return false;\n    }\n\n    this.step(finalIndex, options);\n    return true;\n  },\n\n  visualize() {\n    this.traceIndex = -1;\n    this.resumeStep();\n  },\n\n  command(...args) {\n    const functionName = args.shift();\n    each(this.capsules, (i, capsule) => {\n      if (capsule.allocated) {\n        capsule.tracer.module.prototype[functionName].apply(capsule.tracer, args);\n      }\n    });\n  },\n\n  findOwner(container) {\n    let selectedCapsule = null;\n    each(this.capsules, (i, capsule) => {\n      if (capsule.$container[0] === container) {\n        selectedCapsule = capsule;\n        return false;\n      }\n    });\n    return selectedCapsule.tracer;\n  }\n};\n\nmodule.exports = TracerManager;\n","'use strict';\n\nconst {\n  parse\n} = JSON;\n\nconst fromJSON = (obj) => {\n  return parse(obj, (key, value) => {\n    return value === 'Infinity' ? Infinity : value;\n  });\n};\n\nmodule.exports = fromJSON;\n","'use strict';\n\nconst toJSON = require('./to_json');\nconst fromJSON = require('./from_json');\nconst refineByType = require('./refine_by_type');\n\nmodule.exports = {\n  toJSON,\n  fromJSON,\n  refineByType\n};\n","'use strict';\n\nconst refineByType = (item) => {\n  switch (typeof(item)) {\n    case 'number':\n      return refineNumber(item);\n    case 'boolean':\n      return refineBoolean(item);\n    default:\n      return refineString(item);\n  }\n};\n\nconst refineString = (str) => {\n  return str === '' ? ' ' : str;\n};\n\nconst refineNumber = (num) => {\n  return num === Infinity ? '∞' : num;\n};\n\nconst refineBoolean = (bool) => {\n  return bool ? 'T' : 'F';\n};\n\nmodule.exports = refineByType;\n","'use strict';\n\nconst {\n  stringify\n} = JSON;\n\nconst toJSON = (obj) => {\n  return stringify(obj, (key, value) => {\n    return value === Infinity ? 'Infinity' : value;\n  });\n};\n\nmodule.exports = toJSON;\n","'use strict';\n\nconst isScratchPaper = (category, algorithm) => {\n  return category == 'scratch';\n};\n\nconst getAlgorithmDir = (category, algorithm) => {\n  if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n  return `./algorithm/${category}/${algorithm}/`;\n};\n\nconst getFileDir = (category, algorithm, file) => {\n  if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n  return `./algorithm/${category}/${algorithm}/${file}/`;\n};\n\nmodule.exports = {\n  isScratchPaper,\n  getAlgorithmDir,\n  getFileDir\n};","// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = setTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    clearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        setTimeout(drainQueue, 0);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\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\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","/*!\n * @overview RSVP - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors\n * @license   Licensed under MIT license\n *            See https://raw.githubusercontent.com/tildeio/rsvp.js/master/LICENSE\n * @version   3.2.1\n */\n\n(function() {\n    \"use strict\";\n    function lib$rsvp$utils$$objectOrFunction(x) {\n      return typeof x === 'function' || (typeof x === 'object' && x !== null);\n    }\n\n    function lib$rsvp$utils$$isFunction(x) {\n      return typeof x === 'function';\n    }\n\n    function lib$rsvp$utils$$isMaybeThenable(x) {\n      return typeof x === 'object' && x !== null;\n    }\n\n    var lib$rsvp$utils$$_isArray;\n    if (!Array.isArray) {\n      lib$rsvp$utils$$_isArray = function (x) {\n        return Object.prototype.toString.call(x) === '[object Array]';\n      };\n    } else {\n      lib$rsvp$utils$$_isArray = Array.isArray;\n    }\n\n    var lib$rsvp$utils$$isArray = lib$rsvp$utils$$_isArray;\n\n    var lib$rsvp$utils$$now = Date.now || function() { return new Date().getTime(); };\n\n    function lib$rsvp$utils$$F() { }\n\n    var lib$rsvp$utils$$o_create = (Object.create || function (o) {\n      if (arguments.length > 1) {\n        throw new Error('Second argument not supported');\n      }\n      if (typeof o !== 'object') {\n        throw new TypeError('Argument must be an object');\n      }\n      lib$rsvp$utils$$F.prototype = o;\n      return new lib$rsvp$utils$$F();\n    });\n    function lib$rsvp$events$$indexOf(callbacks, callback) {\n      for (var i=0, l=callbacks.length; i<l; i++) {\n        if (callbacks[i] === callback) { return i; }\n      }\n\n      return -1;\n    }\n\n    function lib$rsvp$events$$callbacksFor(object) {\n      var callbacks = object._promiseCallbacks;\n\n      if (!callbacks) {\n        callbacks = object._promiseCallbacks = {};\n      }\n\n      return callbacks;\n    }\n\n    var lib$rsvp$events$$default = {\n\n      /**\n        `RSVP.EventTarget.mixin` extends an object with EventTarget methods. For\n        Example:\n\n        ```javascript\n        var object = {};\n\n        RSVP.EventTarget.mixin(object);\n\n        object.on('finished', function(event) {\n          // handle event\n        });\n\n        object.trigger('finished', { detail: value });\n        ```\n\n        `EventTarget.mixin` also works with prototypes:\n\n        ```javascript\n        var Person = function() {};\n        RSVP.EventTarget.mixin(Person.prototype);\n\n        var yehuda = new Person();\n        var tom = new Person();\n\n        yehuda.on('poke', function(event) {\n          console.log('Yehuda says OW');\n        });\n\n        tom.on('poke', function(event) {\n          console.log('Tom says OW');\n        });\n\n        yehuda.trigger('poke');\n        tom.trigger('poke');\n        ```\n\n        @method mixin\n        @for RSVP.EventTarget\n        @private\n        @param {Object} object object to extend with EventTarget methods\n      */\n      'mixin': function(object) {\n        object['on']      = this['on'];\n        object['off']     = this['off'];\n        object['trigger'] = this['trigger'];\n        object._promiseCallbacks = undefined;\n        return object;\n      },\n\n      /**\n        Registers a callback to be executed when `eventName` is triggered\n\n        ```javascript\n        object.on('event', function(eventInfo){\n          // handle the event\n        });\n\n        object.trigger('event');\n        ```\n\n        @method on\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName name of the event to listen for\n        @param {Function} callback function to be called when the event is triggered.\n      */\n      'on': function(eventName, callback) {\n        if (typeof callback !== 'function') {\n          throw new TypeError('Callback must be a function');\n        }\n\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks;\n\n        callbacks = allCallbacks[eventName];\n\n        if (!callbacks) {\n          callbacks = allCallbacks[eventName] = [];\n        }\n\n        if (lib$rsvp$events$$indexOf(callbacks, callback) === -1) {\n          callbacks.push(callback);\n        }\n      },\n\n      /**\n        You can use `off` to stop firing a particular callback for an event:\n\n        ```javascript\n        function doStuff() { // do stuff! }\n        object.on('stuff', doStuff);\n\n        object.trigger('stuff'); // doStuff will be called\n\n        // Unregister ONLY the doStuff callback\n        object.off('stuff', doStuff);\n        object.trigger('stuff'); // doStuff will NOT be called\n        ```\n\n        If you don't pass a `callback` argument to `off`, ALL callbacks for the\n        event will not be executed when the event fires. For example:\n\n        ```javascript\n        var callback1 = function(){};\n        var callback2 = function(){};\n\n        object.on('stuff', callback1);\n        object.on('stuff', callback2);\n\n        object.trigger('stuff'); // callback1 and callback2 will be executed.\n\n        object.off('stuff');\n        object.trigger('stuff'); // callback1 and callback2 will not be executed!\n        ```\n\n        @method off\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName event to stop listening to\n        @param {Function} callback optional argument. If given, only the function\n        given will be removed from the event's callback queue. If no `callback`\n        argument is given, all callbacks will be removed from the event's callback\n        queue.\n      */\n      'off': function(eventName, callback) {\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, index;\n\n        if (!callback) {\n          allCallbacks[eventName] = [];\n          return;\n        }\n\n        callbacks = allCallbacks[eventName];\n\n        index = lib$rsvp$events$$indexOf(callbacks, callback);\n\n        if (index !== -1) { callbacks.splice(index, 1); }\n      },\n\n      /**\n        Use `trigger` to fire custom events. For example:\n\n        ```javascript\n        object.on('foo', function(){\n          console.log('foo event happened!');\n        });\n        object.trigger('foo');\n        // 'foo event happened!' logged to the console\n        ```\n\n        You can also pass a value as a second argument to `trigger` that will be\n        passed as an argument to all event listeners for the event:\n\n        ```javascript\n        object.on('foo', function(value){\n          console.log(value.name);\n        });\n\n        object.trigger('foo', { name: 'bar' });\n        // 'bar' logged to the console\n        ```\n\n        @method trigger\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName name of the event to be triggered\n        @param {*} options optional value to be passed to any event handlers for\n        the given `eventName`\n      */\n      'trigger': function(eventName, options, label) {\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, callback;\n\n        if (callbacks = allCallbacks[eventName]) {\n          // Don't cache the callbacks.length since it may grow\n          for (var i=0; i<callbacks.length; i++) {\n            callback = callbacks[i];\n\n            callback(options, label);\n          }\n        }\n      }\n    };\n\n    var lib$rsvp$config$$config = {\n      instrument: false\n    };\n\n    lib$rsvp$events$$default['mixin'](lib$rsvp$config$$config);\n\n    function lib$rsvp$config$$configure(name, value) {\n      if (name === 'onerror') {\n        // handle for legacy users that expect the actual\n        // error to be passed to their function added via\n        // `RSVP.configure('onerror', someFunctionHere);`\n        lib$rsvp$config$$config['on']('error', value);\n        return;\n      }\n\n      if (arguments.length === 2) {\n        lib$rsvp$config$$config[name] = value;\n      } else {\n        return lib$rsvp$config$$config[name];\n      }\n    }\n\n    var lib$rsvp$instrument$$queue = [];\n\n    function lib$rsvp$instrument$$scheduleFlush() {\n      setTimeout(function() {\n        var entry;\n        for (var i = 0; i < lib$rsvp$instrument$$queue.length; i++) {\n          entry = lib$rsvp$instrument$$queue[i];\n\n          var payload = entry.payload;\n\n          payload.guid = payload.key + payload.id;\n          payload.childGuid = payload.key + payload.childId;\n          if (payload.error) {\n            payload.stack = payload.error.stack;\n          }\n\n          lib$rsvp$config$$config['trigger'](entry.name, entry.payload);\n        }\n        lib$rsvp$instrument$$queue.length = 0;\n      }, 50);\n    }\n\n    function lib$rsvp$instrument$$instrument(eventName, promise, child) {\n      if (1 === lib$rsvp$instrument$$queue.push({\n        name: eventName,\n        payload: {\n          key: promise._guidKey,\n          id:  promise._id,\n          eventName: eventName,\n          detail: promise._result,\n          childId: child && child._id,\n          label: promise._label,\n          timeStamp: lib$rsvp$utils$$now(),\n          error: lib$rsvp$config$$config[\"instrument-with-stack\"] ? new Error(promise._label) : null\n        }})) {\n          lib$rsvp$instrument$$scheduleFlush();\n        }\n      }\n    var lib$rsvp$instrument$$default = lib$rsvp$instrument$$instrument;\n    function lib$rsvp$then$$then(onFulfillment, onRejection, label) {\n      var parent = this;\n      var state = parent._state;\n\n      if (state === lib$rsvp$$internal$$FULFILLED && !onFulfillment || state === lib$rsvp$$internal$$REJECTED && !onRejection) {\n        lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, parent);\n        return parent;\n      }\n\n      parent._onError = null;\n\n      var child = new parent.constructor(lib$rsvp$$internal$$noop, label);\n      var result = parent._result;\n\n      lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, child);\n\n      if (state) {\n        var callback = arguments[state - 1];\n        lib$rsvp$config$$config.async(function(){\n          lib$rsvp$$internal$$invokeCallback(state, child, callback, result);\n        });\n      } else {\n        lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection);\n      }\n\n      return child;\n    }\n    var lib$rsvp$then$$default = lib$rsvp$then$$then;\n    function lib$rsvp$promise$resolve$$resolve(object, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n\n      if (object && typeof object === 'object' && object.constructor === Constructor) {\n        return object;\n      }\n\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      lib$rsvp$$internal$$resolve(promise, object);\n      return promise;\n    }\n    var lib$rsvp$promise$resolve$$default = lib$rsvp$promise$resolve$$resolve;\n    function lib$rsvp$enumerator$$makeSettledResult(state, position, value) {\n      if (state === lib$rsvp$$internal$$FULFILLED) {\n        return {\n          state: 'fulfilled',\n          value: value\n        };\n      } else {\n         return {\n          state: 'rejected',\n          reason: value\n        };\n      }\n    }\n\n    function lib$rsvp$enumerator$$Enumerator(Constructor, input, abortOnReject, label) {\n      this._instanceConstructor = Constructor;\n      this.promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      this._abortOnReject = abortOnReject;\n\n      if (this._validateInput(input)) {\n        this._input     = input;\n        this.length     = input.length;\n        this._remaining = input.length;\n\n        this._init();\n\n        if (this.length === 0) {\n          lib$rsvp$$internal$$fulfill(this.promise, this._result);\n        } else {\n          this.length = this.length || 0;\n          this._enumerate();\n          if (this._remaining === 0) {\n            lib$rsvp$$internal$$fulfill(this.promise, this._result);\n          }\n        }\n      } else {\n        lib$rsvp$$internal$$reject(this.promise, this._validationError());\n      }\n    }\n\n    var lib$rsvp$enumerator$$default = lib$rsvp$enumerator$$Enumerator;\n\n    lib$rsvp$enumerator$$Enumerator.prototype._validateInput = function(input) {\n      return lib$rsvp$utils$$isArray(input);\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._validationError = function() {\n      return new Error('Array Methods must be provided an Array');\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._init = function() {\n      this._result = new Array(this.length);\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._enumerate = function() {\n      var length     = this.length;\n      var promise    = this.promise;\n      var input      = this._input;\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        this._eachEntry(input[i], i);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._settleMaybeThenable = function(entry, i) {\n      var c = this._instanceConstructor;\n      var resolve = c.resolve;\n\n      if (resolve === lib$rsvp$promise$resolve$$default) {\n        var then = lib$rsvp$$internal$$getThen(entry);\n\n        if (then === lib$rsvp$then$$default &&\n            entry._state !== lib$rsvp$$internal$$PENDING) {\n          entry._onError = null;\n          this._settledAt(entry._state, i, entry._result);\n        } else if (typeof then !== 'function') {\n          this._remaining--;\n          this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n        } else if (c === lib$rsvp$promise$$default) {\n          var promise = new c(lib$rsvp$$internal$$noop);\n          lib$rsvp$$internal$$handleMaybeThenable(promise, entry, then);\n          this._willSettleAt(promise, i);\n        } else {\n          this._willSettleAt(new c(function(resolve) { resolve(entry); }), i);\n        }\n      } else {\n        this._willSettleAt(resolve(entry), i);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._eachEntry = function(entry, i) {\n      if (lib$rsvp$utils$$isMaybeThenable(entry)) {\n        this._settleMaybeThenable(entry, i);\n      } else {\n        this._remaining--;\n        this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._settledAt = function(state, i, value) {\n      var promise = this.promise;\n\n      if (promise._state === lib$rsvp$$internal$$PENDING) {\n        this._remaining--;\n\n        if (this._abortOnReject && state === lib$rsvp$$internal$$REJECTED) {\n          lib$rsvp$$internal$$reject(promise, value);\n        } else {\n          this._result[i] = this._makeResult(state, i, value);\n        }\n      }\n\n      if (this._remaining === 0) {\n        lib$rsvp$$internal$$fulfill(promise, this._result);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._makeResult = function(state, i, value) {\n      return value;\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._willSettleAt = function(promise, i) {\n      var enumerator = this;\n\n      lib$rsvp$$internal$$subscribe(promise, undefined, function(value) {\n        enumerator._settledAt(lib$rsvp$$internal$$FULFILLED, i, value);\n      }, function(reason) {\n        enumerator._settledAt(lib$rsvp$$internal$$REJECTED, i, reason);\n      });\n    };\n    function lib$rsvp$promise$all$$all(entries, label) {\n      return new lib$rsvp$enumerator$$default(this, entries, true /* abort on reject */, label).promise;\n    }\n    var lib$rsvp$promise$all$$default = lib$rsvp$promise$all$$all;\n    function lib$rsvp$promise$race$$race(entries, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n\n      if (!lib$rsvp$utils$$isArray(entries)) {\n        lib$rsvp$$internal$$reject(promise, new TypeError('You must pass an array to race.'));\n        return promise;\n      }\n\n      var length = entries.length;\n\n      function onFulfillment(value) {\n        lib$rsvp$$internal$$resolve(promise, value);\n      }\n\n      function onRejection(reason) {\n        lib$rsvp$$internal$$reject(promise, reason);\n      }\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        lib$rsvp$$internal$$subscribe(Constructor.resolve(entries[i]), undefined, onFulfillment, onRejection);\n      }\n\n      return promise;\n    }\n    var lib$rsvp$promise$race$$default = lib$rsvp$promise$race$$race;\n    function lib$rsvp$promise$reject$$reject(reason, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      lib$rsvp$$internal$$reject(promise, reason);\n      return promise;\n    }\n    var lib$rsvp$promise$reject$$default = lib$rsvp$promise$reject$$reject;\n\n    var lib$rsvp$promise$$guidKey = 'rsvp_' + lib$rsvp$utils$$now() + '-';\n    var lib$rsvp$promise$$counter = 0;\n\n    function lib$rsvp$promise$$needsResolver() {\n      throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n    }\n\n    function lib$rsvp$promise$$needsNew() {\n      throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n    }\n\n    function lib$rsvp$promise$$Promise(resolver, label) {\n      this._id = lib$rsvp$promise$$counter++;\n      this._label = label;\n      this._state = undefined;\n      this._result = undefined;\n      this._subscribers = [];\n\n      lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('created', this);\n\n      if (lib$rsvp$$internal$$noop !== resolver) {\n        typeof resolver !== 'function' && lib$rsvp$promise$$needsResolver();\n        this instanceof lib$rsvp$promise$$Promise ? lib$rsvp$$internal$$initializePromise(this, resolver) : lib$rsvp$promise$$needsNew();\n      }\n    }\n\n    var lib$rsvp$promise$$default = lib$rsvp$promise$$Promise;\n\n    // deprecated\n    lib$rsvp$promise$$Promise.cast = lib$rsvp$promise$resolve$$default;\n    lib$rsvp$promise$$Promise.all = lib$rsvp$promise$all$$default;\n    lib$rsvp$promise$$Promise.race = lib$rsvp$promise$race$$default;\n    lib$rsvp$promise$$Promise.resolve = lib$rsvp$promise$resolve$$default;\n    lib$rsvp$promise$$Promise.reject = lib$rsvp$promise$reject$$default;\n\n    lib$rsvp$promise$$Promise.prototype = {\n      constructor: lib$rsvp$promise$$Promise,\n\n      _guidKey: lib$rsvp$promise$$guidKey,\n\n      _onError: function (reason) {\n        var promise = this;\n        lib$rsvp$config$$config.after(function() {\n          if (promise._onError) {\n            lib$rsvp$config$$config['trigger']('error', reason, promise._label);\n          }\n        });\n      },\n\n    /**\n      The primary way of interacting with a promise is through its `then` method,\n      which registers callbacks to receive either a promise's eventual value or the\n      reason why the promise cannot be fulfilled.\n\n      ```js\n      findUser().then(function(user){\n        // user is available\n      }, function(reason){\n        // user is unavailable, and you are given the reason why\n      });\n      ```\n\n      Chaining\n      --------\n\n      The return value of `then` is itself a promise.  This second, 'downstream'\n      promise is resolved with the return value of the first promise's fulfillment\n      or rejection handler, or rejected if the handler throws an exception.\n\n      ```js\n      findUser().then(function (user) {\n        return user.name;\n      }, function (reason) {\n        return 'default name';\n      }).then(function (userName) {\n        // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n        // will be `'default name'`\n      });\n\n      findUser().then(function (user) {\n        throw new Error('Found user, but still unhappy');\n      }, function (reason) {\n        throw new Error('`findUser` rejected and we're unhappy');\n      }).then(function (value) {\n        // never reached\n      }, function (reason) {\n        // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n        // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n      });\n      ```\n      If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n\n      ```js\n      findUser().then(function (user) {\n        throw new PedagogicalException('Upstream error');\n      }).then(function (value) {\n        // never reached\n      }).then(function (value) {\n        // never reached\n      }, function (reason) {\n        // The `PedgagocialException` is propagated all the way down to here\n      });\n      ```\n\n      Assimilation\n      ------------\n\n      Sometimes the value you want to propagate to a downstream promise can only be\n      retrieved asynchronously. This can be achieved by returning a promise in the\n      fulfillment or rejection handler. The downstream promise will then be pending\n      until the returned promise is settled. This is called *assimilation*.\n\n      ```js\n      findUser().then(function (user) {\n        return findCommentsByAuthor(user);\n      }).then(function (comments) {\n        // The user's comments are now available\n      });\n      ```\n\n      If the assimliated promise rejects, then the downstream promise will also reject.\n\n      ```js\n      findUser().then(function (user) {\n        return findCommentsByAuthor(user);\n      }).then(function (comments) {\n        // If `findCommentsByAuthor` fulfills, we'll have the value here\n      }, function (reason) {\n        // If `findCommentsByAuthor` rejects, we'll have the reason here\n      });\n      ```\n\n      Simple Example\n      --------------\n\n      Synchronous Example\n\n      ```javascript\n      var result;\n\n      try {\n        result = findResult();\n        // success\n      } catch(reason) {\n        // failure\n      }\n      ```\n\n      Errback Example\n\n      ```js\n      findResult(function(result, err){\n        if (err) {\n          // failure\n        } else {\n          // success\n        }\n      });\n      ```\n\n      Promise Example;\n\n      ```javascript\n      findResult().then(function(result){\n        // success\n      }, function(reason){\n        // failure\n      });\n      ```\n\n      Advanced Example\n      --------------\n\n      Synchronous Example\n\n      ```javascript\n      var author, books;\n\n      try {\n        author = findAuthor();\n        books  = findBooksByAuthor(author);\n        // success\n      } catch(reason) {\n        // failure\n      }\n      ```\n\n      Errback Example\n\n      ```js\n\n      function foundBooks(books) {\n\n      }\n\n      function failure(reason) {\n\n      }\n\n      findAuthor(function(author, err){\n        if (err) {\n          failure(err);\n          // failure\n        } else {\n          try {\n            findBoooksByAuthor(author, function(books, err) {\n              if (err) {\n                failure(err);\n              } else {\n                try {\n                  foundBooks(books);\n                } catch(reason) {\n                  failure(reason);\n                }\n              }\n            });\n          } catch(error) {\n            failure(err);\n          }\n          // success\n        }\n      });\n      ```\n\n      Promise Example;\n\n      ```javascript\n      findAuthor().\n        then(findBooksByAuthor).\n        then(function(books){\n          // found books\n      }).catch(function(reason){\n        // something went wrong\n      });\n      ```\n\n      @method then\n      @param {Function} onFulfillment\n      @param {Function} onRejection\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      then: lib$rsvp$then$$default,\n\n    /**\n      `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n      as the catch block of a try/catch statement.\n\n      ```js\n      function findAuthor(){\n        throw new Error('couldn't find that author');\n      }\n\n      // synchronous\n      try {\n        findAuthor();\n      } catch(reason) {\n        // something went wrong\n      }\n\n      // async with promises\n      findAuthor().catch(function(reason){\n        // something went wrong\n      });\n      ```\n\n      @method catch\n      @param {Function} onRejection\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      'catch': function(onRejection, label) {\n        return this.then(undefined, onRejection, label);\n      },\n\n    /**\n      `finally` will be invoked regardless of the promise's fate just as native\n      try/catch/finally behaves\n\n      Synchronous example:\n\n      ```js\n      findAuthor() {\n        if (Math.random() > 0.5) {\n          throw new Error();\n        }\n        return new Author();\n      }\n\n      try {\n        return findAuthor(); // succeed or fail\n      } catch(error) {\n        return findOtherAuther();\n      } finally {\n        // always runs\n        // doesn't affect the return value\n      }\n      ```\n\n      Asynchronous example:\n\n      ```js\n      findAuthor().catch(function(reason){\n        return findOtherAuther();\n      }).finally(function(){\n        // author was either found, or not\n      });\n      ```\n\n      @method finally\n      @param {Function} callback\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      'finally': function(callback, label) {\n        var promise = this;\n        var constructor = promise.constructor;\n\n        return promise.then(function(value) {\n          return constructor.resolve(callback()).then(function() {\n            return value;\n          });\n        }, function(reason) {\n          return constructor.resolve(callback()).then(function() {\n            return constructor.reject(reason);\n          });\n        }, label);\n      }\n    };\n    function  lib$rsvp$$internal$$withOwnPromise() {\n      return new TypeError('A promises callback cannot return that same promise.');\n    }\n\n    function lib$rsvp$$internal$$noop() {}\n\n    var lib$rsvp$$internal$$PENDING   = void 0;\n    var lib$rsvp$$internal$$FULFILLED = 1;\n    var lib$rsvp$$internal$$REJECTED  = 2;\n\n    var lib$rsvp$$internal$$GET_THEN_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n    function lib$rsvp$$internal$$getThen(promise) {\n      try {\n        return promise.then;\n      } catch(error) {\n        lib$rsvp$$internal$$GET_THEN_ERROR.error = error;\n        return lib$rsvp$$internal$$GET_THEN_ERROR;\n      }\n    }\n\n    function lib$rsvp$$internal$$tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n      try {\n        then.call(value, fulfillmentHandler, rejectionHandler);\n      } catch(e) {\n        return e;\n      }\n    }\n\n    function lib$rsvp$$internal$$handleForeignThenable(promise, thenable, then) {\n      lib$rsvp$config$$config.async(function(promise) {\n        var sealed = false;\n        var error = lib$rsvp$$internal$$tryThen(then, thenable, function(value) {\n          if (sealed) { return; }\n          sealed = true;\n          if (thenable !== value) {\n            lib$rsvp$$internal$$resolve(promise, value, undefined);\n          } else {\n            lib$rsvp$$internal$$fulfill(promise, value);\n          }\n        }, function(reason) {\n          if (sealed) { return; }\n          sealed = true;\n\n          lib$rsvp$$internal$$reject(promise, reason);\n        }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n        if (!sealed && error) {\n          sealed = true;\n          lib$rsvp$$internal$$reject(promise, error);\n        }\n      }, promise);\n    }\n\n    function lib$rsvp$$internal$$handleOwnThenable(promise, thenable) {\n      if (thenable._state === lib$rsvp$$internal$$FULFILLED) {\n        lib$rsvp$$internal$$fulfill(promise, thenable._result);\n      } else if (thenable._state === lib$rsvp$$internal$$REJECTED) {\n        thenable._onError = null;\n        lib$rsvp$$internal$$reject(promise, thenable._result);\n      } else {\n        lib$rsvp$$internal$$subscribe(thenable, undefined, function(value) {\n          if (thenable !== value) {\n            lib$rsvp$$internal$$resolve(promise, value, undefined);\n          } else {\n            lib$rsvp$$internal$$fulfill(promise, value);\n          }\n        }, function(reason) {\n          lib$rsvp$$internal$$reject(promise, reason);\n        });\n      }\n    }\n\n    function lib$rsvp$$internal$$handleMaybeThenable(promise, maybeThenable, then) {\n      if (maybeThenable.constructor === promise.constructor &&\n          then === lib$rsvp$then$$default &&\n          constructor.resolve === lib$rsvp$promise$resolve$$default) {\n        lib$rsvp$$internal$$handleOwnThenable(promise, maybeThenable);\n      } else {\n        if (then === lib$rsvp$$internal$$GET_THEN_ERROR) {\n          lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$GET_THEN_ERROR.error);\n        } else if (then === undefined) {\n          lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n        } else if (lib$rsvp$utils$$isFunction(then)) {\n          lib$rsvp$$internal$$handleForeignThenable(promise, maybeThenable, then);\n        } else {\n          lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n        }\n      }\n    }\n\n    function lib$rsvp$$internal$$resolve(promise, value) {\n      if (promise === value) {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      } else if (lib$rsvp$utils$$objectOrFunction(value)) {\n        lib$rsvp$$internal$$handleMaybeThenable(promise, value, lib$rsvp$$internal$$getThen(value));\n      } else {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      }\n    }\n\n    function lib$rsvp$$internal$$publishRejection(promise) {\n      if (promise._onError) {\n        promise._onError(promise._result);\n      }\n\n      lib$rsvp$$internal$$publish(promise);\n    }\n\n    function lib$rsvp$$internal$$fulfill(promise, value) {\n      if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n\n      promise._result = value;\n      promise._state = lib$rsvp$$internal$$FULFILLED;\n\n      if (promise._subscribers.length === 0) {\n        if (lib$rsvp$config$$config.instrument) {\n          lib$rsvp$instrument$$default('fulfilled', promise);\n        }\n      } else {\n        lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, promise);\n      }\n    }\n\n    function lib$rsvp$$internal$$reject(promise, reason) {\n      if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n      promise._state = lib$rsvp$$internal$$REJECTED;\n      promise._result = reason;\n      lib$rsvp$config$$config.async(lib$rsvp$$internal$$publishRejection, promise);\n    }\n\n    function lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection) {\n      var subscribers = parent._subscribers;\n      var length = subscribers.length;\n\n      parent._onError = null;\n\n      subscribers[length] = child;\n      subscribers[length + lib$rsvp$$internal$$FULFILLED] = onFulfillment;\n      subscribers[length + lib$rsvp$$internal$$REJECTED]  = onRejection;\n\n      if (length === 0 && parent._state) {\n        lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, parent);\n      }\n    }\n\n    function lib$rsvp$$internal$$publish(promise) {\n      var subscribers = promise._subscribers;\n      var settled = promise._state;\n\n      if (lib$rsvp$config$$config.instrument) {\n        lib$rsvp$instrument$$default(settled === lib$rsvp$$internal$$FULFILLED ? 'fulfilled' : 'rejected', promise);\n      }\n\n      if (subscribers.length === 0) { return; }\n\n      var child, callback, detail = promise._result;\n\n      for (var i = 0; i < subscribers.length; i += 3) {\n        child = subscribers[i];\n        callback = subscribers[i + settled];\n\n        if (child) {\n          lib$rsvp$$internal$$invokeCallback(settled, child, callback, detail);\n        } else {\n          callback(detail);\n        }\n      }\n\n      promise._subscribers.length = 0;\n    }\n\n    function lib$rsvp$$internal$$ErrorObject() {\n      this.error = null;\n    }\n\n    var lib$rsvp$$internal$$TRY_CATCH_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n    function lib$rsvp$$internal$$tryCatch(callback, detail) {\n      try {\n        return callback(detail);\n      } catch(e) {\n        lib$rsvp$$internal$$TRY_CATCH_ERROR.error = e;\n        return lib$rsvp$$internal$$TRY_CATCH_ERROR;\n      }\n    }\n\n    function lib$rsvp$$internal$$invokeCallback(settled, promise, callback, detail) {\n      var hasCallback = lib$rsvp$utils$$isFunction(callback),\n          value, error, succeeded, failed;\n\n      if (hasCallback) {\n        value = lib$rsvp$$internal$$tryCatch(callback, detail);\n\n        if (value === lib$rsvp$$internal$$TRY_CATCH_ERROR) {\n          failed = true;\n          error = value.error;\n          value = null;\n        } else {\n          succeeded = true;\n        }\n\n        if (promise === value) {\n          lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$withOwnPromise());\n          return;\n        }\n\n      } else {\n        value = detail;\n        succeeded = true;\n      }\n\n      if (promise._state !== lib$rsvp$$internal$$PENDING) {\n        // noop\n      } else if (hasCallback && succeeded) {\n        lib$rsvp$$internal$$resolve(promise, value);\n      } else if (failed) {\n        lib$rsvp$$internal$$reject(promise, error);\n      } else if (settled === lib$rsvp$$internal$$FULFILLED) {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      } else if (settled === lib$rsvp$$internal$$REJECTED) {\n        lib$rsvp$$internal$$reject(promise, value);\n      }\n    }\n\n    function lib$rsvp$$internal$$initializePromise(promise, resolver) {\n      var resolved = false;\n      try {\n        resolver(function resolvePromise(value){\n          if (resolved) { return; }\n          resolved = true;\n          lib$rsvp$$internal$$resolve(promise, value);\n        }, function rejectPromise(reason) {\n          if (resolved) { return; }\n          resolved = true;\n          lib$rsvp$$internal$$reject(promise, reason);\n        });\n      } catch(e) {\n        lib$rsvp$$internal$$reject(promise, e);\n      }\n    }\n\n    function lib$rsvp$all$settled$$AllSettled(Constructor, entries, label) {\n      this._superConstructor(Constructor, entries, false /* don't abort on reject */, label);\n    }\n\n    lib$rsvp$all$settled$$AllSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n    lib$rsvp$all$settled$$AllSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$all$settled$$AllSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n    lib$rsvp$all$settled$$AllSettled.prototype._validationError = function() {\n      return new Error('allSettled must be called with an array');\n    };\n\n    function lib$rsvp$all$settled$$allSettled(entries, label) {\n      return new lib$rsvp$all$settled$$AllSettled(lib$rsvp$promise$$default, entries, label).promise;\n    }\n    var lib$rsvp$all$settled$$default = lib$rsvp$all$settled$$allSettled;\n    function lib$rsvp$all$$all(array, label) {\n      return lib$rsvp$promise$$default.all(array, label);\n    }\n    var lib$rsvp$all$$default = lib$rsvp$all$$all;\n    var lib$rsvp$asap$$len = 0;\n    var lib$rsvp$asap$$toString = {}.toString;\n    var lib$rsvp$asap$$vertxNext;\n    function lib$rsvp$asap$$asap(callback, arg) {\n      lib$rsvp$asap$$queue[lib$rsvp$asap$$len] = callback;\n      lib$rsvp$asap$$queue[lib$rsvp$asap$$len + 1] = arg;\n      lib$rsvp$asap$$len += 2;\n      if (lib$rsvp$asap$$len === 2) {\n        // If len is 1, that means that we need to schedule an async flush.\n        // If additional callbacks are queued before the queue is flushed, they\n        // will be processed by this flush that we are scheduling.\n        lib$rsvp$asap$$scheduleFlush();\n      }\n    }\n\n    var lib$rsvp$asap$$default = lib$rsvp$asap$$asap;\n\n    var lib$rsvp$asap$$browserWindow = (typeof window !== 'undefined') ? window : undefined;\n    var lib$rsvp$asap$$browserGlobal = lib$rsvp$asap$$browserWindow || {};\n    var lib$rsvp$asap$$BrowserMutationObserver = lib$rsvp$asap$$browserGlobal.MutationObserver || lib$rsvp$asap$$browserGlobal.WebKitMutationObserver;\n    var lib$rsvp$asap$$isNode = typeof self === 'undefined' &&\n      typeof process !== 'undefined' && {}.toString.call(process) === '[object process]';\n\n    // test for web worker but not in IE10\n    var lib$rsvp$asap$$isWorker = typeof Uint8ClampedArray !== 'undefined' &&\n      typeof importScripts !== 'undefined' &&\n      typeof MessageChannel !== 'undefined';\n\n    // node\n    function lib$rsvp$asap$$useNextTick() {\n      var nextTick = process.nextTick;\n      // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n      // setImmediate should be used instead instead\n      var version = process.versions.node.match(/^(?:(\\d+)\\.)?(?:(\\d+)\\.)?(\\*|\\d+)$/);\n      if (Array.isArray(version) && version[1] === '0' && version[2] === '10') {\n        nextTick = setImmediate;\n      }\n      return function() {\n        nextTick(lib$rsvp$asap$$flush);\n      };\n    }\n\n    // vertx\n    function lib$rsvp$asap$$useVertxTimer() {\n      return function() {\n        lib$rsvp$asap$$vertxNext(lib$rsvp$asap$$flush);\n      };\n    }\n\n    function lib$rsvp$asap$$useMutationObserver() {\n      var iterations = 0;\n      var observer = new lib$rsvp$asap$$BrowserMutationObserver(lib$rsvp$asap$$flush);\n      var node = document.createTextNode('');\n      observer.observe(node, { characterData: true });\n\n      return function() {\n        node.data = (iterations = ++iterations % 2);\n      };\n    }\n\n    // web worker\n    function lib$rsvp$asap$$useMessageChannel() {\n      var channel = new MessageChannel();\n      channel.port1.onmessage = lib$rsvp$asap$$flush;\n      return function () {\n        channel.port2.postMessage(0);\n      };\n    }\n\n    function lib$rsvp$asap$$useSetTimeout() {\n      return function() {\n        setTimeout(lib$rsvp$asap$$flush, 1);\n      };\n    }\n\n    var lib$rsvp$asap$$queue = new Array(1000);\n    function lib$rsvp$asap$$flush() {\n      for (var i = 0; i < lib$rsvp$asap$$len; i+=2) {\n        var callback = lib$rsvp$asap$$queue[i];\n        var arg = lib$rsvp$asap$$queue[i+1];\n\n        callback(arg);\n\n        lib$rsvp$asap$$queue[i] = undefined;\n        lib$rsvp$asap$$queue[i+1] = undefined;\n      }\n\n      lib$rsvp$asap$$len = 0;\n    }\n\n    function lib$rsvp$asap$$attemptVertex() {\n      try {\n        var r = require;\n        var vertx = r('vertx');\n        lib$rsvp$asap$$vertxNext = vertx.runOnLoop || vertx.runOnContext;\n        return lib$rsvp$asap$$useVertxTimer();\n      } catch(e) {\n        return lib$rsvp$asap$$useSetTimeout();\n      }\n    }\n\n    var lib$rsvp$asap$$scheduleFlush;\n    // Decide what async method to use to triggering processing of queued callbacks:\n    if (lib$rsvp$asap$$isNode) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useNextTick();\n    } else if (lib$rsvp$asap$$BrowserMutationObserver) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMutationObserver();\n    } else if (lib$rsvp$asap$$isWorker) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMessageChannel();\n    } else if (lib$rsvp$asap$$browserWindow === undefined && typeof require === 'function') {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$attemptVertex();\n    } else {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useSetTimeout();\n    }\n    function lib$rsvp$defer$$defer(label) {\n      var deferred = {};\n\n      deferred['promise'] = new lib$rsvp$promise$$default(function(resolve, reject) {\n        deferred['resolve'] = resolve;\n        deferred['reject'] = reject;\n      }, label);\n\n      return deferred;\n    }\n    var lib$rsvp$defer$$default = lib$rsvp$defer$$defer;\n    function lib$rsvp$filter$$filter(promises, filterFn, label) {\n      return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n        if (!lib$rsvp$utils$$isFunction(filterFn)) {\n          throw new TypeError(\"You must pass a function as filter's second argument.\");\n        }\n\n        var length = values.length;\n        var filtered = new Array(length);\n\n        for (var i = 0; i < length; i++) {\n          filtered[i] = filterFn(values[i]);\n        }\n\n        return lib$rsvp$promise$$default.all(filtered, label).then(function(filtered) {\n          var results = new Array(length);\n          var newLength = 0;\n\n          for (var i = 0; i < length; i++) {\n            if (filtered[i]) {\n              results[newLength] = values[i];\n              newLength++;\n            }\n          }\n\n          results.length = newLength;\n\n          return results;\n        });\n      });\n    }\n    var lib$rsvp$filter$$default = lib$rsvp$filter$$filter;\n\n    function lib$rsvp$promise$hash$$PromiseHash(Constructor, object, label) {\n      this._superConstructor(Constructor, object, true, label);\n    }\n\n    var lib$rsvp$promise$hash$$default = lib$rsvp$promise$hash$$PromiseHash;\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n    lib$rsvp$promise$hash$$PromiseHash.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$promise$hash$$PromiseHash.prototype._init = function() {\n      this._result = {};\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._validateInput = function(input) {\n      return input && typeof input === 'object';\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._validationError = function() {\n      return new Error('Promise.hash must be called with an object');\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._enumerate = function() {\n      var enumerator = this;\n      var promise    = enumerator.promise;\n      var input      = enumerator._input;\n      var results    = [];\n\n      for (var key in input) {\n        if (promise._state === lib$rsvp$$internal$$PENDING && Object.prototype.hasOwnProperty.call(input, key)) {\n          results.push({\n            position: key,\n            entry: input[key]\n          });\n        }\n      }\n\n      var length = results.length;\n      enumerator._remaining = length;\n      var result;\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        result = results[i];\n        enumerator._eachEntry(result.entry, result.position);\n      }\n    };\n\n    function lib$rsvp$hash$settled$$HashSettled(Constructor, object, label) {\n      this._superConstructor(Constructor, object, false, label);\n    }\n\n    lib$rsvp$hash$settled$$HashSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$promise$hash$$default.prototype);\n    lib$rsvp$hash$settled$$HashSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$hash$settled$$HashSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n\n    lib$rsvp$hash$settled$$HashSettled.prototype._validationError = function() {\n      return new Error('hashSettled must be called with an object');\n    };\n\n    function lib$rsvp$hash$settled$$hashSettled(object, label) {\n      return new lib$rsvp$hash$settled$$HashSettled(lib$rsvp$promise$$default, object, label).promise;\n    }\n    var lib$rsvp$hash$settled$$default = lib$rsvp$hash$settled$$hashSettled;\n    function lib$rsvp$hash$$hash(object, label) {\n      return new lib$rsvp$promise$hash$$default(lib$rsvp$promise$$default, object, label).promise;\n    }\n    var lib$rsvp$hash$$default = lib$rsvp$hash$$hash;\n    function lib$rsvp$map$$map(promises, mapFn, label) {\n      return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n        if (!lib$rsvp$utils$$isFunction(mapFn)) {\n          throw new TypeError(\"You must pass a function as map's second argument.\");\n        }\n\n        var length = values.length;\n        var results = new Array(length);\n\n        for (var i = 0; i < length; i++) {\n          results[i] = mapFn(values[i]);\n        }\n\n        return lib$rsvp$promise$$default.all(results, label);\n      });\n    }\n    var lib$rsvp$map$$default = lib$rsvp$map$$map;\n\n    function lib$rsvp$node$$Result() {\n      this.value = undefined;\n    }\n\n    var lib$rsvp$node$$ERROR = new lib$rsvp$node$$Result();\n    var lib$rsvp$node$$GET_THEN_ERROR = new lib$rsvp$node$$Result();\n\n    function lib$rsvp$node$$getThen(obj) {\n      try {\n       return obj.then;\n      } catch(error) {\n        lib$rsvp$node$$ERROR.value= error;\n        return lib$rsvp$node$$ERROR;\n      }\n    }\n\n\n    function lib$rsvp$node$$tryApply(f, s, a) {\n      try {\n        f.apply(s, a);\n      } catch(error) {\n        lib$rsvp$node$$ERROR.value = error;\n        return lib$rsvp$node$$ERROR;\n      }\n    }\n\n    function lib$rsvp$node$$makeObject(_, argumentNames) {\n      var obj = {};\n      var name;\n      var i;\n      var length = _.length;\n      var args = new Array(length);\n\n      for (var x = 0; x < length; x++) {\n        args[x] = _[x];\n      }\n\n      for (i = 0; i < argumentNames.length; i++) {\n        name = argumentNames[i];\n        obj[name] = args[i + 1];\n      }\n\n      return obj;\n    }\n\n    function lib$rsvp$node$$arrayResult(_) {\n      var length = _.length;\n      var args = new Array(length - 1);\n\n      for (var i = 1; i < length; i++) {\n        args[i - 1] = _[i];\n      }\n\n      return args;\n    }\n\n    function lib$rsvp$node$$wrapThenable(then, promise) {\n      return {\n        then: function(onFulFillment, onRejection) {\n          return then.call(promise, onFulFillment, onRejection);\n        }\n      };\n    }\n\n    function lib$rsvp$node$$denodeify(nodeFunc, options) {\n      var fn = function() {\n        var self = this;\n        var l = arguments.length;\n        var args = new Array(l + 1);\n        var arg;\n        var promiseInput = false;\n\n        for (var i = 0; i < l; ++i) {\n          arg = arguments[i];\n\n          if (!promiseInput) {\n            // TODO: clean this up\n            promiseInput = lib$rsvp$node$$needsPromiseInput(arg);\n            if (promiseInput === lib$rsvp$node$$GET_THEN_ERROR) {\n              var p = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n              lib$rsvp$$internal$$reject(p, lib$rsvp$node$$GET_THEN_ERROR.value);\n              return p;\n            } else if (promiseInput && promiseInput !== true) {\n              arg = lib$rsvp$node$$wrapThenable(promiseInput, arg);\n            }\n          }\n          args[i] = arg;\n        }\n\n        var promise = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n\n        args[l] = function(err, val) {\n          if (err)\n            lib$rsvp$$internal$$reject(promise, err);\n          else if (options === undefined)\n            lib$rsvp$$internal$$resolve(promise, val);\n          else if (options === true)\n            lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$arrayResult(arguments));\n          else if (lib$rsvp$utils$$isArray(options))\n            lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$makeObject(arguments, options));\n          else\n            lib$rsvp$$internal$$resolve(promise, val);\n        };\n\n        if (promiseInput) {\n          return lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self);\n        } else {\n          return lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self);\n        }\n      };\n\n      fn.__proto__ = nodeFunc;\n\n      return fn;\n    }\n\n    var lib$rsvp$node$$default = lib$rsvp$node$$denodeify;\n\n    function lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self) {\n      var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n      if (result === lib$rsvp$node$$ERROR) {\n        lib$rsvp$$internal$$reject(promise, result.value);\n      }\n      return promise;\n    }\n\n    function lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self){\n      return lib$rsvp$promise$$default.all(args).then(function(args){\n        var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n        if (result === lib$rsvp$node$$ERROR) {\n          lib$rsvp$$internal$$reject(promise, result.value);\n        }\n        return promise;\n      });\n    }\n\n    function lib$rsvp$node$$needsPromiseInput(arg) {\n      if (arg && typeof arg === 'object') {\n        if (arg.constructor === lib$rsvp$promise$$default) {\n          return true;\n        } else {\n          return lib$rsvp$node$$getThen(arg);\n        }\n      } else {\n        return false;\n      }\n    }\n    var lib$rsvp$platform$$platform;\n\n    /* global self */\n    if (typeof self === 'object') {\n      lib$rsvp$platform$$platform = self;\n\n    /* global global */\n    } else if (typeof global === 'object') {\n      lib$rsvp$platform$$platform = global;\n    } else {\n      throw new Error('no global: `self` or `global` found');\n    }\n\n    var lib$rsvp$platform$$default = lib$rsvp$platform$$platform;\n    function lib$rsvp$race$$race(array, label) {\n      return lib$rsvp$promise$$default.race(array, label);\n    }\n    var lib$rsvp$race$$default = lib$rsvp$race$$race;\n    function lib$rsvp$reject$$reject(reason, label) {\n      return lib$rsvp$promise$$default.reject(reason, label);\n    }\n    var lib$rsvp$reject$$default = lib$rsvp$reject$$reject;\n    function lib$rsvp$resolve$$resolve(value, label) {\n      return lib$rsvp$promise$$default.resolve(value, label);\n    }\n    var lib$rsvp$resolve$$default = lib$rsvp$resolve$$resolve;\n    function lib$rsvp$rethrow$$rethrow(reason) {\n      setTimeout(function() {\n        throw reason;\n      });\n      throw reason;\n    }\n    var lib$rsvp$rethrow$$default = lib$rsvp$rethrow$$rethrow;\n\n    // defaults\n    lib$rsvp$config$$config.async = lib$rsvp$asap$$default;\n    lib$rsvp$config$$config.after = function(cb) {\n      setTimeout(cb, 0);\n    };\n    var lib$rsvp$$cast = lib$rsvp$resolve$$default;\n    function lib$rsvp$$async(callback, arg) {\n      lib$rsvp$config$$config.async(callback, arg);\n    }\n\n    function lib$rsvp$$on() {\n      lib$rsvp$config$$config['on'].apply(lib$rsvp$config$$config, arguments);\n    }\n\n    function lib$rsvp$$off() {\n      lib$rsvp$config$$config['off'].apply(lib$rsvp$config$$config, arguments);\n    }\n\n    // Set up instrumentation through `window.__PROMISE_INTRUMENTATION__`\n    if (typeof window !== 'undefined' && typeof window['__PROMISE_INSTRUMENTATION__'] === 'object') {\n      var lib$rsvp$$callbacks = window['__PROMISE_INSTRUMENTATION__'];\n      lib$rsvp$config$$configure('instrument', true);\n      for (var lib$rsvp$$eventName in lib$rsvp$$callbacks) {\n        if (lib$rsvp$$callbacks.hasOwnProperty(lib$rsvp$$eventName)) {\n          lib$rsvp$$on(lib$rsvp$$eventName, lib$rsvp$$callbacks[lib$rsvp$$eventName]);\n        }\n      }\n    }\n\n    var lib$rsvp$umd$$RSVP = {\n      'race': lib$rsvp$race$$default,\n      'Promise': lib$rsvp$promise$$default,\n      'allSettled': lib$rsvp$all$settled$$default,\n      'hash': lib$rsvp$hash$$default,\n      'hashSettled': lib$rsvp$hash$settled$$default,\n      'denodeify': lib$rsvp$node$$default,\n      'on': lib$rsvp$$on,\n      'off': lib$rsvp$$off,\n      'map': lib$rsvp$map$$default,\n      'filter': lib$rsvp$filter$$default,\n      'resolve': lib$rsvp$resolve$$default,\n      'reject': lib$rsvp$reject$$default,\n      'all': lib$rsvp$all$$default,\n      'rethrow': lib$rsvp$rethrow$$default,\n      'defer': lib$rsvp$defer$$default,\n      'EventTarget': lib$rsvp$events$$default,\n      'configure': lib$rsvp$config$$configure,\n      'async': lib$rsvp$$async\n    };\n\n    /* global define:true module:true window: true */\n    if (typeof define === 'function' && define['amd']) {\n      define(function() { return lib$rsvp$umd$$RSVP; });\n    } else if (typeof module !== 'undefined' && module['exports']) {\n      module['exports'] = lib$rsvp$umd$$RSVP;\n    } else if (typeof lib$rsvp$platform$$default !== 'undefined') {\n      lib$rsvp$platform$$default['RSVP'] = lib$rsvp$umd$$RSVP;\n    }\n}).call(this);\n\n"]}\n"],"sourceRoot":"/source/"} \ No newline at end of file +{"version":3,"sources":["algorithm_visualizer.min.js"],"names":["e","t","n","r","s","o","u","a","require","i","f","Error","code","l","exports","call","length","1","module","_$","$","extend","cache","lastFileUsed","files","assertFileName","name","getCachedFile","updateCachedFile","updates","getLastFileUsed","setLastFileUsed","file","2","Editor","TracerManager","DOM","_require","showLoadingSlider","hideLoadingSlider","Cache","state","isLoading","editor","tracerManager","categories","loadedScratch","wikiList","initState","App","this","getIsLoading","setIsLoading","loading","getEditor","getCategories","getCategory","setCategories","updateCategory","getTracerManager","getLoadedScratch","setLoadedScratch","getWikiList","setWikiList","hasWiki","wiki","indexOf","init","setup","prototype","../dom/loading_slider","../dom/setup","../editor","../tracer_manager","./cache","3","4","app","Server","showAlgorithm","each","getAlgorithmDOM","category","subList","algorithm","append","attr","click","loadAlgorithm","then","data","addCategoryToDOM","_app$getCategory","categoryName","categorySubList","list","$category","$self","toggleClass","next","find","$algorithms","$algorithm","../app","../server","./show_algorithm","5","addFileToDOM","explanation","$file","loadFile","removeClass","addClass","requestedFile","empty","first","scroll","6","addCategories","showDescription","addFiles","showFirstAlgorithm","showRequestedAlgorithm","showWiki","./add_categories","./add_files","./show_description","./show_first_algorithm","./show_requested_algorithm","./show_wiki","7","8","create","$container","9","setupDividers","setupDocument","setupFilesBar","setupInterval","setupModuleContainer","setupTabContainer","setupSideMenu","setupTopMenu","setupWindow","stopPropagation","./setup_dividers","./setup_document","./setup_files_bar","./setup_interval","./setup_module_container","./setup_side_menu","./setup_tab_container","./setup_top_menu","./setup_window","10","_slicedToArray","sliceIterator","arr","_arr","_n","_d","_e","undefined","_s","_i","Symbol","iterator","done","push","value","err","Array","isArray","Object","TypeError","addDividerToDom","divider","_divider","vertical","$first","$second","$parent","parent","thickness","$divider","dragging","_left","css","top","bottom","left","width","x","mousedown","_ref","pageX","document","mousemove","_ref2","new_left","position","percent","Math","min","max","resize","mouseup","_top","height","right","y","_ref3","pageY","_ref4","new_top","dividers","../../app","11","on","href","test","preventDefault","window","open","alert","command","12","definitelyBigger","$wrapper","clipWidth","scrollLeft","children","get","reverse","outerWidth","$left","$right","lefter","righter","13","Toast","parseFloat","Number","minInterval","maxInterval","startInterval","stepInterval","normalize","sec","interval","message","$interval","val","step","_normalize","_normalize2","seconds","showInfoToast","../toast","14","$module_container","findOwner","mousewheel","15","sidemenu_percent","$sidemenu","$workspace","hasClass","../../server","../show_algorithm","16","17","TopMenu","select","$icon","shareScratchPaper","url","$btnRun","$btnTrace","$btnPause","$btnPrev","$btnNext","disableFlowControl","enableFlowControl","execute","console","error","showErrorToast","resetTopMenuButtons","isPause","resumeStep","pauseStep","prevStep","nextStep","../top_menu","18","19","isScratchPaper","$menu","category_name","algorithm_name","categoryObj","html","clearContent","../utils","20","_typeof","obj","constructor","key","$ul","forEach","li","prop","$type","$value","21","22","23","converter","showdown","Converter","tables","loadWiki","makeHtml","scrollTop","24","showToast","type","$toast","setTimeout","fadeOut","remove","25","flowControlBtns","setFlowControlState","isDisabled","$btn","unhighlightLine","setInterval","activateBtnPause","deactivateBtnPause","26","id","ace","edit","setOptions","enableBasicAutocompletion","enableSnippets","enableLiveAutocompletion","setTheme","session","setMode","$blockScrolling","Infinity","27","dataLines","deallocateAll","lines","split","newLines","line","replace","eval","join","visualize","removeUnallocated","executeData","algoData","executeDataAndCode","algoCode","28","_this","Range","dataEditor","createEditor","codeEditor","setData","setValue","setCode","setContent","clearData","clearCode","getValue","Executor","highlightLine","lineNumber","getSession","marker","removeMarker","addMarker","reset","../dom/top_menu","./create","./executor","29","RSVP","AppConstructor","modules","ajaxSetup","dataType","_require2","getHashValue","getParameterByName","getPath","reason","assert","appConstructor","loadCategories","_getPath","loadScratchPaper","loadWikiList","wikis","v1LoadedScratch","v2LoadedScratch","vLoadedScratch","location","protocol","host","pathname","./app","./app/constructor","./dom","./module","./server","./server/helpers","./utils","rsvp","30","Array2D","random","N","randomSorted","./array2d","31","Integer","M","D","j","map","sort","b","./integer","32","C","33","ratio","G","34","Array1D","CoordinateSystem","DirectedGraph","UndirectedGraph","WeightedDirectedGraph","WeightedUndirectedGraph","./array1d","./coordinate_system","./directed_graph","./undirected_graph","./weighted_directed_graph","./weighted_undirected_graph","35","36","37","38","39","tracers","datas","./data","./tracer","40","_classCallCheck","instance","Constructor","_possibleConstructorReturn","self","ReferenceError","_inherits","subClass","superClass","enumerable","writable","configurable","setPrototypeOf","__proto__","_get","object","property","receiver","Function","desc","getOwnPropertyDescriptor","getPrototypeOf","getter","_createClass","defineProperties","target","props","descriptor","defineProperty","protoProps","staticProps","Array2DTracer","Array1DTracer","_Array2DTracer","idx","v","options","chartTracer","newStep","capsule","sy","ey","sx","ex","processStep","41","Tracer","refineByType","_Tracer","colorClass","selected","notified","isNew","initView","manager","pushStep","pushSelectingStep","arguments","_separate","_deseparate","args","slice","shift","mode","coord","$row","$table","eq","$col","text","paintColor","deseparate","separate","viewX","viewY","paddingH","paddingV","fontSize","apply","getCellCss","refresh","clearColor","deseparateAll","padding","toFixed","font-size","dragX","dragY","originalEvent","delta","wheelDelta","detail","weight","keys","after","tracer","../../tracer_manager/util/index","42","ChartTracer","color","default","chart","config","datasets","update","labels","String","backgroundColor","toString","Chart","scales","yAxes","ticks","beginAtZero","animation","legend","responsive","maintainAspectRatio","43","DirectedGraphTracer","CoordinateSystemTracer","_DirectedGraphTracer","graph","clear","nodes","edges","label","size","read","camera","goTo","angle","visit","targetNode","visited","source","edgeId","edge","dropEdge","addEdge","logTracer","print","v1","v2","temp","node","context","settings","setLineDash","nodeIdx","substring","ends","drawEdge","prefix","strokeStyle","lineWidth","beginPath","moveTo","lineTo","stroke","defaultEdgeType","funcEdgesDef","getColor","44","root","setTreeData","undirected","maxDepth","chk","getDepth","depth","place","wgap","dfs","vgap","cnt","unitAngle","PI","currentAngle","sin","cos","_j","renderers","clearGraphColor","edgeColor","defaultNodeColor","defaultEdgeColor","font","fillStyle","textAlign","fillText","round","tSize","sX","sY","tX","tY","atan2","dist","aSize","d","sqrt","pow","aX","aY","vX","vY","closePath","fill","drawArrow","sigma","renderer","container","minArrowSize","maxEdgeSize","labelThreshold","defaultLabelColor","zoomMin","zoomMax","skipErrors","minNodeSize","maxNodeSize","labelSize","labelSizeRatio","funcLabelsDef","drawLabel","funcHoversDef","drawOnHover","funcEdgesArrow","plugins","dragNodes","canvas","def","func","hovers","arrow","45","LogTracer","UndirectedGraphTracer","WeightedDirectedGraphTracer","WeightedUndirectedGraphTracer","./chart","./log","46","msg","scrollToEnd","duration","animate","scrollHeight","47","_toConsumableArray","arr2","from","toJSON","fromJSON","allocate","setName","_len","_key","$name","defaultName","lastData","48","49","clearWeights","dX","dY","save","active","textBaseline","translate","rotate","restore","edgeLabelSize","defaultEdgeLabelSize","edgeLabelSizePowRatio","drawNodeWeight","drawEdgeWeight","50","_WeightedDirectedGrap","51","request","./request","52","53","JSON","stringify","54","ajax","defaults","Promise","resolve","reject","callbacks","success","response","opts","55","checkLoading","regex","RegExp","results","exec","_results","hash","substr","params","pair","setHashValue","found","newHash","removeHashValue","splice","setPath","path","_hash$split","_hash$split2","../dom/toast","56","./load_algorithm","./load_categories","./load_file","./load_scratch_paper","./load_wiki","./load_wiki_list","./share_scratch_paper","57","getJSON","getAlgorithmDir","dir","./ajax/get_json","58","59","getFileDir","loadDataAndCode","loadFileAndUpdateContent","content","cachedContentExists","cachedFile","./ajax/get","./helpers","60","extractGistCode","gistID","CREDIT.md","61","62","63","postJSON","_app$getEditor","gist","description","public","data.js","code.js","_location","./ajax/post_json","64","tm","../module/tracer/tracer","./manager","65","ModuleContainer","grep","stepLimit","timer","pause","capsules","add","allocated","newTracer","selectedCapsule","count","className","getClassName","order","changed","removed","traces","traceIndex","stepCnt","clearTimeout","len","last","isNaN","trace","virtual","finalIndex","functionName","../dom/module_container","66","parse","67","./from_json","./refine_by_type","./to_json","68","item","refineNumber","refineBoolean","refineString","str","num","bool","69","70","71","cleanUpNextTick","draining","currentQueue","queue","concat","queueIndex","drainQueue","timeout","run","Item","fun","array","noop","process","nextTick","title","browser","env","argv","version","versions","addListener","once","off","removeListener","removeAllListeners","emit","binding","cwd","chdir","umask","72","global","lib$rsvp$utils$$objectOrFunction","lib$rsvp$utils$$isFunction","lib$rsvp$utils$$isMaybeThenable","lib$rsvp$utils$$F","lib$rsvp$events$$indexOf","callback","lib$rsvp$events$$callbacksFor","_promiseCallbacks","lib$rsvp$config$$configure","lib$rsvp$config$$config","lib$rsvp$instrument$$scheduleFlush","entry","lib$rsvp$instrument$$queue","payload","guid","childGuid","childId","stack","lib$rsvp$instrument$$instrument","eventName","promise","child","_guidKey","_id","_result","_label","timeStamp","lib$rsvp$utils$$now","lib$rsvp$then$$then","onFulfillment","onRejection","_state","lib$rsvp$$internal$$FULFILLED","lib$rsvp$$internal$$REJECTED","instrument","lib$rsvp$instrument$$default","_onError","lib$rsvp$$internal$$noop","result","async","lib$rsvp$$internal$$invokeCallback","lib$rsvp$$internal$$subscribe","lib$rsvp$promise$resolve$$resolve","lib$rsvp$$internal$$resolve","lib$rsvp$enumerator$$makeSettledResult","lib$rsvp$enumerator$$Enumerator","input","abortOnReject","_instanceConstructor","_abortOnReject","_validateInput","_input","_remaining","_init","lib$rsvp$$internal$$fulfill","_enumerate","lib$rsvp$$internal$$reject","_validationError","lib$rsvp$promise$all$$all","entries","lib$rsvp$enumerator$$default","lib$rsvp$promise$race$$race","lib$rsvp$utils$$isArray","lib$rsvp$$internal$$PENDING","lib$rsvp$promise$reject$$reject","lib$rsvp$promise$$needsResolver","lib$rsvp$promise$$needsNew","lib$rsvp$promise$$Promise","resolver","lib$rsvp$promise$$counter","_subscribers","lib$rsvp$$internal$$initializePromise","lib$rsvp$$internal$$withOwnPromise","lib$rsvp$$internal$$getThen","lib$rsvp$$internal$$GET_THEN_ERROR","lib$rsvp$$internal$$tryThen","fulfillmentHandler","rejectionHandler","lib$rsvp$$internal$$handleForeignThenable","thenable","sealed","lib$rsvp$$internal$$handleOwnThenable","lib$rsvp$$internal$$handleMaybeThenable","maybeThenable","lib$rsvp$then$$default","lib$rsvp$promise$resolve$$default","lib$rsvp$$internal$$publishRejection","lib$rsvp$$internal$$publish","subscribers","settled","lib$rsvp$$internal$$ErrorObject","lib$rsvp$$internal$$tryCatch","lib$rsvp$$internal$$TRY_CATCH_ERROR","succeeded","failed","hasCallback","resolved","lib$rsvp$all$settled$$AllSettled","_superConstructor","lib$rsvp$all$settled$$allSettled","lib$rsvp$promise$$default","lib$rsvp$all$$all","all","lib$rsvp$asap$$asap","arg","lib$rsvp$asap$$queue","lib$rsvp$asap$$len","lib$rsvp$asap$$scheduleFlush","lib$rsvp$asap$$useNextTick","match","setImmediate","lib$rsvp$asap$$flush","lib$rsvp$asap$$useVertxTimer","lib$rsvp$asap$$vertxNext","lib$rsvp$asap$$useMutationObserver","iterations","observer","lib$rsvp$asap$$BrowserMutationObserver","createTextNode","observe","characterData","lib$rsvp$asap$$useMessageChannel","channel","MessageChannel","port1","onmessage","port2","postMessage","lib$rsvp$asap$$useSetTimeout","lib$rsvp$asap$$attemptVertex","vertx","runOnLoop","runOnContext","lib$rsvp$defer$$defer","deferred","lib$rsvp$filter$$filter","promises","filterFn","values","filtered","newLength","lib$rsvp$promise$hash$$PromiseHash","lib$rsvp$hash$settled$$HashSettled","lib$rsvp$hash$settled$$hashSettled","lib$rsvp$hash$$hash","lib$rsvp$promise$hash$$default","lib$rsvp$map$$map","mapFn","lib$rsvp$node$$Result","lib$rsvp$node$$getThen","lib$rsvp$node$$ERROR","lib$rsvp$node$$tryApply","lib$rsvp$node$$makeObject","_","argumentNames","lib$rsvp$node$$arrayResult","lib$rsvp$node$$wrapThenable","onFulFillment","lib$rsvp$node$$denodeify","nodeFunc","fn","promiseInput","lib$rsvp$node$$needsPromiseInput","lib$rsvp$node$$GET_THEN_ERROR","p","lib$rsvp$node$$handlePromiseInput","lib$rsvp$node$$handleValueInput","lib$rsvp$race$$race","race","lib$rsvp$reject$$reject","lib$rsvp$resolve$$resolve","lib$rsvp$rethrow$$rethrow","lib$rsvp$$async","lib$rsvp$$on","lib$rsvp$$off","lib$rsvp$utils$$_isArray","Date","now","getTime","lib$rsvp$utils$$o_create","lib$rsvp$events$$default","mixin","allCallbacks","index","trigger","_eachEntry","_settleMaybeThenable","c","_settledAt","_makeResult","_willSettleAt","enumerator","lib$rsvp$promise$all$$default","lib$rsvp$promise$race$$default","lib$rsvp$promise$reject$$default","lib$rsvp$promise$$guidKey","cast","catch","finally","lib$rsvp$all$settled$$default","lib$rsvp$all$$default","lib$rsvp$asap$$default","lib$rsvp$asap$$browserWindow","lib$rsvp$asap$$browserGlobal","MutationObserver","WebKitMutationObserver","lib$rsvp$asap$$isNode","lib$rsvp$asap$$isWorker","Uint8ClampedArray","importScripts","lib$rsvp$defer$$default","lib$rsvp$filter$$default","hasOwnProperty","lib$rsvp$platform$$platform","lib$rsvp$hash$settled$$default","lib$rsvp$hash$$default","lib$rsvp$map$$default","lib$rsvp$node$$default","lib$rsvp$platform$$default","lib$rsvp$race$$default","lib$rsvp$reject$$default","lib$rsvp$resolve$$default","lib$rsvp$rethrow$$default","cb","lib$rsvp$$callbacks","lib$rsvp$$eventName","lib$rsvp$umd$$RSVP","allSettled","hashSettled","denodeify","filter","rethrow","defer","EventTarget","configure","define","_process"],"mappings":"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","file":"algorithm_visualizer.min.js","sourcesContent":["/**\n * algorithm-visualizer - Algorithm Visualizer\n * @version v0.1.0\n * @author Jason Park & contributors\n * @link https://github.com/parkjs814/AlgorithmVisualizer#readme\n * @license MIT\n */\n(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})({1:[function(require,module,exports){\n'use strict';\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\nvar cache = {\n lastFileUsed: '',\n files: {}\n};\n\nvar assertFileName = function assertFileName(name) {\n if (!name) {\n throw 'Missing file name';\n }\n};\n\n/**\n * Global application cache\n */\nmodule.exports = {\n getCachedFile: function getCachedFile(name) {\n assertFileName(name);\n return cache.files[name];\n },\n updateCachedFile: function updateCachedFile(name, updates) {\n assertFileName(name);\n if (!cache.files[name]) {\n cache.files[name] = {};\n }\n extend(cache.files[name], updates);\n },\n getLastFileUsed: function getLastFileUsed() {\n return cache.lastFileUsed;\n },\n setLastFileUsed: function setLastFileUsed(file) {\n cache.lastFileUsed = file;\n }\n};\n\n},{}],2:[function(require,module,exports){\n'use strict';\n\nvar Editor = require('../editor');\nvar TracerManager = require('../tracer_manager');\nvar DOM = require('../dom/setup');\n\nvar _require = require('../dom/loading_slider');\n\nvar showLoadingSlider = _require.showLoadingSlider;\nvar hideLoadingSlider = _require.hideLoadingSlider;\n\n\nvar Cache = require('./cache');\n\nvar state = {\n isLoading: null,\n editor: null,\n tracerManager: null,\n categories: null,\n loadedScratch: null,\n wikiList: null\n};\n\nvar initState = function initState(tracerManager) {\n state.isLoading = false;\n state.editor = new Editor(tracerManager);\n state.tracerManager = tracerManager;\n state.categories = {};\n state.loadedScratch = null;\n state.wikiList = [];\n};\n\n/**\n * Global application singleton.\n */\nvar App = function App() {\n\n this.getIsLoading = function () {\n return state.isLoading;\n };\n\n this.setIsLoading = function (loading) {\n state.isLoading = loading;\n if (loading) {\n showLoadingSlider();\n } else {\n hideLoadingSlider();\n }\n };\n\n this.getEditor = function () {\n return state.editor;\n };\n\n this.getCategories = function () {\n return state.categories;\n };\n\n this.getCategory = function (name) {\n return state.categories[name];\n };\n\n this.setCategories = function (categories) {\n state.categories = categories;\n };\n\n this.updateCategory = function (name, updates) {\n $.extend(state.categories[name], updates);\n };\n\n this.getTracerManager = function () {\n return state.tracerManager;\n };\n\n this.getLoadedScratch = function () {\n return state.loadedScratch;\n };\n\n this.setLoadedScratch = function (loadedScratch) {\n state.loadedScratch = loadedScratch;\n };\n\n this.getWikiList = function () {\n return state.wikiList;\n };\n\n this.setWikiList = function (wikiList) {\n state.wikiList = wikiList;\n };\n\n this.hasWiki = function (wiki) {\n return ~state.wikiList.indexOf(wiki);\n };\n\n var tracerManager = TracerManager.init();\n\n initState(tracerManager);\n DOM.setup(tracerManager);\n};\n\nApp.prototype = Cache;\n\nmodule.exports = App;\n\n},{\"../dom/loading_slider\":7,\"../dom/setup\":9,\"../editor\":28,\"../tracer_manager\":64,\"./cache\":1}],3:[function(require,module,exports){\n'use strict';\n\n/**\n * This is the main application instance.\n * Gets populated on page load. \n */\n\nmodule.exports = {};\n\n},{}],4:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar Server = require('../server');\nvar showAlgorithm = require('./show_algorithm');\n\nvar _$ = $;\nvar each = _$.each;\n\n\nvar getAlgorithmDOM = function getAlgorithmDOM(category, subList, algorithm) {\n return $('<button class=\"indent\">').append(subList[algorithm]).attr('data-algorithm', algorithm).attr('data-category', category).click(function () {\n Server.loadAlgorithm(category, algorithm).then(function (data) {\n showAlgorithm(category, algorithm, data);\n });\n });\n\n $('#list').append($algorithm);\n};\n\nvar addCategoryToDOM = function addCategoryToDOM(category) {\n var _app$getCategory = app.getCategory(category);\n\n var categoryName = _app$getCategory.name;\n var categorySubList = _app$getCategory.list;\n\n\n var $category = $('<button class=\"category\">').append('<i class=\"fa fa-fw fa-caret-right\">').append(categoryName).attr('data-category', category);\n\n $category.click(function () {\n var $self = $(this);\n $self.toggleClass('open');\n $self.next().toggleClass('collapse');\n $self.find('i.fa').toggleClass('fa-caret-right fa-caret-down');\n });\n\n var $algorithms = $('<div class=\"algorithms collapse\">');\n $('#list').append($category).append($algorithms);\n\n each(categorySubList, function (algorithm) {\n var $algorithm = getAlgorithmDOM(category, categorySubList, algorithm);\n $algorithms.append($algorithm);\n });\n};\n\nmodule.exports = function () {\n each(app.getCategories(), addCategoryToDOM);\n};\n\n},{\"../app\":3,\"../server\":56,\"./show_algorithm\":19}],5:[function(require,module,exports){\n'use strict';\n\nvar Server = require('../server');\n\nvar _$ = $;\nvar each = _$.each;\n\n\nvar addFileToDOM = function addFileToDOM(category, algorithm, file, explanation) {\n var $file = $('<button>').append(file).attr('data-file', file).click(function () {\n Server.loadFile(category, algorithm, file, explanation);\n $('.files_bar > .wrapper > button').removeClass('active');\n $(this).addClass('active');\n });\n $('.files_bar > .wrapper').append($file);\n return $file;\n};\n\nmodule.exports = function (category, algorithm, files, requestedFile) {\n $('.files_bar > .wrapper').empty();\n\n each(files, function (file, explanation) {\n var $file = addFileToDOM(category, algorithm, file, explanation);\n if (requestedFile && requestedFile == file) $file.click();\n });\n\n if (!requestedFile) $('.files_bar > .wrapper > button').first().click();\n $('.files_bar > .wrapper').scroll();\n};\n\n},{\"../server\":56}],6:[function(require,module,exports){\n'use strict';\n\nvar showAlgorithm = require('./show_algorithm');\nvar addCategories = require('./add_categories');\nvar showDescription = require('./show_description');\nvar addFiles = require('./add_files');\nvar showFirstAlgorithm = require('./show_first_algorithm');\nvar showRequestedAlgorithm = require('./show_requested_algorithm');\nvar showWiki = require('./show_wiki');\n\nmodule.exports = {\n showAlgorithm: showAlgorithm,\n addCategories: addCategories,\n showDescription: showDescription,\n addFiles: addFiles,\n showFirstAlgorithm: showFirstAlgorithm,\n showRequestedAlgorithm: showRequestedAlgorithm,\n showWiki: showWiki\n};\n\n},{\"./add_categories\":4,\"./add_files\":5,\"./show_algorithm\":19,\"./show_description\":20,\"./show_first_algorithm\":21,\"./show_requested_algorithm\":22,\"./show_wiki\":23}],7:[function(require,module,exports){\n'use strict';\n\nvar showLoadingSlider = function showLoadingSlider() {\n $('#loading-slider').removeClass('loaded');\n};\n\nvar hideLoadingSlider = function hideLoadingSlider() {\n $('#loading-slider').addClass('loaded');\n};\n\nmodule.exports = {\n showLoadingSlider: showLoadingSlider,\n hideLoadingSlider: hideLoadingSlider\n};\n\n},{}],8:[function(require,module,exports){\n'use strict';\n\nvar create = function create() {\n var $container = $('<section class=\"module_wrapper\">');\n $('.module_container').append($container);\n return $container;\n};\n\nmodule.exports = {\n create: create\n};\n\n},{}],9:[function(require,module,exports){\n'use strict';\n\nvar setupDividers = require('./setup_dividers');\nvar setupDocument = require('./setup_document');\nvar setupFilesBar = require('./setup_files_bar');\nvar setupInterval = require('./setup_interval');\nvar setupModuleContainer = require('./setup_module_container');\nvar setupTabContainer = require('./setup_tab_container');\nvar setupSideMenu = require('./setup_side_menu');\nvar setupTopMenu = require('./setup_top_menu');\nvar setupWindow = require('./setup_window');\n\n/**\n * Initializes elements once the app loads in the DOM.\n */\nvar setup = function setup() {\n\n $('.btn input').click(function (e) {\n e.stopPropagation();\n });\n\n // dividers\n setupDividers();\n\n // document\n setupDocument();\n\n // files bar\n setupFilesBar();\n\n // interval\n setupInterval();\n\n // module container\n setupModuleContainer();\n\n // tab container\n setupTabContainer();\n\n // side menu\n setupSideMenu();\n\n // top menu\n setupTopMenu();\n\n // window\n setupWindow();\n};\n\nmodule.exports = {\n setup: setup\n};\n\n},{\"./setup_dividers\":10,\"./setup_document\":11,\"./setup_files_bar\":12,\"./setup_interval\":13,\"./setup_module_container\":14,\"./setup_side_menu\":15,\"./setup_tab_container\":16,\"./setup_top_menu\":17,\"./setup_window\":18}],10:[function(require,module,exports){\n'use strict';\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar app = require('../../app');\n\nvar addDividerToDom = function addDividerToDom(divider) {\n var _divider = _slicedToArray(divider, 3);\n\n var vertical = _divider[0];\n var $first = _divider[1];\n var $second = _divider[2];\n\n var $parent = $first.parent();\n var thickness = 5;\n\n var $divider = $('<div class=\"divider\">');\n\n var dragging = false;\n if (vertical) {\n (function () {\n $divider.addClass('vertical');\n\n var _left = -thickness / 2;\n $divider.css({\n top: 0,\n bottom: 0,\n left: _left,\n width: thickness\n });\n\n var x = void 0;\n $divider.mousedown(function (_ref) {\n var pageX = _ref.pageX;\n\n x = pageX;\n dragging = true;\n });\n\n $(document).mousemove(function (_ref2) {\n var pageX = _ref2.pageX;\n\n if (dragging) {\n var new_left = $second.position().left + pageX - x;\n var percent = new_left / $parent.width() * 100;\n percent = Math.min(90, Math.max(10, percent));\n $first.css('right', 100 - percent + '%');\n $second.css('left', percent + '%');\n x = pageX;\n app.getTracerManager().resize();\n $('.files_bar > .wrapper').scroll();\n }\n });\n\n $(document).mouseup(function (e) {\n dragging = false;\n });\n })();\n } else {\n (function () {\n\n $divider.addClass('horizontal');\n var _top = -thickness / 2;\n $divider.css({\n top: _top,\n height: thickness,\n left: 0,\n right: 0\n });\n\n var y = void 0;\n $divider.mousedown(function (_ref3) {\n var pageY = _ref3.pageY;\n\n y = pageY;\n dragging = true;\n });\n\n $(document).mousemove(function (_ref4) {\n var pageY = _ref4.pageY;\n\n if (dragging) {\n var new_top = $second.position().top + pageY - y;\n var percent = new_top / $parent.height() * 100;\n percent = Math.min(90, Math.max(10, percent));\n $first.css('bottom', 100 - percent + '%');\n $second.css('top', percent + '%');\n y = pageY;\n app.getTracerManager().resize();\n }\n });\n\n $(document).mouseup(function (e) {\n dragging = false;\n });\n })();\n }\n\n $second.append($divider);\n};\n\nmodule.exports = function () {\n var dividers = [['v', $('.sidemenu'), $('.workspace')], ['v', $('.viewer_container'), $('.editor_container')], ['h', $('.data_container'), $('.code_container')]];\n for (var i = 0; i < dividers.length; i++) {\n addDividerToDom(dividers[i]);\n }\n};\n\n},{\"../../app\":3}],11:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n $(document).on('click', 'a', function (e) {\n var href = $(this).attr('href');\n if (/^(https?:\\/\\/).+/.test(href)) {\n e.preventDefault();\n if (!window.open(href, '_blank')) {\n alert('Please allow popups for this site');\n }\n }\n });\n\n $(document).mouseup(function (e) {\n app.getTracerManager().command('mouseup', e);\n });\n};\n\n},{\"../../app\":3}],12:[function(require,module,exports){\n'use strict';\n\nvar definitelyBigger = function definitelyBigger(x, y) {\n return x > y + 2;\n};\n\nmodule.exports = function () {\n\n $('.files_bar > .btn-left').click(function () {\n var $wrapper = $('.files_bar > .wrapper');\n var clipWidth = $wrapper.width();\n var scrollLeft = $wrapper.scrollLeft();\n\n $($wrapper.children('button').get().reverse()).each(function () {\n var left = $(this).position().left;\n var right = left + $(this).outerWidth();\n if (0 > left) {\n $wrapper.scrollLeft(scrollLeft + right - clipWidth);\n return false;\n }\n });\n });\n\n $('.files_bar > .btn-right').click(function () {\n var $wrapper = $('.files_bar > .wrapper');\n var clipWidth = $wrapper.width();\n var scrollLeft = $wrapper.scrollLeft();\n\n $wrapper.children('button').each(function () {\n var left = $(this).position().left;\n var right = left + $(this).outerWidth();\n if (clipWidth < right) {\n $wrapper.scrollLeft(scrollLeft + left);\n return false;\n }\n });\n });\n\n $('.files_bar > .wrapper').scroll(function () {\n\n var $wrapper = $('.files_bar > .wrapper');\n var clipWidth = $wrapper.width();\n var $left = $wrapper.children('button:first-child');\n var $right = $wrapper.children('button:last-child');\n var left = $left.position().left;\n var right = $right.position().left + $right.outerWidth();\n\n if (definitelyBigger(0, left) && definitelyBigger(clipWidth, right)) {\n var scrollLeft = $wrapper.scrollLeft();\n $wrapper.scrollLeft(scrollLeft + clipWidth - right);\n return;\n }\n\n var lefter = definitelyBigger(0, left);\n var righter = definitelyBigger(right, clipWidth);\n $wrapper.toggleClass('shadow-left', lefter);\n $wrapper.toggleClass('shadow-right', righter);\n $('.files_bar > .btn-left').attr('disabled', !lefter);\n $('.files_bar > .btn-right').attr('disabled', !righter);\n });\n};\n\n},{}],13:[function(require,module,exports){\n'use strict';\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar app = require('../../app');\nvar Toast = require('../toast');\n\nvar parseFloat = Number.parseFloat;\n\n\nvar minInterval = 0.1;\nvar maxInterval = 10;\nvar startInterval = 0.5;\nvar stepInterval = 0.1;\n\nvar normalize = function normalize(sec) {\n\n var interval = void 0;\n var message = void 0;\n if (sec < minInterval) {\n interval = minInterval;\n message = 'Interval of ' + sec + ' seconds is too low. Setting to min allowed interval of ' + minInterval + ' second(s).';\n } else if (sec > maxInterval) {\n interval = maxInterval;\n message = 'Interval of ' + sec + ' seconds is too high. Setting to max allowed interval of ' + maxInterval + ' second(s).';\n } else {\n interval = sec;\n message = 'Interval has been set to ' + sec + ' second(s).';\n }\n\n return [interval, message];\n};\n\nmodule.exports = function () {\n\n var $interval = $('#interval');\n $interval.val(startInterval);\n $interval.attr({\n max: maxInterval,\n min: minInterval,\n step: stepInterval\n });\n\n $('#interval').on('change', function () {\n var tracerManager = app.getTracerManager();\n\n var _normalize = normalize(parseFloat($(this).val()));\n\n var _normalize2 = _slicedToArray(_normalize, 2);\n\n var seconds = _normalize2[0];\n var message = _normalize2[1];\n\n\n $(this).val(seconds);\n tracerManager.interval = seconds * 1000;\n Toast.showInfoToast(message);\n });\n};\n\n},{\"../../app\":3,\"../toast\":24}],14:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n\n var $module_container = $('.module_container');\n\n $module_container.on('mousedown', '.module_wrapper', function (e) {\n app.getTracerManager().findOwner(this).mousedown(e);\n });\n\n $module_container.on('mousemove', '.module_wrapper', function (e) {\n app.getTracerManager().findOwner(this).mousemove(e);\n });\n\n $module_container.on('DOMMouseScroll mousewheel', '.module_wrapper', function (e) {\n app.getTracerManager().findOwner(this).mousewheel(e);\n });\n};\n\n},{\"../../app\":3}],15:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\nvar Server = require('../../server');\nvar showAlgorithm = require('../show_algorithm');\n\nvar sidemenu_percent = void 0;\n\nmodule.exports = function () {\n $('#navigation').click(function () {\n var $sidemenu = $('.sidemenu');\n var $workspace = $('.workspace');\n\n $sidemenu.toggleClass('active');\n $('.nav-dropdown').toggleClass('fa-caret-down fa-caret-up');\n\n if ($sidemenu.hasClass('active')) {\n $sidemenu.css('right', 100 - sidemenu_percent + '%');\n $workspace.css('left', sidemenu_percent + '%');\n } else {\n sidemenu_percent = $workspace.position().left / $('body').width() * 100;\n $sidemenu.css('right', 0);\n $workspace.css('left', 0);\n }\n\n app.getTracerManager().resize();\n });\n\n $('#documentation').click(function () {\n $('#btn_doc').click();\n });\n\n $('#powered-by').click(function () {\n $('#powered-by-list button').toggleClass('collapse');\n });\n\n $('#scratch-paper').click(function () {\n var category = 'scratch';\n var algorithm = app.getLoadedScratch();\n Server.loadAlgorithm(category, algorithm).then(function (data) {\n showAlgorithm(category, algorithm, data);\n });\n });\n};\n\n},{\"../../app\":3,\"../../server\":56,\"../show_algorithm\":19}],16:[function(require,module,exports){\n'use strict';\n\nmodule.exports = function () {\n $('.tab_bar > button').click(function () {\n $('.tab_bar > button').removeClass('active');\n $('.tab_container > .tab').removeClass('active');\n $(this).addClass('active');\n $($(this).attr('data-target')).addClass('active');\n });\n};\n\n},{}],17:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\nvar Server = require('../../server');\nvar Toast = require('../toast');\nvar TopMenu = require('../top_menu');\n\nmodule.exports = function () {\n\n // shared\n $('#shared').mouseup(function () {\n $(this).select();\n });\n\n $('#btn_share').click(function () {\n\n var $icon = $(this).find('.fa-share');\n $icon.addClass('fa-spin fa-spin-faster');\n\n Server.shareScratchPaper().then(function (url) {\n $icon.removeClass('fa-spin fa-spin-faster');\n $('#shared').removeClass('collapse');\n $('#shared').val(url);\n Toast.showInfoToast('Shareable link is created.');\n });\n });\n\n // control\n\n var $btnRun = $('#btn_run');\n var $btnTrace = $('#btn_trace');\n var $btnPause = $('#btn_pause');\n var $btnPrev = $('#btn_prev');\n var $btnNext = $('#btn_next');\n\n // initially, control buttons are disabled\n TopMenu.disableFlowControl();\n\n $btnRun.click(function () {\n $btnTrace.click();\n $btnPause.removeClass('active');\n $btnRun.addClass('active');\n TopMenu.enableFlowControl();\n var err = app.getEditor().execute();\n if (err) {\n console.error(err);\n Toast.showErrorToast(err);\n TopMenu.resetTopMenuButtons();\n }\n });\n\n $btnPause.click(function () {\n $btnRun.toggleClass('active');\n $btnPause.toggleClass('active');\n if (app.getTracerManager().isPause()) {\n app.getTracerManager().resumeStep();\n } else {\n app.getTracerManager().pauseStep();\n }\n });\n\n $btnPrev.click(function () {\n $btnRun.removeClass('active');\n $btnPause.addClass('active');\n app.getTracerManager().pauseStep();\n app.getTracerManager().prevStep();\n });\n\n $btnNext.click(function () {\n $btnRun.removeClass('active');\n $btnPause.addClass('active');\n app.getTracerManager().pauseStep();\n app.getTracerManager().nextStep();\n });\n};\n\n},{\"../../app\":3,\"../../server\":56,\"../toast\":24,\"../top_menu\":25}],18:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n $(window).resize(function () {\n app.getTracerManager().resize();\n });\n};\n\n},{\"../../app\":3}],19:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\n\nvar _require = require('../utils');\n\nvar isScratchPaper = _require.isScratchPaper;\n\n\nvar showDescription = require('./show_description');\nvar addFiles = require('./add_files');\n\nmodule.exports = function (category, algorithm, data, requestedFile) {\n var $menu = void 0;\n var category_name = void 0;\n var algorithm_name = void 0;\n\n if (isScratchPaper(category)) {\n $menu = $('#scratch-paper');\n category_name = 'Scratch Paper';\n algorithm_name = algorithm ? 'Shared' : 'Temporary';\n } else {\n $menu = $('[data-category=\"' + category + '\"][data-algorithm=\"' + algorithm + '\"]');\n var categoryObj = app.getCategory(category);\n category_name = categoryObj.name;\n algorithm_name = categoryObj.list[algorithm];\n }\n\n $('.sidemenu button').removeClass('active');\n $menu.addClass('active');\n\n $('#category').html(category_name);\n $('#algorithm').html(algorithm_name);\n $('#tab_desc > .wrapper').empty();\n $('.files_bar > .wrapper').empty();\n $('#explanation').html('');\n\n app.setLastFileUsed(null);\n app.getEditor().clearContent();\n\n var files = data.files;\n\n\n delete data.files;\n\n showDescription(data);\n addFiles(category, algorithm, files, requestedFile);\n};\n\n},{\"../app\":3,\"../utils\":70,\"./add_files\":5,\"./show_description\":20}],20:[function(require,module,exports){\n'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol ? \"symbol\" : typeof obj; };\n\nvar isArray = Array.isArray;\nvar _$ = $;\nvar each = _$.each;\n\n\nmodule.exports = function (data) {\n var $container = $('#tab_desc > .wrapper');\n $container.empty();\n\n each(data, function (key, value) {\n\n if (key) {\n $container.append($('<h3>').html(key));\n }\n\n if (typeof value === 'string') {\n $container.append($('<p>').html(value));\n } else if (isArray(value)) {\n (function () {\n\n var $ul = $('<ul class=\"applications\">');\n $container.append($ul);\n\n value.forEach(function (li) {\n $ul.append($('<li>').html(li));\n });\n })();\n } else if ((typeof value === 'undefined' ? 'undefined' : _typeof(value)) === 'object') {\n (function () {\n\n var $ul = $('<ul class=\"complexities\">');\n $container.append($ul);\n\n each(value, function (prop) {\n var $wrapper = $('<div class=\"complexity\">');\n var $type = $('<span class=\"complexity-type\">').html(prop + ': ');\n var $value = $('<span class=\"complexity-value\">').html('' + value[prop]);\n\n $wrapper.append($type).append($value);\n\n $ul.append($('<li>').append($wrapper));\n });\n })();\n }\n });\n};\n\n},{}],21:[function(require,module,exports){\n'use strict';\n\n// click the first algorithm in the first category\n\nmodule.exports = function () {\n $('#list .category').first().click();\n $('#list .category + .algorithms > .indent').first().click();\n};\n\n},{}],22:[function(require,module,exports){\n'use strict';\n\nvar Server = require('../server');\nvar showAlgorithm = require('./show_algorithm');\n\nmodule.exports = function (category, algorithm, file) {\n $('.category[data-category=\"' + category + '\"]').click();\n Server.loadAlgorithm(category, algorithm).then(function (data) {\n showAlgorithm(category, algorithm, data, file);\n });\n};\n\n},{\"../server\":56,\"./show_algorithm\":19}],23:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar Server = require('../server');\nvar converter = new showdown.Converter({ tables: true });\n\nmodule.exports = function (wiki) {\n Server.loadWiki(wiki).then(function (data) {\n $('#tab_doc > .wrapper').html(converter.makeHtml('#' + wiki + '\\n' + data));\n $('#tab_doc').scrollTop(0);\n $('#tab_doc > .wrapper a').click(function (e) {\n var href = $(this).attr('href');\n if (app.hasWiki(href)) {\n e.preventDefault();\n module.exports(href);\n }\n });\n });\n};\n\n},{\"../app\":3,\"../server\":56}],24:[function(require,module,exports){\n'use strict';\n\nvar showToast = function showToast(data, type) {\n var $toast = $('<div class=\"toast ' + type + '\">').append(data);\n\n $('.toast_container').append($toast);\n setTimeout(function () {\n $toast.fadeOut(function () {\n $toast.remove();\n });\n }, 3000);\n};\n\nvar showErrorToast = function showErrorToast(err) {\n showToast(err, 'error');\n};\n\nvar showInfoToast = function showInfoToast(err) {\n showToast(err, 'info');\n};\n\nmodule.exports = {\n showErrorToast: showErrorToast,\n showInfoToast: showInfoToast\n};\n\n},{}],25:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\n\nvar flowControlBtns = [$('#btn_pause'), $('#btn_prev'), $('#btn_next')];\nvar setFlowControlState = function setFlowControlState(isDisabled) {\n flowControlBtns.forEach(function ($btn) {\n return $btn.attr('disabled', isDisabled);\n });\n};\n\nvar enableFlowControl = function enableFlowControl() {\n setFlowControlState(false);\n};\n\nvar disableFlowControl = function disableFlowControl() {\n setFlowControlState(true);\n};\n\nvar resetTopMenuButtons = function resetTopMenuButtons() {\n $('.top-menu-buttons button').removeClass('active');\n disableFlowControl();\n app.getEditor().unhighlightLine();\n};\n\nvar setInterval = function setInterval(val) {\n $('#interval').val(interval);\n};\n\nvar activateBtnPause = function activateBtnPause() {\n $('#btn_pause').addClass('active');\n};\n\nvar deactivateBtnPause = function deactivateBtnPause() {\n $('#btn_pause').removeClass('active');\n};\n\nmodule.exports = {\n enableFlowControl: enableFlowControl,\n disableFlowControl: disableFlowControl,\n resetTopMenuButtons: resetTopMenuButtons,\n setInterval: setInterval,\n activateBtnPause: activateBtnPause,\n deactivateBtnPause: deactivateBtnPause\n};\n\n},{\"../app\":3}],26:[function(require,module,exports){\n'use strict';\n\nmodule.exports = function (id) {\n var editor = ace.edit(id);\n\n editor.setOptions({\n enableBasicAutocompletion: true,\n enableSnippets: true,\n enableLiveAutocompletion: true\n });\n\n editor.setTheme('ace/theme/tomorrow_night_eighties');\n editor.session.setMode('ace/mode/javascript');\n editor.$blockScrolling = Infinity;\n\n return editor;\n};\n\n},{}],27:[function(require,module,exports){\n'use strict';\n\nvar execute = function execute(tracerManager, code, dataLines) {\n // all modules available to eval are obtained from window\n try {\n (function () {\n tracerManager.deallocateAll();\n var lines = code.split('\\n');\n var newLines = [];\n lines.forEach(function (line, i) {\n newLines.push(line.replace(/(.+\\. *_wait *)(\\( *\\))/g, '$1(' + (i - dataLines) + ')'));\n });\n eval(newLines.join('\\n'));\n tracerManager.visualize();\n })();\n } catch (err) {\n return err;\n } finally {\n tracerManager.removeUnallocated();\n }\n};\n\nvar executeData = function executeData(tracerManager, algoData) {\n return execute(tracerManager, algoData);\n};\n\nvar executeDataAndCode = function executeDataAndCode(tracerManager, algoData, algoCode) {\n var dataLines = algoData.split('\\n').length;\n return execute(tracerManager, algoData + '\\n' + algoCode, dataLines);\n};\n\nmodule.exports = {\n executeData: executeData,\n executeDataAndCode: executeDataAndCode\n};\n\n},{}],28:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar createEditor = require('./create');\nvar Executor = require('./executor');\nvar TopMenu = require('../dom/top_menu');\n\nfunction Editor(tracerManager) {\n var _this = this;\n\n if (!tracerManager) {\n throw 'Cannot create Editor. Missing the tracerManager';\n }\n\n ace.require('ace/ext/language_tools');\n var Range = ace.require(\"ace/range\").Range;\n\n this.dataEditor = createEditor('data');\n this.codeEditor = createEditor('code');\n\n // Setting data\n\n this.setData = function (data) {\n _this.dataEditor.setValue(data, -1);\n };\n\n this.setCode = function (code) {\n _this.codeEditor.setValue(code, -1);\n };\n\n this.setContent = function (_ref) {\n var data = _ref.data;\n var code = _ref.code;\n\n _this.setData(data);\n _this.setCode(code);\n };\n\n // Clearing data\n\n this.clearData = function () {\n _this.dataEditor.setValue('');\n };\n\n this.clearCode = function () {\n _this.codeEditor.setValue('');\n };\n\n this.clearContent = function () {\n _this.clearData();\n _this.clearCode();\n };\n\n this.execute = function () {\n var data = _this.dataEditor.getValue();\n var code = _this.codeEditor.getValue();\n return Executor.executeDataAndCode(tracerManager, data, code);\n };\n\n this.highlightLine = function (lineNumber) {\n var session = _this.codeEditor.getSession();\n if (_this.marker) session.removeMarker(_this.marker);\n _this.marker = session.addMarker(new Range(lineNumber, 0, lineNumber, Infinity), \"executing\", \"line\", true);\n };\n\n this.unhighlightLine = function () {\n var session = _this.codeEditor.getSession();\n if (_this.marker) session.removeMarker(_this.marker);\n };\n\n // listeners\n\n this.dataEditor.on('change', function () {\n var data = _this.dataEditor.getValue();\n var lastFileUsed = app.getLastFileUsed();\n if (lastFileUsed) {\n app.updateCachedFile(lastFileUsed, {\n data: data\n });\n }\n Executor.executeData(tracerManager, data);\n TopMenu.resetTopMenuButtons();\n });\n\n this.codeEditor.on('change', function () {\n var code = _this.codeEditor.getValue();\n var lastFileUsed = app.getLastFileUsed();\n if (lastFileUsed) {\n app.updateCachedFile(lastFileUsed, {\n code: code\n });\n }\n tracerManager.reset();\n TopMenu.resetTopMenuButtons();\n });\n}\n\nmodule.exports = Editor;\n\n},{\"../app\":3,\"../dom/top_menu\":25,\"./create\":26,\"./executor\":27}],29:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('./app');\nvar AppConstructor = require('./app/constructor');\nvar DOM = require('./dom');\nvar Server = require('./server');\n\nvar modules = require('./module');\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\n$.ajaxSetup({\n cache: false,\n dataType: 'text'\n});\n\nvar _require = require('./utils');\n\nvar isScratchPaper = _require.isScratchPaper;\n\nvar _require2 = require('./server/helpers');\n\nvar getHashValue = _require2.getHashValue;\nvar getParameterByName = _require2.getParameterByName;\nvar getPath = _require2.getPath;\n\n// set global promise error handler\n\nRSVP.on('error', function (reason) {\n console.assert(false, reason);\n});\n\n$(function () {\n\n // initialize the application and attach in to the instance module\n var appConstructor = new AppConstructor();\n extend(true, app, appConstructor);\n\n // load modules to the global scope so they can be evaled\n extend(true, window, modules);\n\n Server.loadCategories().then(function (data) {\n app.setCategories(data);\n DOM.addCategories();\n\n // determine if the app is loading a pre-existing scratch-pad\n // or the home page\n\n var _getPath = getPath();\n\n var category = _getPath.category;\n var algorithm = _getPath.algorithm;\n var file = _getPath.file;\n\n if (isScratchPaper(category)) {\n if (algorithm) {\n Server.loadScratchPaper(algorithm).then(function (_ref) {\n var category = _ref.category;\n var algorithm = _ref.algorithm;\n var data = _ref.data;\n\n DOM.showAlgorithm(category, algorithm, data);\n });\n } else {\n Server.loadAlgorithm(category).then(function (data) {\n DOM.showAlgorithm(category, null, data);\n });\n }\n } else if (category && algorithm) {\n DOM.showRequestedAlgorithm(category, algorithm, file);\n } else {\n DOM.showFirstAlgorithm();\n }\n });\n\n Server.loadWikiList().then(function (data) {\n app.setWikiList(data.wikis);\n\n DOM.showWiki('Tracer');\n });\n\n var v1LoadedScratch = getHashValue('scratch-paper');\n var v2LoadedScratch = getParameterByName('scratch-paper');\n var vLoadedScratch = v1LoadedScratch || v2LoadedScratch;\n if (vLoadedScratch) {\n window.location.href = window.location.protocol + '//' + window.location.host + window.location.pathname + '#path=scratch/' + vLoadedScratch;\n }\n});\n\n},{\"./app\":3,\"./app/constructor\":2,\"./dom\":6,\"./module\":39,\"./server\":56,\"./server/helpers\":55,\"./utils\":70,\"rsvp\":72}],30:[function(require,module,exports){\n'use strict';\n\nvar Array2D = require('./array2d');\n\nvar random = function random(N, min, max) {\n return Array2D.random(1, N, min, max)[0];\n};\n\nvar randomSorted = function randomSorted(N, min, max) {\n return Array2D.randomSorted(1, N, min, max)[0];\n};\n\nmodule.exports = {\n random: random,\n randomSorted: randomSorted\n};\n\n},{\"./array2d\":31}],31:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, M, min, max) {\n if (!N) N = 10;\n if (!M) M = 10;\n if (min === undefined) min = 1;\n if (max === undefined) max = 9;\n var D = [];\n for (var i = 0; i < N; i++) {\n D.push([]);\n for (var j = 0; j < M; j++) {\n D[i].push(Integer.random(min, max));\n }\n }\n return D;\n};\n\nvar randomSorted = function randomSorted(N, M, min, max) {\n return random(N, M, min, max).map(function (arr) {\n return arr.sort(function (a, b) {\n return a - b;\n });\n });\n};\n\nmodule.exports = {\n random: random,\n randomSorted: randomSorted\n};\n\n},{\"./integer\":35}],32:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, min, max) {\n if (!N) N = 7;\n if (!min) min = 1;\n if (!max) max = 10;\n var C = new Array(N);\n for (var i = 0; i < N; i++) {\n C[i] = new Array(2);\n }for (var i = 0; i < N; i++) {\n for (var j = 0; j < C[i].length; j++) {\n C[i][j] = Integer.random(min, max);\n }\n }return C;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{\"./integer\":35}],33:[function(require,module,exports){\n'use strict';\n\nvar random = function random(N, ratio) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n for (var j = 0; j < N; j++) {\n if (i != j) {\n G[i][j] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],34:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\nvar Array1D = require('./array1d');\nvar Array2D = require('./array2d');\nvar CoordinateSystem = require('./coordinate_system');\nvar DirectedGraph = require('./directed_graph');\nvar UndirectedGraph = require('./undirected_graph');\nvar WeightedDirectedGraph = require('./weighted_directed_graph');\nvar WeightedUndirectedGraph = require('./weighted_undirected_graph');\n\nmodule.exports = {\n Integer: Integer,\n Array1D: Array1D,\n Array2D: Array2D,\n CoordinateSystem: CoordinateSystem,\n DirectedGraph: DirectedGraph,\n UndirectedGraph: UndirectedGraph,\n WeightedDirectedGraph: WeightedDirectedGraph,\n WeightedUndirectedGraph: WeightedUndirectedGraph\n};\n\n},{\"./array1d\":30,\"./array2d\":31,\"./coordinate_system\":32,\"./directed_graph\":33,\"./integer\":35,\"./undirected_graph\":36,\"./weighted_directed_graph\":37,\"./weighted_undirected_graph\":38}],35:[function(require,module,exports){\n'use strict';\n\nvar random = function random(min, max) {\n return (Math.random() * (max - min + 1) | 0) + min;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],36:[function(require,module,exports){\n'use strict';\n\nvar random = function random(N, ratio) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n }for (var i = 0; i < N; i++) {\n for (var j = 0; j < N; j++) {\n if (i > j) {\n G[i][j] = G[j][i] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],37:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, ratio, min, max) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n if (!min) min = 1;\n if (!max) max = 5;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n for (var j = 0; j < N; j++) {\n if (i != j && (Math.random() * (1 / ratio) | 0) == 0) {\n G[i][j] = Integer.random(min, max);\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{\"./integer\":35}],38:[function(require,module,exports){\n'use strict';\n\nvar Integer = require('./integer');\n\nvar random = function random(N, ratio, min, max) {\n if (!N) N = 5;\n if (!ratio) ratio = .3;\n if (!min) min = 1;\n if (!max) max = 5;\n var G = new Array(N);\n for (var i = 0; i < N; i++) {\n G[i] = new Array(N);\n }for (var i = 0; i < N; i++) {\n for (var j = 0; j < N; j++) {\n if (i > j && (Math.random() * (1 / ratio) | 0) == 0) {\n G[i][j] = G[j][i] = Integer.random(min, max);\n }\n }\n }\n return G;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{\"./integer\":35}],39:[function(require,module,exports){\n'use strict';\n\nvar tracers = require('./tracer');\nvar datas = require('./data');\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\nmodule.exports = extend(true, {}, tracers, datas);\n\n},{\"./data\":34,\"./tracer\":45}],40:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Array2DTracer = require('./array2d');\n\nvar Array1DTracer = function (_Array2DTracer) {\n _inherits(Array1DTracer, _Array2DTracer);\n\n _createClass(Array1DTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'Array1DTracer';\n }\n }]);\n\n function Array1DTracer(name) {\n _classCallCheck(this, Array1DTracer);\n\n return _possibleConstructorReturn(this, Object.getPrototypeOf(Array1DTracer).call(this, name));\n }\n\n _createClass(Array1DTracer, [{\n key: '_notify',\n value: function _notify(idx, v) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_notify', this).call(this, 0, idx, v);\n return this;\n }\n }, {\n key: '_denotify',\n value: function _denotify(idx) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_denotify', this).call(this, 0, idx);\n return this;\n }\n }, {\n key: '_select',\n value: function _select(s, e) {\n if (e === undefined) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_select', this).call(this, 0, s);\n } else {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_selectRow', this).call(this, 0, s, e);\n }\n return this;\n }\n }, {\n key: '_deselect',\n value: function _deselect(s, e) {\n if (e === undefined) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_deselect', this).call(this, 0, s);\n } else {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), '_deselectRow', this).call(this, 0, s, e);\n }\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n _get(Object.getPrototypeOf(Array1DTracer.prototype), 'processStep', this).call(this, step, options);\n if (this.chartTracer) {\n var newStep = $.extend(true, {}, step);\n newStep.capsule = this.chartTracer.capsule;\n newStep.s = newStep.sy;\n newStep.e = newStep.ey;\n if (newStep.s === undefined) newStep.s = newStep.y;\n delete newStep.x;\n delete newStep.y;\n delete newStep.sx;\n delete newStep.sy;\n delete newStep.ex;\n delete newStep.ey;\n this.chartTracer.processStep(newStep, options);\n }\n }\n }, {\n key: 'setData',\n value: function setData(D) {\n return _get(Object.getPrototypeOf(Array1DTracer.prototype), 'setData', this).call(this, [D]);\n }\n }]);\n\n return Array1DTracer;\n}(Array2DTracer);\n\nmodule.exports = Array1DTracer;\n\n},{\"./array2d\":41}],41:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar refineByType = _require.refineByType;\n\nvar Array2DTracer = function (_Tracer) {\n _inherits(Array2DTracer, _Tracer);\n\n _createClass(Array2DTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'Array2DTracer';\n }\n }]);\n\n function Array2DTracer(name) {\n _classCallCheck(this, Array2DTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(Array2DTracer).call(this, name));\n\n _this.colorClass = {\n selected: 'selected',\n notified: 'notified'\n };\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(Array2DTracer, [{\n key: '_notify',\n value: function _notify(x, y, v) {\n this.manager.pushStep(this.capsule, {\n type: 'notify',\n x: x,\n y: y,\n v: v\n });\n return this;\n }\n }, {\n key: '_denotify',\n value: function _denotify(x, y) {\n this.manager.pushStep(this.capsule, {\n type: 'denotify',\n x: x,\n y: y\n });\n return this;\n }\n }, {\n key: '_select',\n value: function _select(sx, sy, ex, ey) {\n this.pushSelectingStep('select', null, arguments);\n return this;\n }\n }, {\n key: '_selectRow',\n value: function _selectRow(x, sy, ey) {\n this.pushSelectingStep('select', 'row', arguments);\n return this;\n }\n }, {\n key: '_selectCol',\n value: function _selectCol(y, sx, ex) {\n this.pushSelectingStep('select', 'col', arguments);\n return this;\n }\n }, {\n key: '_deselect',\n value: function _deselect(sx, sy, ex, ey) {\n this.pushSelectingStep('deselect', null, arguments);\n return this;\n }\n }, {\n key: '_deselectRow',\n value: function _deselectRow(x, sy, ey) {\n this.pushSelectingStep('deselect', 'row', arguments);\n return this;\n }\n }, {\n key: '_deselectCol',\n value: function _deselectCol(y, sx, ex) {\n this.pushSelectingStep('deselect', 'col', arguments);\n return this;\n }\n }, {\n key: '_separate',\n value: function _separate(x, y) {\n this.manager.pushStep(this.capsule, {\n type: 'separate',\n x: x,\n y: y\n });\n return this;\n }\n }, {\n key: '_separateRow',\n value: function _separateRow(x) {\n this._separate(x, -1);\n return this;\n }\n }, {\n key: '_separateCol',\n value: function _separateCol(y) {\n this._separate(-1, y);\n return this;\n }\n }, {\n key: '_deseparate',\n value: function _deseparate(x, y) {\n this.manager.pushStep(this.capsule, {\n type: 'deseparate',\n x: x,\n y: y\n });\n return this;\n }\n }, {\n key: '_deseparateRow',\n value: function _deseparateRow(x) {\n this._deseparate(x, -1);\n return this;\n }\n }, {\n key: '_deseparateCol',\n value: function _deseparateCol(y) {\n this._deseparate(-1, y);\n return this;\n }\n }, {\n key: 'pushSelectingStep',\n value: function pushSelectingStep() {\n var args = Array.prototype.slice.call(arguments);\n var type = args.shift();\n var mode = args.shift();\n args = Array.prototype.slice.call(args.shift());\n var coord;\n switch (mode) {\n case 'row':\n coord = {\n x: args[0],\n sy: args[1],\n ey: args[2]\n };\n break;\n case 'col':\n coord = {\n y: args[0],\n sx: args[1],\n ex: args[2]\n };\n break;\n default:\n if (args[2] === undefined && args[3] === undefined) {\n coord = {\n x: args[0],\n y: args[1]\n };\n } else {\n coord = {\n sx: args[0],\n sy: args[1],\n ex: args[2],\n ey: args[3]\n };\n }\n }\n var step = {\n type: type\n };\n $.extend(step, coord);\n this.manager.pushStep(this.capsule, step);\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'notify':\n if (step.v !== undefined) {\n var $row = this.$table.find('.mtbl-row').eq(step.x);\n var $col = $row.find('.mtbl-col').eq(step.y);\n $col.text(refineByType(step.v));\n }\n case 'denotify':\n case 'select':\n case 'deselect':\n var colorClass = step.type == 'select' || step.type == 'deselect' ? this.colorClass.selected : this.colorClass.notified;\n var addClass = step.type == 'select' || step.type == 'notify';\n var sx = step.sx;\n var sy = step.sy;\n var ex = step.ex;\n var ey = step.ey;\n if (sx === undefined) sx = step.x;\n if (sy === undefined) sy = step.y;\n if (ex === undefined) ex = step.x;\n if (ey === undefined) ey = step.y;\n this.paintColor(sx, sy, ex, ey, colorClass, addClass);\n break;\n case 'separate':\n this.deseparate(step.x, step.y);\n this.separate(step.x, step.y);\n break;\n case 'deseparate':\n this.deseparate(step.x, step.y);\n break;\n default:\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'setData',\n value: function setData(D) {\n this.viewX = this.viewY = 0;\n this.paddingH = 6;\n this.paddingV = 3;\n this.fontSize = 16;\n\n if (_get(Object.getPrototypeOf(Array2DTracer.prototype), 'setData', this).apply(this, arguments)) {\n this.$table.find('.mtbl-row').each(function (i) {\n $(this).find('.mtbl-col').each(function (j) {\n $(this).text(refineByType(D[i][j]));\n });\n });\n return true;\n }\n\n this.$table.empty();\n for (var i = 0; i < D.length; i++) {\n var $row = $('<div class=\"mtbl-row\">');\n this.$table.append($row);\n for (var j = 0; j < D[i].length; j++) {\n var $col = $('<div class=\"mtbl-col\">').css(this.getCellCss()).text(refineByType(D[i][j]));\n $row.append($col);\n }\n }\n this.resize();\n\n return false;\n }\n }, {\n key: 'resize',\n value: function resize() {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'resize', this).call(this);\n\n this.refresh();\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'clear', this).call(this);\n\n this.clearColor();\n this.deseparateAll();\n }\n }, {\n key: 'getCellCss',\n value: function getCellCss() {\n return {\n padding: this.paddingV.toFixed(1) + 'px ' + this.paddingH.toFixed(1) + 'px',\n 'font-size': this.fontSize.toFixed(1) + 'px'\n };\n }\n }, {\n key: 'refresh',\n value: function refresh() {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'refresh', this).call(this);\n\n var $parent = this.$table.parent();\n var top = $parent.height() / 2 - this.$table.height() / 2 + this.viewY;\n var left = $parent.width() / 2 - this.$table.width() / 2 + this.viewX;\n this.$table.css('margin-top', top);\n this.$table.css('margin-left', left);\n }\n }, {\n key: 'mousedown',\n value: function mousedown(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mousedown', this).call(this, e);\n\n this.dragX = e.pageX;\n this.dragY = e.pageY;\n this.dragging = true;\n }\n }, {\n key: 'mousemove',\n value: function mousemove(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mousemove', this).call(this, e);\n\n if (this.dragging) {\n this.viewX += e.pageX - this.dragX;\n this.viewY += e.pageY - this.dragY;\n this.dragX = e.pageX;\n this.dragY = e.pageY;\n this.refresh();\n }\n }\n }, {\n key: 'mouseup',\n value: function mouseup(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mouseup', this).call(this, e);\n\n this.dragging = false;\n }\n }, {\n key: 'mousewheel',\n value: function mousewheel(e) {\n _get(Object.getPrototypeOf(Array2DTracer.prototype), 'mousewheel', this).call(this, e);\n\n e.preventDefault();\n e = e.originalEvent;\n var delta = e.wheelDelta !== undefined && e.wheelDelta || e.detail !== undefined && -e.detail;\n var weight = 1.01;\n var ratio = delta > 0 ? 1 / weight : weight;\n if (this.fontSize < 4 && ratio < 1) return;\n if (this.fontSize > 40 && ratio > 1) return;\n this.paddingV *= ratio;\n this.paddingH *= ratio;\n this.fontSize *= ratio;\n this.$table.find('.mtbl-col').css(this.getCellCss());\n this.refresh();\n }\n }, {\n key: 'paintColor',\n value: function paintColor(sx, sy, ex, ey, colorClass, addClass) {\n for (var i = sx; i <= ex; i++) {\n var $row = this.$table.find('.mtbl-row').eq(i);\n for (var j = sy; j <= ey; j++) {\n var $col = $row.find('.mtbl-col').eq(j);\n if (addClass) $col.addClass(colorClass);else $col.removeClass(colorClass);\n }\n }\n }\n }, {\n key: 'clearColor',\n value: function clearColor() {\n this.$table.find('.mtbl-col').removeClass(Object.keys(this.colorClass).join(' '));\n }\n }, {\n key: 'separate',\n value: function separate(x, y) {\n this.$table.find('.mtbl-row').each(function (i) {\n var $row = $(this);\n if (i == x) {\n $row.after($('<div class=\"mtbl-empty-row\">').attr('data-row', i));\n }\n $row.find('.mtbl-col').each(function (j) {\n var $col = $(this);\n if (j == y) {\n $col.after($('<div class=\"mtbl-empty-col\">').attr('data-col', j));\n }\n });\n });\n }\n }, {\n key: 'deseparate',\n value: function deseparate(x, y) {\n this.$table.find('[data-row=' + x + ']').remove();\n this.$table.find('[data-col=' + y + ']').remove();\n }\n }, {\n key: 'deseparateAll',\n value: function deseparateAll() {\n this.$table.find('.mtbl-empty-row, .mtbl-empty-col').remove();\n }\n }]);\n\n return Array2DTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.$table = tracer.capsule.$table = $('<div class=\"mtbl-table\">');\n tracer.$container.append(tracer.$table);\n};\n\nmodule.exports = Array2DTracer;\n\n},{\"../../tracer_manager/util/index\":67,\"./tracer\":47}],42:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar ChartTracer = function (_Tracer) {\n _inherits(ChartTracer, _Tracer);\n\n _createClass(ChartTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'ChartTracer';\n }\n }]);\n\n function ChartTracer(name) {\n _classCallCheck(this, ChartTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(ChartTracer).call(this, name));\n\n _this.color = {\n selected: 'rgb(0, 0, 255)',\n notified: 'rgb(255, 0, 0)',\n default: 'rgb(136, 136, 136)'\n };\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(ChartTracer, [{\n key: 'setData',\n value: function setData(C) {\n if (_get(Object.getPrototypeOf(ChartTracer.prototype), 'setData', this).apply(this, arguments)) {\n this.chart.config.data.datasets[0].data = C;\n this.chart.update();\n return true;\n }\n\n var color = [];\n for (var i = 0; i < C.length; i++) {\n color.push(this.color.default);\n }this.chart.config.data = {\n labels: C.map(String),\n datasets: [{\n backgroundColor: color,\n data: C\n }]\n };\n this.chart.update();\n }\n }, {\n key: '_notify',\n value: function _notify(s, v) {\n this.manager.pushStep(this.capsule, {\n type: 'notify',\n s: s,\n v: v\n });\n return this;\n }\n }, {\n key: '_denotify',\n value: function _denotify(s) {\n this.manager.pushStep(this.capsule, {\n type: 'denotify',\n s: s\n });\n return this;\n }\n }, {\n key: '_select',\n value: function _select(s, e) {\n this.manager.pushStep(this.capsule, {\n type: 'select',\n s: s,\n e: e\n });\n return this;\n }\n }, {\n key: '_deselect',\n value: function _deselect(s, e) {\n this.manager.pushStep(this.capsule, {\n type: 'deselect',\n s: s,\n e: e\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'notify':\n if (step.v !== undefined) {\n this.chart.config.data.datasets[0].data[step.s] = step.v;\n this.chart.config.data.labels[step.s] = step.v.toString();\n }\n case 'denotify':\n case 'select':\n case 'deselect':\n var color = step.type == 'notify' ? this.color.notified : step.type == 'select' ? this.color.selected : this.color.default;\n if (step.e !== undefined) for (var i = step.s; i <= step.e; i++) {\n this.chart.config.data.datasets[0].backgroundColor[i] = color;\n } else this.chart.config.data.datasets[0].backgroundColor[step.s] = color;\n this.chart.update();\n break;\n default:\n _get(Object.getPrototypeOf(ChartTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'resize',\n value: function resize() {\n _get(Object.getPrototypeOf(ChartTracer.prototype), 'resize', this).call(this);\n\n this.chart.resize();\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(ChartTracer.prototype), 'clear', this).call(this);\n\n var data = this.chart.config.data;\n if (data.datasets.length) {\n var backgroundColor = data.datasets[0].backgroundColor;\n for (var i = 0; i < backgroundColor.length; i++) {\n backgroundColor[i] = this.color.default;\n }\n this.chart.update();\n }\n }\n }]);\n\n return ChartTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.$wrapper = tracer.capsule.$wrapper = $('<canvas class=\"mchrt-chart\">');\n tracer.$container.append(tracer.$wrapper);\n tracer.chart = tracer.capsule.chart = new Chart(tracer.$wrapper, {\n type: 'bar',\n data: {\n labels: [],\n datasets: []\n },\n options: {\n scales: {\n yAxes: [{\n ticks: {\n beginAtZero: true\n }\n }]\n },\n animation: false,\n legend: false,\n responsive: true,\n maintainAspectRatio: false\n }\n });\n};\n\nmodule.exports = ChartTracer;\n\n},{\"./tracer\":47}],43:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar DirectedGraphTracer = require('./directed_graph');\n\nvar CoordinateSystemTracer = function (_DirectedGraphTracer) {\n _inherits(CoordinateSystemTracer, _DirectedGraphTracer);\n\n _createClass(CoordinateSystemTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'CoordinateSystemTracer';\n }\n }]);\n\n function CoordinateSystemTracer(name) {\n _classCallCheck(this, CoordinateSystemTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(CoordinateSystemTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(CoordinateSystemTracer, [{\n key: 'setData',\n value: function setData(C) {\n if (Tracer.prototype.setData.apply(this, arguments)) return true;\n\n this.graph.clear();\n var nodes = [];\n var edges = [];\n for (var i = 0; i < C.length; i++) {\n nodes.push({\n id: this.n(i),\n x: C[i][0],\n y: C[i][1],\n label: '' + i,\n size: 1,\n color: this.color.default\n });\n }this.graph.read({\n nodes: nodes,\n edges: edges\n });\n this.s.camera.goTo({\n x: 0,\n y: 0,\n angle: 0,\n ratio: 1\n });\n this.refresh();\n\n return false;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'visit':\n case 'leave':\n var visit = step.type == 'visit';\n var targetNode = this.graph.nodes(this.n(step.target));\n var color = visit ? this.color.visited : this.color.left;\n targetNode.color = color;\n if (step.source !== undefined) {\n var edgeId = this.e(step.source, step.target);\n if (this.graph.edges(edgeId)) {\n var edge = this.graph.edges(edgeId);\n edge.color = color;\n this.graph.dropEdge(edgeId).addEdge(edge);\n } else {\n this.graph.addEdge({\n id: this.e(step.target, step.source),\n source: this.n(step.source),\n target: this.n(step.target),\n color: color,\n size: 1\n });\n }\n }\n if (this.logTracer) {\n var source = step.source;\n if (source === undefined) source = '';\n this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n }\n break;\n default:\n _get(Object.getPrototypeOf(CoordinateSystemTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'e',\n value: function e(v1, v2) {\n if (v1 > v2) {\n var temp = v1;\n v1 = v2;\n v2 = temp;\n }\n return 'e' + v1 + '_' + v2;\n }\n }, {\n key: 'drawOnHover',\n value: function drawOnHover(node, context, settings, next) {\n var tracer = this;\n\n context.setLineDash([5, 5]);\n var nodeIdx = node.id.substring(1);\n this.graph.edges().forEach(function (edge) {\n var ends = edge.id.substring(1).split(\"_\");\n if (ends[0] == nodeIdx) {\n var color = '#0ff';\n var source = node;\n var target = tracer.graph.nodes('n' + ends[1]);\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n } else if (ends[1] == nodeIdx) {\n var color = '#0ff';\n var source = tracer.graph.nodes('n' + ends[0]);\n var target = node;\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n }\n });\n }\n }, {\n key: 'drawEdge',\n value: function drawEdge(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1;\n\n context.strokeStyle = color;\n context.lineWidth = size;\n context.beginPath();\n context.moveTo(source[prefix + 'x'], source[prefix + 'y']);\n context.lineTo(target[prefix + 'x'], target[prefix + 'y']);\n context.stroke();\n }\n }]);\n\n return CoordinateSystemTracer;\n}(DirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n defaultEdgeType: 'def',\n funcEdgesDef: function funcEdgesDef(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawEdge(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = CoordinateSystemTracer;\n\n},{\"./directed_graph\":44}],44:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar refineByType = _require.refineByType;\n\nvar DirectedGraphTracer = function (_Tracer) {\n _inherits(DirectedGraphTracer, _Tracer);\n\n _createClass(DirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'DirectedGraphTracer';\n }\n }]);\n\n function DirectedGraphTracer(name) {\n _classCallCheck(this, DirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(DirectedGraphTracer).call(this, name));\n\n _this.color = {\n selected: '#0f0',\n visited: '#f00',\n left: '#000',\n default: '#888'\n };\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(DirectedGraphTracer, [{\n key: '_setTreeData',\n value: function _setTreeData(G, root) {\n this.manager.pushStep(this.capsule, {\n type: 'setTreeData',\n arguments: arguments\n });\n return this;\n }\n }, {\n key: '_visit',\n value: function _visit(target, source) {\n this.manager.pushStep(this.capsule, {\n type: 'visit',\n target: target,\n source: source\n });\n return this;\n }\n }, {\n key: '_leave',\n value: function _leave(target, source) {\n this.manager.pushStep(this.capsule, {\n type: 'leave',\n target: target,\n source: source\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'setTreeData':\n this.setTreeData.apply(this, step.arguments);\n break;\n case 'visit':\n case 'leave':\n var visit = step.type == 'visit';\n var targetNode = this.graph.nodes(this.n(step.target));\n var color = visit ? this.color.visited : this.color.left;\n targetNode.color = color;\n if (step.source !== undefined) {\n var edgeId = this.e(step.source, step.target);\n var edge = this.graph.edges(edgeId);\n edge.color = color;\n this.graph.dropEdge(edgeId).addEdge(edge);\n }\n if (this.logTracer) {\n var source = step.source;\n if (source === undefined) source = '';\n this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n }\n break;\n default:\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'setTreeData',\n value: function setTreeData(G, root, undirected) {\n var tracer = this;\n\n root = root || 0;\n var maxDepth = -1;\n\n var chk = new Array(G.length);\n var getDepth = function getDepth(node, depth) {\n if (chk[node]) throw \"the given graph is not a tree because it forms a circuit\";\n chk[node] = true;\n if (maxDepth < depth) maxDepth = depth;\n for (var i = 0; i < G[node].length; i++) {\n if (G[node][i]) getDepth(i, depth + 1);\n }\n };\n getDepth(root, 1);\n\n if (this.setData(G, undirected)) return true;\n\n var place = function place(node, x, y) {\n var temp = tracer.graph.nodes(tracer.n(node));\n temp.x = x;\n temp.y = y;\n };\n\n var wgap = 1 / (maxDepth - 1);\n var dfs = function dfs(node, depth, top, bottom) {\n place(node, top + bottom, depth * wgap);\n var children = 0;\n for (var i = 0; i < G[node].length; i++) {\n if (G[node][i]) children++;\n }\n var vgap = (bottom - top) / children;\n var cnt = 0;\n for (var i = 0; i < G[node].length; i++) {\n if (G[node][i]) dfs(i, depth + 1, top + vgap * cnt, top + vgap * ++cnt);\n }\n };\n dfs(root, 0, 0, 1);\n\n this.refresh();\n }\n }, {\n key: 'setData',\n value: function setData(G, undirected) {\n if (_get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'setData', this).apply(this, arguments)) return true;\n\n this.graph.clear();\n var nodes = [];\n var edges = [];\n var unitAngle = 2 * Math.PI / G.length;\n var currentAngle = 0;\n for (var i = 0; i < G.length; i++) {\n currentAngle += unitAngle;\n nodes.push({\n id: this.n(i),\n label: '' + i,\n x: .5 + Math.sin(currentAngle) / 2,\n y: .5 + Math.cos(currentAngle) / 2,\n size: 1,\n color: this.color.default,\n weight: 0\n });\n\n if (undirected) {\n for (var j = 0; j <= i; j++) {\n var value = G[i][j] || G[j][i];\n if (value) {\n edges.push({\n id: this.e(i, j),\n source: this.n(i),\n target: this.n(j),\n color: this.color.default,\n size: 1,\n weight: refineByType(value)\n });\n }\n }\n } else {\n for (var _j = 0; _j < G[i].length; _j++) {\n if (G[i][_j]) {\n edges.push({\n id: this.e(i, _j),\n source: this.n(i),\n target: this.n(_j),\n color: this.color.default,\n size: 1,\n weight: refineByType(G[i][_j])\n });\n }\n }\n }\n }\n\n this.graph.read({\n nodes: nodes,\n edges: edges\n });\n this.s.camera.goTo({\n x: 0,\n y: 0,\n angle: 0,\n ratio: 1\n });\n this.refresh();\n\n return false;\n }\n }, {\n key: 'resize',\n value: function resize() {\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'resize', this).call(this);\n\n this.s.renderers[0].resize();\n this.refresh();\n }\n }, {\n key: 'refresh',\n value: function refresh() {\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'refresh', this).call(this);\n\n this.s.refresh();\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(DirectedGraphTracer.prototype), 'clear', this).call(this);\n\n this.clearGraphColor();\n this.refresh();\n }\n }, {\n key: 'clearGraphColor',\n value: function clearGraphColor() {\n var tracer = this;\n\n this.graph.nodes().forEach(function (node) {\n node.color = tracer.color.default;\n });\n this.graph.edges().forEach(function (edge) {\n edge.color = tracer.color.default;\n });\n }\n }, {\n key: 'n',\n value: function n(v) {\n return 'n' + v;\n }\n }, {\n key: 'e',\n value: function e(v1, v2) {\n return 'e' + v1 + '_' + v2;\n }\n }, {\n key: 'getColor',\n value: function getColor(edge, source, target, settings) {\n var color = edge.color,\n edgeColor = settings('edgeColor'),\n defaultNodeColor = settings('defaultNodeColor'),\n defaultEdgeColor = settings('defaultEdgeColor');\n if (!color) switch (edgeColor) {\n case 'source':\n color = source.color || defaultNodeColor;\n break;\n case 'target':\n color = target.color || defaultNodeColor;\n break;\n default:\n color = defaultEdgeColor;\n break;\n }\n\n return color;\n }\n }, {\n key: 'drawLabel',\n value: function drawLabel(node, context, settings) {\n var fontSize,\n prefix = settings('prefix') || '',\n size = node[prefix + 'size'];\n\n if (size < settings('labelThreshold')) return;\n\n if (!node.label || typeof node.label !== 'string') return;\n\n fontSize = settings('labelSize') === 'fixed' ? settings('defaultLabelSize') : settings('labelSizeRatio') * size;\n\n context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') + fontSize + 'px ' + settings('font');\n context.fillStyle = settings('labelColor') === 'node' ? node.color || settings('defaultNodeColor') : settings('defaultLabelColor');\n\n context.textAlign = 'center';\n context.fillText(node.label, Math.round(node[prefix + 'x']), Math.round(node[prefix + 'y'] + fontSize / 3));\n }\n }, {\n key: 'drawArrow',\n value: function drawArrow(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1,\n tSize = target[prefix + 'size'],\n sX = source[prefix + 'x'],\n sY = source[prefix + 'y'],\n tX = target[prefix + 'x'],\n tY = target[prefix + 'y'],\n angle = Math.atan2(tY - sY, tX - sX),\n dist = 3;\n sX += Math.sin(angle) * dist;\n tX += Math.sin(angle) * dist;\n sY += -Math.cos(angle) * dist;\n tY += -Math.cos(angle) * dist;\n var aSize = Math.max(size * 2.5, settings('minArrowSize')),\n d = Math.sqrt(Math.pow(tX - sX, 2) + Math.pow(tY - sY, 2)),\n aX = sX + (tX - sX) * (d - aSize - tSize) / d,\n aY = sY + (tY - sY) * (d - aSize - tSize) / d,\n vX = (tX - sX) * aSize / d,\n vY = (tY - sY) * aSize / d;\n\n context.strokeStyle = color;\n context.lineWidth = size;\n context.beginPath();\n context.moveTo(sX, sY);\n context.lineTo(aX, aY);\n context.stroke();\n\n context.fillStyle = color;\n context.beginPath();\n context.moveTo(aX + vX, aY + vY);\n context.lineTo(aX + vY * 0.6, aY - vX * 0.6);\n context.lineTo(aX - vY * 0.6, aY + vX * 0.6);\n context.lineTo(aX + vX, aY + vY);\n context.closePath();\n context.fill();\n }\n }, {\n key: 'drawOnHover',\n value: function drawOnHover(node, context, settings, next) {\n var tracer = this;\n\n context.setLineDash([5, 5]);\n var nodeIdx = node.id.substring(1);\n this.graph.edges().forEach(function (edge) {\n var ends = edge.id.substring(1).split(\"_\");\n if (ends[0] == nodeIdx) {\n var color = '#0ff';\n var source = node;\n var target = tracer.graph.nodes('n' + ends[1]);\n tracer.drawArrow(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n } else if (ends[1] == nodeIdx) {\n var color = '#ff0';\n var source = tracer.graph.nodes('n' + ends[0]);\n var target = node;\n tracer.drawArrow(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n }\n });\n }\n }]);\n\n return DirectedGraphTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.s = tracer.capsule.s = new sigma({\n renderer: {\n container: tracer.$container[0],\n type: 'canvas'\n },\n settings: {\n minArrowSize: 8,\n defaultEdgeType: 'arrow',\n maxEdgeSize: 2.5,\n labelThreshold: 4,\n font: 'Roboto',\n defaultLabelColor: '#fff',\n zoomMin: 0.6,\n zoomMax: 1.2,\n skipErrors: true,\n minNodeSize: .5,\n maxNodeSize: 12,\n labelSize: 'proportional',\n labelSizeRatio: 1.3,\n funcLabelsDef: function funcLabelsDef(node, context, settings) {\n tracer.drawLabel(node, context, settings);\n },\n funcHoversDef: function funcHoversDef(node, context, settings, next) {\n tracer.drawOnHover(node, context, settings, next);\n },\n funcEdgesArrow: function funcEdgesArrow(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawArrow(edge, source, target, color, context, settings);\n }\n }\n });\n sigma.plugins.dragNodes(tracer.s, tracer.s.renderers[0]);\n tracer.graph = tracer.capsule.graph = tracer.s.graph;\n};\n\nsigma.canvas.labels.def = function (node, context, settings) {\n var func = settings('funcLabelsDef');\n if (func) {\n func(node, context, settings);\n }\n};\nsigma.canvas.hovers.def = function (node, context, settings) {\n var func = settings('funcHoversDef');\n if (func) {\n func(node, context, settings);\n }\n};\nsigma.canvas.edges.def = function (edge, source, target, context, settings) {\n var func = settings('funcEdgesDef');\n if (func) {\n func(edge, source, target, context, settings);\n }\n};\nsigma.canvas.edges.arrow = function (edge, source, target, context, settings) {\n var func = settings('funcEdgesArrow');\n if (func) {\n func(edge, source, target, context, settings);\n }\n};\n\nmodule.exports = DirectedGraphTracer;\n\n},{\"../../tracer_manager/util/index\":67,\"./tracer\":47}],45:[function(require,module,exports){\n'use strict';\n\nvar Tracer = require('./tracer');\nvar LogTracer = require('./log');\nvar Array1DTracer = require('./array1d');\nvar Array2DTracer = require('./array2d');\nvar ChartTracer = require('./chart');\nvar CoordinateSystemTracer = require('./coordinate_system');\nvar DirectedGraphTracer = require('./directed_graph');\nvar UndirectedGraphTracer = require('./undirected_graph');\nvar WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nvar WeightedUndirectedGraphTracer = require('./weighted_undirected_graph');\n\nmodule.exports = {\n Tracer: Tracer,\n LogTracer: LogTracer,\n Array1DTracer: Array1DTracer,\n Array2DTracer: Array2DTracer,\n ChartTracer: ChartTracer,\n CoordinateSystemTracer: CoordinateSystemTracer,\n DirectedGraphTracer: DirectedGraphTracer,\n UndirectedGraphTracer: UndirectedGraphTracer,\n WeightedDirectedGraphTracer: WeightedDirectedGraphTracer,\n WeightedUndirectedGraphTracer: WeightedUndirectedGraphTracer\n};\n\n},{\"./array1d\":40,\"./array2d\":41,\"./chart\":42,\"./coordinate_system\":43,\"./directed_graph\":44,\"./log\":46,\"./tracer\":47,\"./undirected_graph\":48,\"./weighted_directed_graph\":49,\"./weighted_undirected_graph\":50}],46:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar Tracer = require('./tracer');\n\nvar LogTracer = function (_Tracer) {\n _inherits(LogTracer, _Tracer);\n\n _createClass(LogTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'LogTracer';\n }\n }]);\n\n function LogTracer(name) {\n _classCallCheck(this, LogTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(LogTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(LogTracer, [{\n key: '_print',\n value: function _print(msg) {\n this.manager.pushStep(this.capsule, {\n type: 'print',\n msg: msg\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'print':\n this.print(step.msg);\n break;\n }\n }\n }, {\n key: 'refresh',\n value: function refresh() {\n this.scrollToEnd(Math.min(50, this.interval));\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(LogTracer.prototype), 'clear', this).call(this);\n\n this.$wrapper.empty();\n }\n }, {\n key: 'print',\n value: function print(message) {\n this.$wrapper.append($('<span>').append(message + '<br/>'));\n }\n }, {\n key: 'scrollToEnd',\n value: function scrollToEnd(duration) {\n this.$container.animate({\n scrollTop: this.$container[0].scrollHeight\n }, duration);\n }\n }]);\n\n return LogTracer;\n}(Tracer);\n\nvar initView = function initView(tracer) {\n tracer.$wrapper = tracer.capsule.$wrapper = $('<div class=\"wrapper\">');\n tracer.$container.append(tracer.$wrapper);\n};\n\nmodule.exports = LogTracer;\n\n},{\"./tracer\":47}],47:[function(require,module,exports){\n'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar app = require('../../app');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar toJSON = _require.toJSON;\nvar fromJSON = _require.fromJSON;\n\nvar Tracer = function () {\n _createClass(Tracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'Tracer';\n }\n }]);\n\n function Tracer(name) {\n _classCallCheck(this, Tracer);\n\n this.module = this.constructor;\n\n this.manager = app.getTracerManager();\n this.capsule = this.manager.allocate(this);\n $.extend(this, this.capsule);\n\n this.setName(name);\n }\n\n _createClass(Tracer, [{\n key: '_setData',\n value: function _setData() {\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n this.manager.pushStep(this.capsule, {\n type: 'setData',\n args: toJSON(args)\n });\n return this;\n }\n }, {\n key: '_clear',\n value: function _clear() {\n this.manager.pushStep(this.capsule, {\n type: 'clear'\n });\n return this;\n }\n }, {\n key: '_wait',\n value: function _wait(line) {\n this.manager.newStep(line);\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n var type = step.type;\n var args = step.args;\n\n\n switch (type) {\n case 'setData':\n this.setData.apply(this, _toConsumableArray(fromJSON(args)));\n break;\n case 'clear':\n this.clear();\n break;\n }\n }\n }, {\n key: 'setName',\n value: function setName(name) {\n var $name = void 0;\n if (this.isNew) {\n $name = $('<span class=\"name\">');\n this.$container.append($name);\n } else {\n $name = this.$container.find('span.name');\n }\n $name.text(name || this.defaultName);\n }\n }, {\n key: 'setData',\n value: function setData() {\n var data = toJSON(arguments);\n if (!this.isNew && this.lastData === data) {\n return true;\n }\n this.lastData = this.capsule.lastData = data;\n return false;\n }\n }, {\n key: 'resize',\n value: function resize() {}\n }, {\n key: 'refresh',\n value: function refresh() {}\n }, {\n key: 'clear',\n value: function clear() {}\n }, {\n key: 'attach',\n value: function attach(tracer) {\n switch (tracer.module) {\n case LogTracer:\n this.logTracer = tracer;\n break;\n case ChartTracer:\n this.chartTracer = tracer;\n break;\n }\n return this;\n }\n }, {\n key: 'mousedown',\n value: function mousedown(e) {}\n }, {\n key: 'mousemove',\n value: function mousemove(e) {}\n }, {\n key: 'mouseup',\n value: function mouseup(e) {}\n }, {\n key: 'mousewheel',\n value: function mousewheel(e) {}\n }]);\n\n return Tracer;\n}();\n\nmodule.exports = Tracer;\n\n},{\"../../app\":3,\"../../tracer_manager/util/index\":67}],48:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar DirectedGraphTracer = require('./directed_graph');\n\nvar UndirectedGraphTracer = function (_DirectedGraphTracer) {\n _inherits(UndirectedGraphTracer, _DirectedGraphTracer);\n\n _createClass(UndirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'UndirectedGraphTracer';\n }\n }]);\n\n function UndirectedGraphTracer(name) {\n _classCallCheck(this, UndirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(UndirectedGraphTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(UndirectedGraphTracer, [{\n key: 'setTreeData',\n value: function setTreeData(G, root) {\n return _get(Object.getPrototypeOf(UndirectedGraphTracer.prototype), 'setTreeData', this).call(this, G, root, true);\n }\n }, {\n key: 'setData',\n value: function setData(G) {\n return _get(Object.getPrototypeOf(UndirectedGraphTracer.prototype), 'setData', this).call(this, G, true);\n }\n }, {\n key: 'e',\n value: function e(v1, v2) {\n if (v1 > v2) {\n var temp = v1;\n v1 = v2;\n v2 = temp;\n }\n return 'e' + v1 + '_' + v2;\n }\n }, {\n key: 'drawOnHover',\n value: function drawOnHover(node, context, settings, next) {\n var tracer = this;\n\n context.setLineDash([5, 5]);\n var nodeIdx = node.id.substring(1);\n this.graph.edges().forEach(function (edge) {\n var ends = edge.id.substring(1).split(\"_\");\n if (ends[0] == nodeIdx) {\n var color = '#0ff';\n var source = node;\n var target = tracer.graph.nodes('n' + ends[1]);\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n } else if (ends[1] == nodeIdx) {\n var color = '#0ff';\n var source = tracer.graph.nodes('n' + ends[0]);\n var target = node;\n tracer.drawEdge(edge, source, target, color, context, settings);\n if (next) next(edge, source, target, color, context, settings);\n }\n });\n }\n }, {\n key: 'drawEdge',\n value: function drawEdge(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1;\n\n context.strokeStyle = color;\n context.lineWidth = size;\n context.beginPath();\n context.moveTo(source[prefix + 'x'], source[prefix + 'y']);\n context.lineTo(target[prefix + 'x'], target[prefix + 'y']);\n context.stroke();\n }\n }]);\n\n return UndirectedGraphTracer;\n}(DirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n defaultEdgeType: 'def',\n funcEdgesDef: function funcEdgesDef(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawEdge(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = UndirectedGraphTracer;\n\n},{\"./directed_graph\":44}],49:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar DirectedGraphTracer = require('./directed_graph');\n\nvar _require = require('../../tracer_manager/util/index');\n\nvar refineByType = _require.refineByType;\n\nvar WeightedDirectedGraphTracer = function (_DirectedGraphTracer) {\n _inherits(WeightedDirectedGraphTracer, _DirectedGraphTracer);\n\n _createClass(WeightedDirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'WeightedDirectedGraphTracer';\n }\n }]);\n\n function WeightedDirectedGraphTracer(name) {\n _classCallCheck(this, WeightedDirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(WeightedDirectedGraphTracer).call(this, name));\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(WeightedDirectedGraphTracer, [{\n key: '_weight',\n value: function _weight(target, weight) {\n this.manager.pushStep(this.capsule, {\n type: 'weight',\n target: target,\n weight: weight\n });\n return this;\n }\n }, {\n key: '_visit',\n value: function _visit(target, source, weight) {\n this.manager.pushStep(this.capsule, {\n type: 'visit',\n target: target,\n source: source,\n weight: weight\n });\n return this;\n }\n }, {\n key: '_leave',\n value: function _leave(target, source, weight) {\n this.manager.pushStep(this.capsule, {\n type: 'leave',\n target: target,\n source: source,\n weight: weight\n });\n return this;\n }\n }, {\n key: 'processStep',\n value: function processStep(step, options) {\n switch (step.type) {\n case 'weight':\n var targetNode = this.graph.nodes(this.n(step.target));\n if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n break;\n case 'visit':\n case 'leave':\n var visit = step.type == 'visit';\n var targetNode = this.graph.nodes(this.n(step.target));\n var color = visit ? step.weight === undefined ? this.color.selected : this.color.visited : this.color.left;\n targetNode.color = color;\n if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n if (step.source !== undefined) {\n var edgeId = this.e(step.source, step.target);\n var edge = this.graph.edges(edgeId);\n edge.color = color;\n this.graph.dropEdge(edgeId).addEdge(edge);\n }\n if (this.logTracer) {\n var source = step.source;\n if (source === undefined) source = '';\n this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n }\n break;\n default:\n _get(Object.getPrototypeOf(WeightedDirectedGraphTracer.prototype), 'processStep', this).call(this, step, options);\n }\n }\n }, {\n key: 'clear',\n value: function clear() {\n _get(Object.getPrototypeOf(WeightedDirectedGraphTracer.prototype), 'clear', this).call(this);\n\n this.clearWeights();\n }\n }, {\n key: 'clearWeights',\n value: function clearWeights() {\n this.graph.nodes().forEach(function (node) {\n node.weight = 0;\n });\n }\n }, {\n key: 'drawEdgeWeight',\n value: function drawEdgeWeight(edge, source, target, color, context, settings) {\n if (source == target) return;\n\n var prefix = settings('prefix') || '',\n size = edge[prefix + 'size'] || 1;\n\n if (size < settings('edgeLabelThreshold')) return;\n\n if (0 === settings('edgeLabelSizePowRatio')) throw '\"edgeLabelSizePowRatio\" must not be 0.';\n\n var fontSize,\n x = (source[prefix + 'x'] + target[prefix + 'x']) / 2,\n y = (source[prefix + 'y'] + target[prefix + 'y']) / 2,\n dX = target[prefix + 'x'] - source[prefix + 'x'],\n dY = target[prefix + 'y'] - source[prefix + 'y'],\n angle = Math.atan2(dY, dX);\n\n fontSize = settings('edgeLabelSize') === 'fixed' ? settings('defaultEdgeLabelSize') : settings('defaultEdgeLabelSize') * size * Math.pow(size, -1 / settings('edgeLabelSizePowRatio'));\n\n context.save();\n\n if (edge.active) {\n context.font = [settings('activeFontStyle'), fontSize + 'px', settings('activeFont') || settings('font')].join(' ');\n\n context.fillStyle = color;\n } else {\n context.font = [settings('fontStyle'), fontSize + 'px', settings('font')].join(' ');\n\n context.fillStyle = color;\n }\n\n context.textAlign = 'center';\n context.textBaseline = 'alphabetic';\n\n context.translate(x, y);\n context.rotate(angle);\n context.fillText(edge.weight, 0, -size / 2 - 3);\n\n context.restore();\n }\n }, {\n key: 'drawNodeWeight',\n value: function drawNodeWeight(node, context, settings) {\n var fontSize,\n prefix = settings('prefix') || '',\n size = node[prefix + 'size'];\n\n if (size < settings('labelThreshold')) return;\n\n fontSize = settings('labelSize') === 'fixed' ? settings('defaultLabelSize') : settings('labelSizeRatio') * size;\n\n context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') + fontSize + 'px ' + settings('font');\n context.fillStyle = settings('labelColor') === 'node' ? node.color || settings('defaultNodeColor') : settings('defaultLabelColor');\n\n context.textAlign = 'left';\n context.fillText(node.weight, Math.round(node[prefix + 'x'] + size * 1.5), Math.round(node[prefix + 'y'] + fontSize / 3));\n }\n }]);\n\n return WeightedDirectedGraphTracer;\n}(DirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n edgeLabelSize: 'proportional',\n defaultEdgeLabelSize: 20,\n edgeLabelSizePowRatio: 0.8,\n funcLabelsDef: function funcLabelsDef(node, context, settings) {\n tracer.drawNodeWeight(node, context, settings);\n tracer.drawLabel(node, context, settings);\n },\n funcHoversDef: function funcHoversDef(node, context, settings) {\n tracer.drawOnHover(node, context, settings, tracer.drawEdgeWeight);\n },\n funcEdgesArrow: function funcEdgesArrow(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawArrow(edge, source, target, color, context, settings);\n tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = WeightedDirectedGraphTracer;\n\n},{\"../../tracer_manager/util/index\":67,\"./directed_graph\":44}],50:[function(require,module,exports){\n'use strict';\n\nvar _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if (\"value\" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return call && (typeof call === \"object\" || typeof call === \"function\") ? call : self; }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function, not \" + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }\n\nvar WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nvar UndirectedGraphTracer = require('./undirected_graph');\n\nvar WeightedUndirectedGraphTracer = function (_WeightedDirectedGrap) {\n _inherits(WeightedUndirectedGraphTracer, _WeightedDirectedGrap);\n\n _createClass(WeightedUndirectedGraphTracer, null, [{\n key: 'getClassName',\n value: function getClassName() {\n return 'WeightedUndirectedGraphTracer';\n }\n }]);\n\n function WeightedUndirectedGraphTracer(name) {\n _classCallCheck(this, WeightedUndirectedGraphTracer);\n\n var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(WeightedUndirectedGraphTracer).call(this, name));\n\n _this.e = UndirectedGraphTracer.prototype.e;\n _this.drawOnHover = UndirectedGraphTracer.prototype.drawOnHover;\n _this.drawEdge = UndirectedGraphTracer.prototype.drawEdge;\n\n if (_this.isNew) initView(_this);\n return _this;\n }\n\n _createClass(WeightedUndirectedGraphTracer, [{\n key: 'setTreeData',\n value: function setTreeData(G, root) {\n return _get(Object.getPrototypeOf(WeightedUndirectedGraphTracer.prototype), 'setTreeData', this).call(this, G, root, true);\n }\n }, {\n key: 'setData',\n value: function setData(G) {\n return _get(Object.getPrototypeOf(WeightedUndirectedGraphTracer.prototype), 'setData', this).call(this, G, true);\n }\n }, {\n key: 'drawEdgeWeight',\n value: function drawEdgeWeight(edge, source, target, color, context, settings) {\n var prefix = settings('prefix') || '';\n if (source[prefix + 'x'] > target[prefix + 'x']) {\n var temp = source;\n source = target;\n target = temp;\n }\n WeightedDirectedGraphTracer.prototype.drawEdgeWeight.call(this, edge, source, target, color, context, settings);\n }\n }]);\n\n return WeightedUndirectedGraphTracer;\n}(WeightedDirectedGraphTracer);\n\nvar initView = function initView(tracer) {\n tracer.s.settings({\n defaultEdgeType: 'def',\n funcEdgesDef: function funcEdgesDef(edge, source, target, context, settings) {\n var color = tracer.getColor(edge, source, target, settings);\n tracer.drawEdge(edge, source, target, color, context, settings);\n tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n }\n });\n};\n\nmodule.exports = WeightedUndirectedGraphTracer;\n\n},{\"./undirected_graph\":48,\"./weighted_directed_graph\":49}],51:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url) {\n return request(url, {\n type: 'GET'\n });\n};\n\n},{\"./request\":54}],52:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url) {\n return request(url, {\n dataType: 'json',\n type: 'GET'\n });\n};\n\n},{\"./request\":54}],53:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url, data) {\n return request(url, {\n dataType: 'json',\n type: 'POST',\n data: JSON.stringify(data)\n });\n};\n\n},{\"./request\":54}],54:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('../../app');\n\nvar _$ = $;\nvar ajax = _$.ajax;\nvar extend = _$.extend;\n\n\nvar defaults = {};\n\nmodule.exports = function (url) {\n var options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1];\n\n app.setIsLoading(true);\n\n return new RSVP.Promise(function (resolve, reject) {\n var callbacks = {\n success: function success(response) {\n app.setIsLoading(false);\n resolve(response);\n },\n error: function error(reason) {\n app.setIsLoading(false);\n reject(reason);\n }\n };\n\n var opts = extend({}, defaults, options, callbacks, {\n url: url\n });\n\n ajax(opts);\n });\n};\n\n},{\"../../app\":3,\"rsvp\":72}],55:[function(require,module,exports){\n'use strict';\n\nvar _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i[\"return\"]) _i[\"return\"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError(\"Invalid attempt to destructure non-iterable instance\"); } }; }();\n\nvar app = require('../app');\nvar Toast = require('../dom/toast');\n\nvar checkLoading = function checkLoading() {\n if (app.getIsLoading()) {\n Toast.showErrorToast('Wait until it completes loading of previous file.');\n return true;\n }\n return false;\n};\n\nvar getParameterByName = function getParameterByName(name) {\n var url = window.location.href;\n var regex = new RegExp('[?&]' + name + '(=([^&#]*)|&|#|$)');\n\n var results = regex.exec(url);\n\n if (!results || results.length !== 3) {\n return null;\n }\n\n var _results = _slicedToArray(results, 3);\n\n var id = _results[2];\n\n\n return id;\n};\n\nvar getHashValue = function getHashValue(key) {\n if (!key) return null;\n var hash = window.location.hash.substr(1);\n var params = hash ? hash.split('&') : [];\n for (var i = 0; i < params.length; i++) {\n var pair = params[i].split('=');\n if (pair[0] === key) {\n return pair[1];\n }\n }\n return null;\n};\n\nvar setHashValue = function setHashValue(key, value) {\n if (!key || !value) return;\n var hash = window.location.hash.substr(1);\n var params = hash ? hash.split('&') : [];\n\n var found = false;\n for (var i = 0; i < params.length && !found; i++) {\n var pair = params[i].split('=');\n if (pair[0] === key) {\n pair[1] = value;\n params[i] = pair.join('=');\n found = true;\n }\n }\n if (!found) {\n params.push([key, value].join('='));\n }\n\n var newHash = params.join('&');\n window.location.hash = '#' + newHash;\n};\n\nvar removeHashValue = function removeHashValue(key) {\n if (!key) return;\n var hash = window.location.hash.substr(1);\n var params = hash ? hash.split('&') : [];\n\n for (var i = 0; i < params.length; i++) {\n var pair = params[i].split('=');\n if (pair[0] === key) {\n params.splice(i, 1);\n break;\n }\n }\n\n var newHash = params.join('&');\n window.location.hash = '#' + newHash;\n};\n\nvar setPath = function setPath(category, algorithm, file) {\n var path = category ? category + (algorithm ? '/' + algorithm + (file ? '/' + file : '') : '') : '';\n setHashValue('path', path);\n};\n\nvar getPath = function getPath() {\n var hash = getHashValue('path');\n if (hash) {\n var _hash$split = hash.split('/');\n\n var _hash$split2 = _slicedToArray(_hash$split, 3);\n\n var category = _hash$split2[0];\n var algorithm = _hash$split2[1];\n var file = _hash$split2[2];\n\n return { category: category, algorithm: algorithm, file: file };\n } else {\n return false;\n }\n};\n\nmodule.exports = {\n checkLoading: checkLoading,\n getParameterByName: getParameterByName,\n getHashValue: getHashValue,\n setHashValue: setHashValue,\n removeHashValue: removeHashValue,\n setPath: setPath,\n getPath: getPath\n};\n\n},{\"../app\":3,\"../dom/toast\":24}],56:[function(require,module,exports){\n'use strict';\n\nvar loadAlgorithm = require('./load_algorithm');\nvar loadCategories = require('./load_categories');\nvar loadFile = require('./load_file');\nvar loadScratchPaper = require('./load_scratch_paper');\nvar shareScratchPaper = require('./share_scratch_paper');\nvar loadWikiList = require('./load_wiki_list');\nvar loadWiki = require('./load_wiki');\n\nmodule.exports = {\n loadAlgorithm: loadAlgorithm,\n loadCategories: loadCategories,\n loadFile: loadFile,\n loadScratchPaper: loadScratchPaper,\n shareScratchPaper: shareScratchPaper,\n loadWikiList: loadWikiList,\n loadWiki: loadWiki\n};\n\n},{\"./load_algorithm\":57,\"./load_categories\":58,\"./load_file\":59,\"./load_scratch_paper\":60,\"./load_wiki\":61,\"./load_wiki_list\":62,\"./share_scratch_paper\":63}],57:[function(require,module,exports){\n'use strict';\n\nvar getJSON = require('./ajax/get_json');\n\nvar _require = require('../utils');\n\nvar getAlgorithmDir = _require.getAlgorithmDir;\n\n\nmodule.exports = function (category, algorithm) {\n var dir = getAlgorithmDir(category, algorithm);\n return getJSON(dir + 'desc.json');\n};\n\n},{\"../utils\":70,\"./ajax/get_json\":52}],58:[function(require,module,exports){\n'use strict';\n\nvar getJSON = require('./ajax/get_json');\n\nmodule.exports = function () {\n return getJSON('./algorithm/category.json');\n};\n\n},{\"./ajax/get_json\":52}],59:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\n\nvar app = require('../app');\n\nvar _require = require('../utils');\n\nvar getFileDir = _require.getFileDir;\nvar isScratchPaper = _require.isScratchPaper;\n\nvar _require2 = require('./helpers');\n\nvar checkLoading = _require2.checkLoading;\nvar setPath = _require2.setPath;\n\n\nvar get = require('./ajax/get');\n\nvar loadDataAndCode = function loadDataAndCode(dir) {\n return RSVP.hash({\n data: get(dir + 'data.js'),\n code: get(dir + 'code.js')\n });\n};\n\nvar loadFileAndUpdateContent = function loadFileAndUpdateContent(dir) {\n app.getEditor().clearContent();\n\n return loadDataAndCode(dir).then(function (content) {\n app.updateCachedFile(dir, content);\n app.getEditor().setContent(content);\n });\n};\n\nvar cachedContentExists = function cachedContentExists(cachedFile) {\n return cachedFile && cachedFile.data !== undefined && cachedFile.code !== undefined;\n};\n\nmodule.exports = function (category, algorithm, file, explanation) {\n return new RSVP.Promise(function (resolve, reject) {\n if (checkLoading()) {\n reject();\n } else {\n if (isScratchPaper(category)) {\n setPath(category, app.getLoadedScratch());\n } else {\n setPath(category, algorithm, file);\n }\n $('#explanation').html(explanation);\n\n var dir = getFileDir(category, algorithm, file);\n app.setLastFileUsed(dir);\n var cachedFile = app.getCachedFile(dir);\n\n if (cachedContentExists(cachedFile)) {\n app.getEditor().setContent(cachedFile);\n resolve();\n } else {\n loadFileAndUpdateContent(dir).then(resolve, reject);\n }\n }\n });\n};\n\n},{\"../app\":3,\"../utils\":70,\"./ajax/get\":51,\"./helpers\":55,\"rsvp\":72}],60:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('../app');\n\nvar _require = require('../utils');\n\nvar getFileDir = _require.getFileDir;\n\n\nvar getJSON = require('./ajax/get_json');\nvar loadAlgorithm = require('./load_algorithm');\n\nvar extractGistCode = function extractGistCode(files, name) {\n return files[name + '.js'].content;\n};\n\nmodule.exports = function (gistID) {\n return new RSVP.Promise(function (resolve, reject) {\n app.setLoadedScratch(gistID);\n\n getJSON('https://api.github.com/gists/' + gistID).then(function (_ref) {\n var files = _ref.files;\n\n\n var category = 'scratch';\n var algorithm = gistID;\n\n loadAlgorithm(category, algorithm).then(function (data) {\n\n var algoData = extractGistCode(files, 'data');\n var algoCode = extractGistCode(files, 'code');\n\n // update scratch paper algo code with the loaded gist code\n var dir = getFileDir(category, algorithm, 'scratch_paper');\n app.updateCachedFile(dir, {\n data: algoData,\n code: algoCode,\n 'CREDIT.md': 'Shared by an anonymous user from http://parkjs814.github.io/AlgorithmVisualizer'\n });\n\n resolve({\n category: category,\n algorithm: algorithm,\n data: data\n });\n });\n });\n });\n};\n\n},{\"../app\":3,\"../utils\":70,\"./ajax/get_json\":52,\"./load_algorithm\":57,\"rsvp\":72}],61:[function(require,module,exports){\n'use strict';\n\nvar get = require('./ajax/get');\n\nmodule.exports = function (wiki) {\n return get('./AlgorithmVisualizer.wiki/' + wiki + '.md');\n};\n\n},{\"./ajax/get\":51}],62:[function(require,module,exports){\n'use strict';\n\nvar getJSON = require('./ajax/get_json');\n\nmodule.exports = function () {\n return getJSON('./wiki.json');\n};\n\n},{\"./ajax/get_json\":52}],63:[function(require,module,exports){\n'use strict';\n\nvar RSVP = require('rsvp');\nvar app = require('../app');\n\nvar postJSON = require('./ajax/post_json');\n\nvar _require = require('./helpers');\n\nvar setPath = _require.setPath;\n\n\nmodule.exports = function () {\n return new RSVP.Promise(function (resolve, reject) {\n var _app$getEditor = app.getEditor();\n\n var dataEditor = _app$getEditor.dataEditor;\n var codeEditor = _app$getEditor.codeEditor;\n\n\n var gist = {\n 'description': 'temp',\n 'public': true,\n 'files': {\n 'data.js': {\n 'content': dataEditor.getValue()\n },\n 'code.js': {\n 'content': codeEditor.getValue()\n }\n }\n };\n\n postJSON('https://api.github.com/gists', gist).then(function (_ref) {\n var id = _ref.id;\n\n app.setLoadedScratch(id);\n setPath('scratch', id);\n var _location = location;\n var href = _location.href;\n\n $('#algorithm').html('Shared');\n resolve(href);\n });\n });\n};\n\n},{\"../app\":3,\"./ajax/post_json\":53,\"./helpers\":55,\"rsvp\":72}],64:[function(require,module,exports){\n'use strict';\n\nvar TracerManager = require('./manager');\nvar Tracer = require('../module/tracer/tracer');\n\nmodule.exports = {\n init: function init() {\n var tm = new TracerManager();\n Tracer.prototype.manager = tm;\n return tm;\n }\n};\n\n},{\"../module/tracer/tracer\":47,\"./manager\":65}],65:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar ModuleContainer = require('../dom/module_container');\nvar TopMenu = require('../dom/top_menu');\n\nvar _$ = $;\nvar each = _$.each;\nvar extend = _$.extend;\nvar grep = _$.grep;\n\n\nvar stepLimit = 1e6;\n\nvar TracerManager = function TracerManager() {\n this.timer = null;\n this.pause = false;\n this.capsules = [];\n this.interval = 500;\n};\n\nTracerManager.prototype = {\n add: function add(tracer) {\n\n var $container = ModuleContainer.create();\n\n var capsule = {\n module: tracer.module,\n tracer: tracer,\n allocated: true,\n defaultName: null,\n $container: $container,\n isNew: true\n };\n\n this.capsules.push(capsule);\n return capsule;\n },\n allocate: function allocate(newTracer) {\n var selectedCapsule = null;\n var count = 0;\n\n each(this.capsules, function (i, capsule) {\n if (capsule.module === newTracer.module) {\n count++;\n if (!capsule.allocated) {\n capsule.tracer = newTracer;\n capsule.allocated = true;\n capsule.isNew = false;\n selectedCapsule = capsule;\n return false;\n }\n }\n });\n\n if (selectedCapsule === null) {\n count++;\n selectedCapsule = this.add(newTracer);\n }\n\n var className = newTracer.module.getClassName();\n selectedCapsule.defaultName = className + ' ' + count;\n selectedCapsule.order = this.order++;\n return selectedCapsule;\n },\n deallocateAll: function deallocateAll() {\n this.order = 0;\n this.reset();\n each(this.capsules, function (i, capsule) {\n capsule.allocated = false;\n });\n },\n removeUnallocated: function removeUnallocated() {\n var changed = false;\n\n this.capsules = grep(this.capsules, function (capsule) {\n var removed = !capsule.allocated;\n\n if (capsule.isNew || removed) {\n changed = true;\n }\n if (removed) {\n capsule.$container.remove();\n }\n\n return !removed;\n });\n\n if (changed) {\n this.place();\n }\n },\n place: function place() {\n var capsules = this.capsules;\n\n\n each(capsules, function (i, capsule) {\n var width = 100;\n var height = 100 / capsules.length;\n var top = height * capsule.order;\n\n capsule.$container.css({\n top: top + '%',\n width: width + '%',\n height: height + '%'\n });\n\n capsule.tracer.resize();\n });\n },\n resize: function resize() {\n this.command('resize');\n },\n isPause: function isPause() {\n return this.pause;\n },\n setInterval: function setInterval(interval) {\n TopMenu.setInterval(interval);\n },\n reset: function reset() {\n this.traces = [];\n this.traceIndex = -1;\n this.stepCnt = 0;\n if (this.timer) {\n clearTimeout(this.timer);\n }\n this.command('clear');\n },\n pushStep: function pushStep(capsule, step) {\n if (this.stepCnt++ > stepLimit) throw \"Tracer's stack overflow\";\n var len = this.traces.length;\n if (len == 0) len += this.newStep();\n var last = this.traces[len - 1];\n last.push(extend(step, {\n capsule: capsule\n }));\n },\n newStep: function newStep() {\n var line = arguments.length <= 0 || arguments[0] === undefined ? -1 : arguments[0];\n\n var len = this.traces.length;\n if (len > 0 && ~line) {\n this.traces[len - 1].push(line);\n }\n return this.traces.push([]);\n },\n pauseStep: function pauseStep() {\n if (this.traceIndex < 0) return;\n this.pause = true;\n if (this.timer) {\n clearTimeout(this.timer);\n }\n TopMenu.activateBtnPause();\n },\n resumeStep: function resumeStep() {\n this.pause = false;\n this.step(this.traceIndex + 1);\n TopMenu.deactivateBtnPause();\n },\n step: function step(i) {\n var options = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1];\n\n var tracer = this;\n\n if (isNaN(i) || i >= this.traces.length || i < 0) return;\n\n this.traceIndex = i;\n var trace = this.traces[i];\n trace.forEach(function (step) {\n if (typeof step === 'number') {\n app.getEditor().highlightLine(step);\n return;\n }\n step.capsule.tracer.processStep(step, options);\n });\n\n if (!options.virtual) {\n this.command('refresh');\n }\n\n if (this.pause) return;\n\n this.timer = setTimeout(function () {\n if (!tracer.nextStep(options)) {\n TopMenu.resetTopMenuButtons();\n }\n }, this.interval);\n },\n prevStep: function prevStep() {\n var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n this.command('clear');\n\n var finalIndex = this.traceIndex - 1;\n if (finalIndex < 0) {\n this.traceIndex = -1;\n this.command('refresh');\n return false;\n }\n\n for (var i = 0; i < finalIndex; i++) {\n this.step(i, extend(options, {\n virtual: true\n }));\n }\n\n this.step(finalIndex);\n return true;\n },\n nextStep: function nextStep() {\n var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0];\n\n var finalIndex = this.traceIndex + 1;\n if (finalIndex >= this.traces.length) {\n this.traceIndex = this.traces.length - 1;\n return false;\n }\n\n this.step(finalIndex, options);\n return true;\n },\n visualize: function visualize() {\n this.traceIndex = -1;\n this.resumeStep();\n },\n command: function command() {\n for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var functionName = args.shift();\n each(this.capsules, function (i, capsule) {\n if (capsule.allocated) {\n capsule.tracer.module.prototype[functionName].apply(capsule.tracer, args);\n }\n });\n },\n findOwner: function findOwner(container) {\n var selectedCapsule = null;\n each(this.capsules, function (i, capsule) {\n if (capsule.$container[0] === container) {\n selectedCapsule = capsule;\n return false;\n }\n });\n return selectedCapsule.tracer;\n }\n};\n\nmodule.exports = TracerManager;\n\n},{\"../app\":3,\"../dom/module_container\":8,\"../dom/top_menu\":25}],66:[function(require,module,exports){\n'use strict';\n\nvar parse = JSON.parse;\n\n\nvar fromJSON = function fromJSON(obj) {\n return parse(obj, function (key, value) {\n return value === 'Infinity' ? Infinity : value;\n });\n};\n\nmodule.exports = fromJSON;\n\n},{}],67:[function(require,module,exports){\n'use strict';\n\nvar toJSON = require('./to_json');\nvar fromJSON = require('./from_json');\nvar refineByType = require('./refine_by_type');\n\nmodule.exports = {\n toJSON: toJSON,\n fromJSON: fromJSON,\n refineByType: refineByType\n};\n\n},{\"./from_json\":66,\"./refine_by_type\":68,\"./to_json\":69}],68:[function(require,module,exports){\n'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol ? \"symbol\" : typeof obj; };\n\nvar refineByType = function refineByType(item) {\n switch (typeof item === 'undefined' ? 'undefined' : _typeof(item)) {\n case 'number':\n return refineNumber(item);\n case 'boolean':\n return refineBoolean(item);\n default:\n return refineString(item);\n }\n};\n\nvar refineString = function refineString(str) {\n return str === '' ? ' ' : str;\n};\n\nvar refineNumber = function refineNumber(num) {\n return num === Infinity ? '∞' : num;\n};\n\nvar refineBoolean = function refineBoolean(bool) {\n return bool ? 'T' : 'F';\n};\n\nmodule.exports = refineByType;\n\n},{}],69:[function(require,module,exports){\n'use strict';\n\nvar stringify = JSON.stringify;\n\n\nvar toJSON = function toJSON(obj) {\n return stringify(obj, function (key, value) {\n return value === Infinity ? 'Infinity' : value;\n });\n};\n\nmodule.exports = toJSON;\n\n},{}],70:[function(require,module,exports){\n'use strict';\n\nvar isScratchPaper = function isScratchPaper(category, algorithm) {\n return category == 'scratch';\n};\n\nvar getAlgorithmDir = function getAlgorithmDir(category, algorithm) {\n if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n return './algorithm/' + category + '/' + algorithm + '/';\n};\n\nvar getFileDir = function getFileDir(category, algorithm, file) {\n if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n return './algorithm/' + category + '/' + algorithm + '/' + file + '/';\n};\n\nmodule.exports = {\n isScratchPaper: isScratchPaper,\n getAlgorithmDir: getAlgorithmDir,\n getFileDir: getFileDir\n};\n\n},{}],71:[function(require,module,exports){\n// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n if (!draining || !currentQueue) {\n return;\n }\n draining = false;\n if (currentQueue.length) {\n queue = currentQueue.concat(queue);\n } else {\n queueIndex = -1;\n }\n if (queue.length) {\n drainQueue();\n }\n}\n\nfunction drainQueue() {\n if (draining) {\n return;\n }\n var timeout = setTimeout(cleanUpNextTick);\n draining = true;\n\n var len = queue.length;\n while(len) {\n currentQueue = queue;\n queue = [];\n while (++queueIndex < len) {\n if (currentQueue) {\n currentQueue[queueIndex].run();\n }\n }\n queueIndex = -1;\n len = queue.length;\n }\n currentQueue = null;\n draining = false;\n clearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n var args = new Array(arguments.length - 1);\n if (arguments.length > 1) {\n for (var i = 1; i < arguments.length; i++) {\n args[i - 1] = arguments[i];\n }\n }\n queue.push(new Item(fun, args));\n if (queue.length === 1 && !draining) {\n setTimeout(drainQueue, 0);\n }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n this.fun = fun;\n this.array = array;\n}\nItem.prototype.run = function () {\n this.fun.apply(null, this.array);\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\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n\n},{}],72:[function(require,module,exports){\n(function (process,global){\n/*!\n * @overview RSVP - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors\n * @license Licensed under MIT license\n * See https://raw.githubusercontent.com/tildeio/rsvp.js/master/LICENSE\n * @version 3.2.1\n */\n\n(function() {\n \"use strict\";\n function lib$rsvp$utils$$objectOrFunction(x) {\n return typeof x === 'function' || (typeof x === 'object' && x !== null);\n }\n\n function lib$rsvp$utils$$isFunction(x) {\n return typeof x === 'function';\n }\n\n function lib$rsvp$utils$$isMaybeThenable(x) {\n return typeof x === 'object' && x !== null;\n }\n\n var lib$rsvp$utils$$_isArray;\n if (!Array.isArray) {\n lib$rsvp$utils$$_isArray = function (x) {\n return Object.prototype.toString.call(x) === '[object Array]';\n };\n } else {\n lib$rsvp$utils$$_isArray = Array.isArray;\n }\n\n var lib$rsvp$utils$$isArray = lib$rsvp$utils$$_isArray;\n\n var lib$rsvp$utils$$now = Date.now || function() { return new Date().getTime(); };\n\n function lib$rsvp$utils$$F() { }\n\n var lib$rsvp$utils$$o_create = (Object.create || function (o) {\n if (arguments.length > 1) {\n throw new Error('Second argument not supported');\n }\n if (typeof o !== 'object') {\n throw new TypeError('Argument must be an object');\n }\n lib$rsvp$utils$$F.prototype = o;\n return new lib$rsvp$utils$$F();\n });\n function lib$rsvp$events$$indexOf(callbacks, callback) {\n for (var i=0, l=callbacks.length; i<l; i++) {\n if (callbacks[i] === callback) { return i; }\n }\n\n return -1;\n }\n\n function lib$rsvp$events$$callbacksFor(object) {\n var callbacks = object._promiseCallbacks;\n\n if (!callbacks) {\n callbacks = object._promiseCallbacks = {};\n }\n\n return callbacks;\n }\n\n var lib$rsvp$events$$default = {\n\n /**\n `RSVP.EventTarget.mixin` extends an object with EventTarget methods. For\n Example:\n\n ```javascript\n var object = {};\n\n RSVP.EventTarget.mixin(object);\n\n object.on('finished', function(event) {\n // handle event\n });\n\n object.trigger('finished', { detail: value });\n ```\n\n `EventTarget.mixin` also works with prototypes:\n\n ```javascript\n var Person = function() {};\n RSVP.EventTarget.mixin(Person.prototype);\n\n var yehuda = new Person();\n var tom = new Person();\n\n yehuda.on('poke', function(event) {\n console.log('Yehuda says OW');\n });\n\n tom.on('poke', function(event) {\n console.log('Tom says OW');\n });\n\n yehuda.trigger('poke');\n tom.trigger('poke');\n ```\n\n @method mixin\n @for RSVP.EventTarget\n @private\n @param {Object} object object to extend with EventTarget methods\n */\n 'mixin': function(object) {\n object['on'] = this['on'];\n object['off'] = this['off'];\n object['trigger'] = this['trigger'];\n object._promiseCallbacks = undefined;\n return object;\n },\n\n /**\n Registers a callback to be executed when `eventName` is triggered\n\n ```javascript\n object.on('event', function(eventInfo){\n // handle the event\n });\n\n object.trigger('event');\n ```\n\n @method on\n @for RSVP.EventTarget\n @private\n @param {String} eventName name of the event to listen for\n @param {Function} callback function to be called when the event is triggered.\n */\n 'on': function(eventName, callback) {\n if (typeof callback !== 'function') {\n throw new TypeError('Callback must be a function');\n }\n\n var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks;\n\n callbacks = allCallbacks[eventName];\n\n if (!callbacks) {\n callbacks = allCallbacks[eventName] = [];\n }\n\n if (lib$rsvp$events$$indexOf(callbacks, callback) === -1) {\n callbacks.push(callback);\n }\n },\n\n /**\n You can use `off` to stop firing a particular callback for an event:\n\n ```javascript\n function doStuff() { // do stuff! }\n object.on('stuff', doStuff);\n\n object.trigger('stuff'); // doStuff will be called\n\n // Unregister ONLY the doStuff callback\n object.off('stuff', doStuff);\n object.trigger('stuff'); // doStuff will NOT be called\n ```\n\n If you don't pass a `callback` argument to `off`, ALL callbacks for the\n event will not be executed when the event fires. For example:\n\n ```javascript\n var callback1 = function(){};\n var callback2 = function(){};\n\n object.on('stuff', callback1);\n object.on('stuff', callback2);\n\n object.trigger('stuff'); // callback1 and callback2 will be executed.\n\n object.off('stuff');\n object.trigger('stuff'); // callback1 and callback2 will not be executed!\n ```\n\n @method off\n @for RSVP.EventTarget\n @private\n @param {String} eventName event to stop listening to\n @param {Function} callback optional argument. If given, only the function\n given will be removed from the event's callback queue. If no `callback`\n argument is given, all callbacks will be removed from the event's callback\n queue.\n */\n 'off': function(eventName, callback) {\n var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, index;\n\n if (!callback) {\n allCallbacks[eventName] = [];\n return;\n }\n\n callbacks = allCallbacks[eventName];\n\n index = lib$rsvp$events$$indexOf(callbacks, callback);\n\n if (index !== -1) { callbacks.splice(index, 1); }\n },\n\n /**\n Use `trigger` to fire custom events. For example:\n\n ```javascript\n object.on('foo', function(){\n console.log('foo event happened!');\n });\n object.trigger('foo');\n // 'foo event happened!' logged to the console\n ```\n\n You can also pass a value as a second argument to `trigger` that will be\n passed as an argument to all event listeners for the event:\n\n ```javascript\n object.on('foo', function(value){\n console.log(value.name);\n });\n\n object.trigger('foo', { name: 'bar' });\n // 'bar' logged to the console\n ```\n\n @method trigger\n @for RSVP.EventTarget\n @private\n @param {String} eventName name of the event to be triggered\n @param {*} options optional value to be passed to any event handlers for\n the given `eventName`\n */\n 'trigger': function(eventName, options, label) {\n var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, callback;\n\n if (callbacks = allCallbacks[eventName]) {\n // Don't cache the callbacks.length since it may grow\n for (var i=0; i<callbacks.length; i++) {\n callback = callbacks[i];\n\n callback(options, label);\n }\n }\n }\n };\n\n var lib$rsvp$config$$config = {\n instrument: false\n };\n\n lib$rsvp$events$$default['mixin'](lib$rsvp$config$$config);\n\n function lib$rsvp$config$$configure(name, value) {\n if (name === 'onerror') {\n // handle for legacy users that expect the actual\n // error to be passed to their function added via\n // `RSVP.configure('onerror', someFunctionHere);`\n lib$rsvp$config$$config['on']('error', value);\n return;\n }\n\n if (arguments.length === 2) {\n lib$rsvp$config$$config[name] = value;\n } else {\n return lib$rsvp$config$$config[name];\n }\n }\n\n var lib$rsvp$instrument$$queue = [];\n\n function lib$rsvp$instrument$$scheduleFlush() {\n setTimeout(function() {\n var entry;\n for (var i = 0; i < lib$rsvp$instrument$$queue.length; i++) {\n entry = lib$rsvp$instrument$$queue[i];\n\n var payload = entry.payload;\n\n payload.guid = payload.key + payload.id;\n payload.childGuid = payload.key + payload.childId;\n if (payload.error) {\n payload.stack = payload.error.stack;\n }\n\n lib$rsvp$config$$config['trigger'](entry.name, entry.payload);\n }\n lib$rsvp$instrument$$queue.length = 0;\n }, 50);\n }\n\n function lib$rsvp$instrument$$instrument(eventName, promise, child) {\n if (1 === lib$rsvp$instrument$$queue.push({\n name: eventName,\n payload: {\n key: promise._guidKey,\n id: promise._id,\n eventName: eventName,\n detail: promise._result,\n childId: child && child._id,\n label: promise._label,\n timeStamp: lib$rsvp$utils$$now(),\n error: lib$rsvp$config$$config[\"instrument-with-stack\"] ? new Error(promise._label) : null\n }})) {\n lib$rsvp$instrument$$scheduleFlush();\n }\n }\n var lib$rsvp$instrument$$default = lib$rsvp$instrument$$instrument;\n function lib$rsvp$then$$then(onFulfillment, onRejection, label) {\n var parent = this;\n var state = parent._state;\n\n if (state === lib$rsvp$$internal$$FULFILLED && !onFulfillment || state === lib$rsvp$$internal$$REJECTED && !onRejection) {\n lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, parent);\n return parent;\n }\n\n parent._onError = null;\n\n var child = new parent.constructor(lib$rsvp$$internal$$noop, label);\n var result = parent._result;\n\n lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, child);\n\n if (state) {\n var callback = arguments[state - 1];\n lib$rsvp$config$$config.async(function(){\n lib$rsvp$$internal$$invokeCallback(state, child, callback, result);\n });\n } else {\n lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection);\n }\n\n return child;\n }\n var lib$rsvp$then$$default = lib$rsvp$then$$then;\n function lib$rsvp$promise$resolve$$resolve(object, label) {\n /*jshint validthis:true */\n var Constructor = this;\n\n if (object && typeof object === 'object' && object.constructor === Constructor) {\n return object;\n }\n\n var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n lib$rsvp$$internal$$resolve(promise, object);\n return promise;\n }\n var lib$rsvp$promise$resolve$$default = lib$rsvp$promise$resolve$$resolve;\n function lib$rsvp$enumerator$$makeSettledResult(state, position, value) {\n if (state === lib$rsvp$$internal$$FULFILLED) {\n return {\n state: 'fulfilled',\n value: value\n };\n } else {\n return {\n state: 'rejected',\n reason: value\n };\n }\n }\n\n function lib$rsvp$enumerator$$Enumerator(Constructor, input, abortOnReject, label) {\n this._instanceConstructor = Constructor;\n this.promise = new Constructor(lib$rsvp$$internal$$noop, label);\n this._abortOnReject = abortOnReject;\n\n if (this._validateInput(input)) {\n this._input = input;\n this.length = input.length;\n this._remaining = input.length;\n\n this._init();\n\n if (this.length === 0) {\n lib$rsvp$$internal$$fulfill(this.promise, this._result);\n } else {\n this.length = this.length || 0;\n this._enumerate();\n if (this._remaining === 0) {\n lib$rsvp$$internal$$fulfill(this.promise, this._result);\n }\n }\n } else {\n lib$rsvp$$internal$$reject(this.promise, this._validationError());\n }\n }\n\n var lib$rsvp$enumerator$$default = lib$rsvp$enumerator$$Enumerator;\n\n lib$rsvp$enumerator$$Enumerator.prototype._validateInput = function(input) {\n return lib$rsvp$utils$$isArray(input);\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._validationError = function() {\n return new Error('Array Methods must be provided an Array');\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._init = function() {\n this._result = new Array(this.length);\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._enumerate = function() {\n var length = this.length;\n var promise = this.promise;\n var input = this._input;\n\n for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n this._eachEntry(input[i], i);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._settleMaybeThenable = function(entry, i) {\n var c = this._instanceConstructor;\n var resolve = c.resolve;\n\n if (resolve === lib$rsvp$promise$resolve$$default) {\n var then = lib$rsvp$$internal$$getThen(entry);\n\n if (then === lib$rsvp$then$$default &&\n entry._state !== lib$rsvp$$internal$$PENDING) {\n entry._onError = null;\n this._settledAt(entry._state, i, entry._result);\n } else if (typeof then !== 'function') {\n this._remaining--;\n this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n } else if (c === lib$rsvp$promise$$default) {\n var promise = new c(lib$rsvp$$internal$$noop);\n lib$rsvp$$internal$$handleMaybeThenable(promise, entry, then);\n this._willSettleAt(promise, i);\n } else {\n this._willSettleAt(new c(function(resolve) { resolve(entry); }), i);\n }\n } else {\n this._willSettleAt(resolve(entry), i);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._eachEntry = function(entry, i) {\n if (lib$rsvp$utils$$isMaybeThenable(entry)) {\n this._settleMaybeThenable(entry, i);\n } else {\n this._remaining--;\n this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._settledAt = function(state, i, value) {\n var promise = this.promise;\n\n if (promise._state === lib$rsvp$$internal$$PENDING) {\n this._remaining--;\n\n if (this._abortOnReject && state === lib$rsvp$$internal$$REJECTED) {\n lib$rsvp$$internal$$reject(promise, value);\n } else {\n this._result[i] = this._makeResult(state, i, value);\n }\n }\n\n if (this._remaining === 0) {\n lib$rsvp$$internal$$fulfill(promise, this._result);\n }\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._makeResult = function(state, i, value) {\n return value;\n };\n\n lib$rsvp$enumerator$$Enumerator.prototype._willSettleAt = function(promise, i) {\n var enumerator = this;\n\n lib$rsvp$$internal$$subscribe(promise, undefined, function(value) {\n enumerator._settledAt(lib$rsvp$$internal$$FULFILLED, i, value);\n }, function(reason) {\n enumerator._settledAt(lib$rsvp$$internal$$REJECTED, i, reason);\n });\n };\n function lib$rsvp$promise$all$$all(entries, label) {\n return new lib$rsvp$enumerator$$default(this, entries, true /* abort on reject */, label).promise;\n }\n var lib$rsvp$promise$all$$default = lib$rsvp$promise$all$$all;\n function lib$rsvp$promise$race$$race(entries, label) {\n /*jshint validthis:true */\n var Constructor = this;\n\n var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n\n if (!lib$rsvp$utils$$isArray(entries)) {\n lib$rsvp$$internal$$reject(promise, new TypeError('You must pass an array to race.'));\n return promise;\n }\n\n var length = entries.length;\n\n function onFulfillment(value) {\n lib$rsvp$$internal$$resolve(promise, value);\n }\n\n function onRejection(reason) {\n lib$rsvp$$internal$$reject(promise, reason);\n }\n\n for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n lib$rsvp$$internal$$subscribe(Constructor.resolve(entries[i]), undefined, onFulfillment, onRejection);\n }\n\n return promise;\n }\n var lib$rsvp$promise$race$$default = lib$rsvp$promise$race$$race;\n function lib$rsvp$promise$reject$$reject(reason, label) {\n /*jshint validthis:true */\n var Constructor = this;\n var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n lib$rsvp$$internal$$reject(promise, reason);\n return promise;\n }\n var lib$rsvp$promise$reject$$default = lib$rsvp$promise$reject$$reject;\n\n var lib$rsvp$promise$$guidKey = 'rsvp_' + lib$rsvp$utils$$now() + '-';\n var lib$rsvp$promise$$counter = 0;\n\n function lib$rsvp$promise$$needsResolver() {\n throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n }\n\n function lib$rsvp$promise$$needsNew() {\n throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n }\n\n function lib$rsvp$promise$$Promise(resolver, label) {\n this._id = lib$rsvp$promise$$counter++;\n this._label = label;\n this._state = undefined;\n this._result = undefined;\n this._subscribers = [];\n\n lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('created', this);\n\n if (lib$rsvp$$internal$$noop !== resolver) {\n typeof resolver !== 'function' && lib$rsvp$promise$$needsResolver();\n this instanceof lib$rsvp$promise$$Promise ? lib$rsvp$$internal$$initializePromise(this, resolver) : lib$rsvp$promise$$needsNew();\n }\n }\n\n var lib$rsvp$promise$$default = lib$rsvp$promise$$Promise;\n\n // deprecated\n lib$rsvp$promise$$Promise.cast = lib$rsvp$promise$resolve$$default;\n lib$rsvp$promise$$Promise.all = lib$rsvp$promise$all$$default;\n lib$rsvp$promise$$Promise.race = lib$rsvp$promise$race$$default;\n lib$rsvp$promise$$Promise.resolve = lib$rsvp$promise$resolve$$default;\n lib$rsvp$promise$$Promise.reject = lib$rsvp$promise$reject$$default;\n\n lib$rsvp$promise$$Promise.prototype = {\n constructor: lib$rsvp$promise$$Promise,\n\n _guidKey: lib$rsvp$promise$$guidKey,\n\n _onError: function (reason) {\n var promise = this;\n lib$rsvp$config$$config.after(function() {\n if (promise._onError) {\n lib$rsvp$config$$config['trigger']('error', reason, promise._label);\n }\n });\n },\n\n /**\n The primary way of interacting with a promise is through its `then` method,\n which registers callbacks to receive either a promise's eventual value or the\n reason why the promise cannot be fulfilled.\n\n ```js\n findUser().then(function(user){\n // user is available\n }, function(reason){\n // user is unavailable, and you are given the reason why\n });\n ```\n\n Chaining\n --------\n\n The return value of `then` is itself a promise. This second, 'downstream'\n promise is resolved with the return value of the first promise's fulfillment\n or rejection handler, or rejected if the handler throws an exception.\n\n ```js\n findUser().then(function (user) {\n return user.name;\n }, function (reason) {\n return 'default name';\n }).then(function (userName) {\n // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n // will be `'default name'`\n });\n\n findUser().then(function (user) {\n throw new Error('Found user, but still unhappy');\n }, function (reason) {\n throw new Error('`findUser` rejected and we're unhappy');\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n });\n ```\n If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n\n ```js\n findUser().then(function (user) {\n throw new PedagogicalException('Upstream error');\n }).then(function (value) {\n // never reached\n }).then(function (value) {\n // never reached\n }, function (reason) {\n // The `PedgagocialException` is propagated all the way down to here\n });\n ```\n\n Assimilation\n ------------\n\n Sometimes the value you want to propagate to a downstream promise can only be\n retrieved asynchronously. This can be achieved by returning a promise in the\n fulfillment or rejection handler. The downstream promise will then be pending\n until the returned promise is settled. This is called *assimilation*.\n\n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // The user's comments are now available\n });\n ```\n\n If the assimliated promise rejects, then the downstream promise will also reject.\n\n ```js\n findUser().then(function (user) {\n return findCommentsByAuthor(user);\n }).then(function (comments) {\n // If `findCommentsByAuthor` fulfills, we'll have the value here\n }, function (reason) {\n // If `findCommentsByAuthor` rejects, we'll have the reason here\n });\n ```\n\n Simple Example\n --------------\n\n Synchronous Example\n\n ```javascript\n var result;\n\n try {\n result = findResult();\n // success\n } catch(reason) {\n // failure\n }\n ```\n\n Errback Example\n\n ```js\n findResult(function(result, err){\n if (err) {\n // failure\n } else {\n // success\n }\n });\n ```\n\n Promise Example;\n\n ```javascript\n findResult().then(function(result){\n // success\n }, function(reason){\n // failure\n });\n ```\n\n Advanced Example\n --------------\n\n Synchronous Example\n\n ```javascript\n var author, books;\n\n try {\n author = findAuthor();\n books = findBooksByAuthor(author);\n // success\n } catch(reason) {\n // failure\n }\n ```\n\n Errback Example\n\n ```js\n\n function foundBooks(books) {\n\n }\n\n function failure(reason) {\n\n }\n\n findAuthor(function(author, err){\n if (err) {\n failure(err);\n // failure\n } else {\n try {\n findBoooksByAuthor(author, function(books, err) {\n if (err) {\n failure(err);\n } else {\n try {\n foundBooks(books);\n } catch(reason) {\n failure(reason);\n }\n }\n });\n } catch(error) {\n failure(err);\n }\n // success\n }\n });\n ```\n\n Promise Example;\n\n ```javascript\n findAuthor().\n then(findBooksByAuthor).\n then(function(books){\n // found books\n }).catch(function(reason){\n // something went wrong\n });\n ```\n\n @method then\n @param {Function} onFulfillment\n @param {Function} onRejection\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise}\n */\n then: lib$rsvp$then$$default,\n\n /**\n `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n as the catch block of a try/catch statement.\n\n ```js\n function findAuthor(){\n throw new Error('couldn't find that author');\n }\n\n // synchronous\n try {\n findAuthor();\n } catch(reason) {\n // something went wrong\n }\n\n // async with promises\n findAuthor().catch(function(reason){\n // something went wrong\n });\n ```\n\n @method catch\n @param {Function} onRejection\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise}\n */\n 'catch': function(onRejection, label) {\n return this.then(undefined, onRejection, label);\n },\n\n /**\n `finally` will be invoked regardless of the promise's fate just as native\n try/catch/finally behaves\n\n Synchronous example:\n\n ```js\n findAuthor() {\n if (Math.random() > 0.5) {\n throw new Error();\n }\n return new Author();\n }\n\n try {\n return findAuthor(); // succeed or fail\n } catch(error) {\n return findOtherAuther();\n } finally {\n // always runs\n // doesn't affect the return value\n }\n ```\n\n Asynchronous example:\n\n ```js\n findAuthor().catch(function(reason){\n return findOtherAuther();\n }).finally(function(){\n // author was either found, or not\n });\n ```\n\n @method finally\n @param {Function} callback\n @param {String} label optional string for labeling the promise.\n Useful for tooling.\n @return {Promise}\n */\n 'finally': function(callback, label) {\n var promise = this;\n var constructor = promise.constructor;\n\n return promise.then(function(value) {\n return constructor.resolve(callback()).then(function() {\n return value;\n });\n }, function(reason) {\n return constructor.resolve(callback()).then(function() {\n return constructor.reject(reason);\n });\n }, label);\n }\n };\n function lib$rsvp$$internal$$withOwnPromise() {\n return new TypeError('A promises callback cannot return that same promise.');\n }\n\n function lib$rsvp$$internal$$noop() {}\n\n var lib$rsvp$$internal$$PENDING = void 0;\n var lib$rsvp$$internal$$FULFILLED = 1;\n var lib$rsvp$$internal$$REJECTED = 2;\n\n var lib$rsvp$$internal$$GET_THEN_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n function lib$rsvp$$internal$$getThen(promise) {\n try {\n return promise.then;\n } catch(error) {\n lib$rsvp$$internal$$GET_THEN_ERROR.error = error;\n return lib$rsvp$$internal$$GET_THEN_ERROR;\n }\n }\n\n function lib$rsvp$$internal$$tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n try {\n then.call(value, fulfillmentHandler, rejectionHandler);\n } catch(e) {\n return e;\n }\n }\n\n function lib$rsvp$$internal$$handleForeignThenable(promise, thenable, then) {\n lib$rsvp$config$$config.async(function(promise) {\n var sealed = false;\n var error = lib$rsvp$$internal$$tryThen(then, thenable, function(value) {\n if (sealed) { return; }\n sealed = true;\n if (thenable !== value) {\n lib$rsvp$$internal$$resolve(promise, value, undefined);\n } else {\n lib$rsvp$$internal$$fulfill(promise, value);\n }\n }, function(reason) {\n if (sealed) { return; }\n sealed = true;\n\n lib$rsvp$$internal$$reject(promise, reason);\n }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n if (!sealed && error) {\n sealed = true;\n lib$rsvp$$internal$$reject(promise, error);\n }\n }, promise);\n }\n\n function lib$rsvp$$internal$$handleOwnThenable(promise, thenable) {\n if (thenable._state === lib$rsvp$$internal$$FULFILLED) {\n lib$rsvp$$internal$$fulfill(promise, thenable._result);\n } else if (thenable._state === lib$rsvp$$internal$$REJECTED) {\n thenable._onError = null;\n lib$rsvp$$internal$$reject(promise, thenable._result);\n } else {\n lib$rsvp$$internal$$subscribe(thenable, undefined, function(value) {\n if (thenable !== value) {\n lib$rsvp$$internal$$resolve(promise, value, undefined);\n } else {\n lib$rsvp$$internal$$fulfill(promise, value);\n }\n }, function(reason) {\n lib$rsvp$$internal$$reject(promise, reason);\n });\n }\n }\n\n function lib$rsvp$$internal$$handleMaybeThenable(promise, maybeThenable, then) {\n if (maybeThenable.constructor === promise.constructor &&\n then === lib$rsvp$then$$default &&\n constructor.resolve === lib$rsvp$promise$resolve$$default) {\n lib$rsvp$$internal$$handleOwnThenable(promise, maybeThenable);\n } else {\n if (then === lib$rsvp$$internal$$GET_THEN_ERROR) {\n lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$GET_THEN_ERROR.error);\n } else if (then === undefined) {\n lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n } else if (lib$rsvp$utils$$isFunction(then)) {\n lib$rsvp$$internal$$handleForeignThenable(promise, maybeThenable, then);\n } else {\n lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n }\n }\n }\n\n function lib$rsvp$$internal$$resolve(promise, value) {\n if (promise === value) {\n lib$rsvp$$internal$$fulfill(promise, value);\n } else if (lib$rsvp$utils$$objectOrFunction(value)) {\n lib$rsvp$$internal$$handleMaybeThenable(promise, value, lib$rsvp$$internal$$getThen(value));\n } else {\n lib$rsvp$$internal$$fulfill(promise, value);\n }\n }\n\n function lib$rsvp$$internal$$publishRejection(promise) {\n if (promise._onError) {\n promise._onError(promise._result);\n }\n\n lib$rsvp$$internal$$publish(promise);\n }\n\n function lib$rsvp$$internal$$fulfill(promise, value) {\n if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n\n promise._result = value;\n promise._state = lib$rsvp$$internal$$FULFILLED;\n\n if (promise._subscribers.length === 0) {\n if (lib$rsvp$config$$config.instrument) {\n lib$rsvp$instrument$$default('fulfilled', promise);\n }\n } else {\n lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, promise);\n }\n }\n\n function lib$rsvp$$internal$$reject(promise, reason) {\n if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n promise._state = lib$rsvp$$internal$$REJECTED;\n promise._result = reason;\n lib$rsvp$config$$config.async(lib$rsvp$$internal$$publishRejection, promise);\n }\n\n function lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection) {\n var subscribers = parent._subscribers;\n var length = subscribers.length;\n\n parent._onError = null;\n\n subscribers[length] = child;\n subscribers[length + lib$rsvp$$internal$$FULFILLED] = onFulfillment;\n subscribers[length + lib$rsvp$$internal$$REJECTED] = onRejection;\n\n if (length === 0 && parent._state) {\n lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, parent);\n }\n }\n\n function lib$rsvp$$internal$$publish(promise) {\n var subscribers = promise._subscribers;\n var settled = promise._state;\n\n if (lib$rsvp$config$$config.instrument) {\n lib$rsvp$instrument$$default(settled === lib$rsvp$$internal$$FULFILLED ? 'fulfilled' : 'rejected', promise);\n }\n\n if (subscribers.length === 0) { return; }\n\n var child, callback, detail = promise._result;\n\n for (var i = 0; i < subscribers.length; i += 3) {\n child = subscribers[i];\n callback = subscribers[i + settled];\n\n if (child) {\n lib$rsvp$$internal$$invokeCallback(settled, child, callback, detail);\n } else {\n callback(detail);\n }\n }\n\n promise._subscribers.length = 0;\n }\n\n function lib$rsvp$$internal$$ErrorObject() {\n this.error = null;\n }\n\n var lib$rsvp$$internal$$TRY_CATCH_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n function lib$rsvp$$internal$$tryCatch(callback, detail) {\n try {\n return callback(detail);\n } catch(e) {\n lib$rsvp$$internal$$TRY_CATCH_ERROR.error = e;\n return lib$rsvp$$internal$$TRY_CATCH_ERROR;\n }\n }\n\n function lib$rsvp$$internal$$invokeCallback(settled, promise, callback, detail) {\n var hasCallback = lib$rsvp$utils$$isFunction(callback),\n value, error, succeeded, failed;\n\n if (hasCallback) {\n value = lib$rsvp$$internal$$tryCatch(callback, detail);\n\n if (value === lib$rsvp$$internal$$TRY_CATCH_ERROR) {\n failed = true;\n error = value.error;\n value = null;\n } else {\n succeeded = true;\n }\n\n if (promise === value) {\n lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$withOwnPromise());\n return;\n }\n\n } else {\n value = detail;\n succeeded = true;\n }\n\n if (promise._state !== lib$rsvp$$internal$$PENDING) {\n // noop\n } else if (hasCallback && succeeded) {\n lib$rsvp$$internal$$resolve(promise, value);\n } else if (failed) {\n lib$rsvp$$internal$$reject(promise, error);\n } else if (settled === lib$rsvp$$internal$$FULFILLED) {\n lib$rsvp$$internal$$fulfill(promise, value);\n } else if (settled === lib$rsvp$$internal$$REJECTED) {\n lib$rsvp$$internal$$reject(promise, value);\n }\n }\n\n function lib$rsvp$$internal$$initializePromise(promise, resolver) {\n var resolved = false;\n try {\n resolver(function resolvePromise(value){\n if (resolved) { return; }\n resolved = true;\n lib$rsvp$$internal$$resolve(promise, value);\n }, function rejectPromise(reason) {\n if (resolved) { return; }\n resolved = true;\n lib$rsvp$$internal$$reject(promise, reason);\n });\n } catch(e) {\n lib$rsvp$$internal$$reject(promise, e);\n }\n }\n\n function lib$rsvp$all$settled$$AllSettled(Constructor, entries, label) {\n this._superConstructor(Constructor, entries, false /* don't abort on reject */, label);\n }\n\n lib$rsvp$all$settled$$AllSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n lib$rsvp$all$settled$$AllSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n lib$rsvp$all$settled$$AllSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n lib$rsvp$all$settled$$AllSettled.prototype._validationError = function() {\n return new Error('allSettled must be called with an array');\n };\n\n function lib$rsvp$all$settled$$allSettled(entries, label) {\n return new lib$rsvp$all$settled$$AllSettled(lib$rsvp$promise$$default, entries, label).promise;\n }\n var lib$rsvp$all$settled$$default = lib$rsvp$all$settled$$allSettled;\n function lib$rsvp$all$$all(array, label) {\n return lib$rsvp$promise$$default.all(array, label);\n }\n var lib$rsvp$all$$default = lib$rsvp$all$$all;\n var lib$rsvp$asap$$len = 0;\n var lib$rsvp$asap$$toString = {}.toString;\n var lib$rsvp$asap$$vertxNext;\n function lib$rsvp$asap$$asap(callback, arg) {\n lib$rsvp$asap$$queue[lib$rsvp$asap$$len] = callback;\n lib$rsvp$asap$$queue[lib$rsvp$asap$$len + 1] = arg;\n lib$rsvp$asap$$len += 2;\n if (lib$rsvp$asap$$len === 2) {\n // If len is 1, that means that we need to schedule an async flush.\n // If additional callbacks are queued before the queue is flushed, they\n // will be processed by this flush that we are scheduling.\n lib$rsvp$asap$$scheduleFlush();\n }\n }\n\n var lib$rsvp$asap$$default = lib$rsvp$asap$$asap;\n\n var lib$rsvp$asap$$browserWindow = (typeof window !== 'undefined') ? window : undefined;\n var lib$rsvp$asap$$browserGlobal = lib$rsvp$asap$$browserWindow || {};\n var lib$rsvp$asap$$BrowserMutationObserver = lib$rsvp$asap$$browserGlobal.MutationObserver || lib$rsvp$asap$$browserGlobal.WebKitMutationObserver;\n var lib$rsvp$asap$$isNode = typeof self === 'undefined' &&\n typeof process !== 'undefined' && {}.toString.call(process) === '[object process]';\n\n // test for web worker but not in IE10\n var lib$rsvp$asap$$isWorker = typeof Uint8ClampedArray !== 'undefined' &&\n typeof importScripts !== 'undefined' &&\n typeof MessageChannel !== 'undefined';\n\n // node\n function lib$rsvp$asap$$useNextTick() {\n var nextTick = process.nextTick;\n // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n // setImmediate should be used instead instead\n var version = process.versions.node.match(/^(?:(\\d+)\\.)?(?:(\\d+)\\.)?(\\*|\\d+)$/);\n if (Array.isArray(version) && version[1] === '0' && version[2] === '10') {\n nextTick = setImmediate;\n }\n return function() {\n nextTick(lib$rsvp$asap$$flush);\n };\n }\n\n // vertx\n function lib$rsvp$asap$$useVertxTimer() {\n return function() {\n lib$rsvp$asap$$vertxNext(lib$rsvp$asap$$flush);\n };\n }\n\n function lib$rsvp$asap$$useMutationObserver() {\n var iterations = 0;\n var observer = new lib$rsvp$asap$$BrowserMutationObserver(lib$rsvp$asap$$flush);\n var node = document.createTextNode('');\n observer.observe(node, { characterData: true });\n\n return function() {\n node.data = (iterations = ++iterations % 2);\n };\n }\n\n // web worker\n function lib$rsvp$asap$$useMessageChannel() {\n var channel = new MessageChannel();\n channel.port1.onmessage = lib$rsvp$asap$$flush;\n return function () {\n channel.port2.postMessage(0);\n };\n }\n\n function lib$rsvp$asap$$useSetTimeout() {\n return function() {\n setTimeout(lib$rsvp$asap$$flush, 1);\n };\n }\n\n var lib$rsvp$asap$$queue = new Array(1000);\n function lib$rsvp$asap$$flush() {\n for (var i = 0; i < lib$rsvp$asap$$len; i+=2) {\n var callback = lib$rsvp$asap$$queue[i];\n var arg = lib$rsvp$asap$$queue[i+1];\n\n callback(arg);\n\n lib$rsvp$asap$$queue[i] = undefined;\n lib$rsvp$asap$$queue[i+1] = undefined;\n }\n\n lib$rsvp$asap$$len = 0;\n }\n\n function lib$rsvp$asap$$attemptVertex() {\n try {\n var r = require;\n var vertx = r('vertx');\n lib$rsvp$asap$$vertxNext = vertx.runOnLoop || vertx.runOnContext;\n return lib$rsvp$asap$$useVertxTimer();\n } catch(e) {\n return lib$rsvp$asap$$useSetTimeout();\n }\n }\n\n var lib$rsvp$asap$$scheduleFlush;\n // Decide what async method to use to triggering processing of queued callbacks:\n if (lib$rsvp$asap$$isNode) {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useNextTick();\n } else if (lib$rsvp$asap$$BrowserMutationObserver) {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMutationObserver();\n } else if (lib$rsvp$asap$$isWorker) {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMessageChannel();\n } else if (lib$rsvp$asap$$browserWindow === undefined && typeof require === 'function') {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$attemptVertex();\n } else {\n lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useSetTimeout();\n }\n function lib$rsvp$defer$$defer(label) {\n var deferred = {};\n\n deferred['promise'] = new lib$rsvp$promise$$default(function(resolve, reject) {\n deferred['resolve'] = resolve;\n deferred['reject'] = reject;\n }, label);\n\n return deferred;\n }\n var lib$rsvp$defer$$default = lib$rsvp$defer$$defer;\n function lib$rsvp$filter$$filter(promises, filterFn, label) {\n return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n if (!lib$rsvp$utils$$isFunction(filterFn)) {\n throw new TypeError(\"You must pass a function as filter's second argument.\");\n }\n\n var length = values.length;\n var filtered = new Array(length);\n\n for (var i = 0; i < length; i++) {\n filtered[i] = filterFn(values[i]);\n }\n\n return lib$rsvp$promise$$default.all(filtered, label).then(function(filtered) {\n var results = new Array(length);\n var newLength = 0;\n\n for (var i = 0; i < length; i++) {\n if (filtered[i]) {\n results[newLength] = values[i];\n newLength++;\n }\n }\n\n results.length = newLength;\n\n return results;\n });\n });\n }\n var lib$rsvp$filter$$default = lib$rsvp$filter$$filter;\n\n function lib$rsvp$promise$hash$$PromiseHash(Constructor, object, label) {\n this._superConstructor(Constructor, object, true, label);\n }\n\n var lib$rsvp$promise$hash$$default = lib$rsvp$promise$hash$$PromiseHash;\n\n lib$rsvp$promise$hash$$PromiseHash.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n lib$rsvp$promise$hash$$PromiseHash.prototype._superConstructor = lib$rsvp$enumerator$$default;\n lib$rsvp$promise$hash$$PromiseHash.prototype._init = function() {\n this._result = {};\n };\n\n lib$rsvp$promise$hash$$PromiseHash.prototype._validateInput = function(input) {\n return input && typeof input === 'object';\n };\n\n lib$rsvp$promise$hash$$PromiseHash.prototype._validationError = function() {\n return new Error('Promise.hash must be called with an object');\n };\n\n lib$rsvp$promise$hash$$PromiseHash.prototype._enumerate = function() {\n var enumerator = this;\n var promise = enumerator.promise;\n var input = enumerator._input;\n var results = [];\n\n for (var key in input) {\n if (promise._state === lib$rsvp$$internal$$PENDING && Object.prototype.hasOwnProperty.call(input, key)) {\n results.push({\n position: key,\n entry: input[key]\n });\n }\n }\n\n var length = results.length;\n enumerator._remaining = length;\n var result;\n\n for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n result = results[i];\n enumerator._eachEntry(result.entry, result.position);\n }\n };\n\n function lib$rsvp$hash$settled$$HashSettled(Constructor, object, label) {\n this._superConstructor(Constructor, object, false, label);\n }\n\n lib$rsvp$hash$settled$$HashSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$promise$hash$$default.prototype);\n lib$rsvp$hash$settled$$HashSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n lib$rsvp$hash$settled$$HashSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n\n lib$rsvp$hash$settled$$HashSettled.prototype._validationError = function() {\n return new Error('hashSettled must be called with an object');\n };\n\n function lib$rsvp$hash$settled$$hashSettled(object, label) {\n return new lib$rsvp$hash$settled$$HashSettled(lib$rsvp$promise$$default, object, label).promise;\n }\n var lib$rsvp$hash$settled$$default = lib$rsvp$hash$settled$$hashSettled;\n function lib$rsvp$hash$$hash(object, label) {\n return new lib$rsvp$promise$hash$$default(lib$rsvp$promise$$default, object, label).promise;\n }\n var lib$rsvp$hash$$default = lib$rsvp$hash$$hash;\n function lib$rsvp$map$$map(promises, mapFn, label) {\n return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n if (!lib$rsvp$utils$$isFunction(mapFn)) {\n throw new TypeError(\"You must pass a function as map's second argument.\");\n }\n\n var length = values.length;\n var results = new Array(length);\n\n for (var i = 0; i < length; i++) {\n results[i] = mapFn(values[i]);\n }\n\n return lib$rsvp$promise$$default.all(results, label);\n });\n }\n var lib$rsvp$map$$default = lib$rsvp$map$$map;\n\n function lib$rsvp$node$$Result() {\n this.value = undefined;\n }\n\n var lib$rsvp$node$$ERROR = new lib$rsvp$node$$Result();\n var lib$rsvp$node$$GET_THEN_ERROR = new lib$rsvp$node$$Result();\n\n function lib$rsvp$node$$getThen(obj) {\n try {\n return obj.then;\n } catch(error) {\n lib$rsvp$node$$ERROR.value= error;\n return lib$rsvp$node$$ERROR;\n }\n }\n\n\n function lib$rsvp$node$$tryApply(f, s, a) {\n try {\n f.apply(s, a);\n } catch(error) {\n lib$rsvp$node$$ERROR.value = error;\n return lib$rsvp$node$$ERROR;\n }\n }\n\n function lib$rsvp$node$$makeObject(_, argumentNames) {\n var obj = {};\n var name;\n var i;\n var length = _.length;\n var args = new Array(length);\n\n for (var x = 0; x < length; x++) {\n args[x] = _[x];\n }\n\n for (i = 0; i < argumentNames.length; i++) {\n name = argumentNames[i];\n obj[name] = args[i + 1];\n }\n\n return obj;\n }\n\n function lib$rsvp$node$$arrayResult(_) {\n var length = _.length;\n var args = new Array(length - 1);\n\n for (var i = 1; i < length; i++) {\n args[i - 1] = _[i];\n }\n\n return args;\n }\n\n function lib$rsvp$node$$wrapThenable(then, promise) {\n return {\n then: function(onFulFillment, onRejection) {\n return then.call(promise, onFulFillment, onRejection);\n }\n };\n }\n\n function lib$rsvp$node$$denodeify(nodeFunc, options) {\n var fn = function() {\n var self = this;\n var l = arguments.length;\n var args = new Array(l + 1);\n var arg;\n var promiseInput = false;\n\n for (var i = 0; i < l; ++i) {\n arg = arguments[i];\n\n if (!promiseInput) {\n // TODO: clean this up\n promiseInput = lib$rsvp$node$$needsPromiseInput(arg);\n if (promiseInput === lib$rsvp$node$$GET_THEN_ERROR) {\n var p = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n lib$rsvp$$internal$$reject(p, lib$rsvp$node$$GET_THEN_ERROR.value);\n return p;\n } else if (promiseInput && promiseInput !== true) {\n arg = lib$rsvp$node$$wrapThenable(promiseInput, arg);\n }\n }\n args[i] = arg;\n }\n\n var promise = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n\n args[l] = function(err, val) {\n if (err)\n lib$rsvp$$internal$$reject(promise, err);\n else if (options === undefined)\n lib$rsvp$$internal$$resolve(promise, val);\n else if (options === true)\n lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$arrayResult(arguments));\n else if (lib$rsvp$utils$$isArray(options))\n lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$makeObject(arguments, options));\n else\n lib$rsvp$$internal$$resolve(promise, val);\n };\n\n if (promiseInput) {\n return lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self);\n } else {\n return lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self);\n }\n };\n\n fn.__proto__ = nodeFunc;\n\n return fn;\n }\n\n var lib$rsvp$node$$default = lib$rsvp$node$$denodeify;\n\n function lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self) {\n var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n if (result === lib$rsvp$node$$ERROR) {\n lib$rsvp$$internal$$reject(promise, result.value);\n }\n return promise;\n }\n\n function lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self){\n return lib$rsvp$promise$$default.all(args).then(function(args){\n var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n if (result === lib$rsvp$node$$ERROR) {\n lib$rsvp$$internal$$reject(promise, result.value);\n }\n return promise;\n });\n }\n\n function lib$rsvp$node$$needsPromiseInput(arg) {\n if (arg && typeof arg === 'object') {\n if (arg.constructor === lib$rsvp$promise$$default) {\n return true;\n } else {\n return lib$rsvp$node$$getThen(arg);\n }\n } else {\n return false;\n }\n }\n var lib$rsvp$platform$$platform;\n\n /* global self */\n if (typeof self === 'object') {\n lib$rsvp$platform$$platform = self;\n\n /* global global */\n } else if (typeof global === 'object') {\n lib$rsvp$platform$$platform = global;\n } else {\n throw new Error('no global: `self` or `global` found');\n }\n\n var lib$rsvp$platform$$default = lib$rsvp$platform$$platform;\n function lib$rsvp$race$$race(array, label) {\n return lib$rsvp$promise$$default.race(array, label);\n }\n var lib$rsvp$race$$default = lib$rsvp$race$$race;\n function lib$rsvp$reject$$reject(reason, label) {\n return lib$rsvp$promise$$default.reject(reason, label);\n }\n var lib$rsvp$reject$$default = lib$rsvp$reject$$reject;\n function lib$rsvp$resolve$$resolve(value, label) {\n return lib$rsvp$promise$$default.resolve(value, label);\n }\n var lib$rsvp$resolve$$default = lib$rsvp$resolve$$resolve;\n function lib$rsvp$rethrow$$rethrow(reason) {\n setTimeout(function() {\n throw reason;\n });\n throw reason;\n }\n var lib$rsvp$rethrow$$default = lib$rsvp$rethrow$$rethrow;\n\n // defaults\n lib$rsvp$config$$config.async = lib$rsvp$asap$$default;\n lib$rsvp$config$$config.after = function(cb) {\n setTimeout(cb, 0);\n };\n var lib$rsvp$$cast = lib$rsvp$resolve$$default;\n function lib$rsvp$$async(callback, arg) {\n lib$rsvp$config$$config.async(callback, arg);\n }\n\n function lib$rsvp$$on() {\n lib$rsvp$config$$config['on'].apply(lib$rsvp$config$$config, arguments);\n }\n\n function lib$rsvp$$off() {\n lib$rsvp$config$$config['off'].apply(lib$rsvp$config$$config, arguments);\n }\n\n // Set up instrumentation through `window.__PROMISE_INTRUMENTATION__`\n if (typeof window !== 'undefined' && typeof window['__PROMISE_INSTRUMENTATION__'] === 'object') {\n var lib$rsvp$$callbacks = window['__PROMISE_INSTRUMENTATION__'];\n lib$rsvp$config$$configure('instrument', true);\n for (var lib$rsvp$$eventName in lib$rsvp$$callbacks) {\n if (lib$rsvp$$callbacks.hasOwnProperty(lib$rsvp$$eventName)) {\n lib$rsvp$$on(lib$rsvp$$eventName, lib$rsvp$$callbacks[lib$rsvp$$eventName]);\n }\n }\n }\n\n var lib$rsvp$umd$$RSVP = {\n 'race': lib$rsvp$race$$default,\n 'Promise': lib$rsvp$promise$$default,\n 'allSettled': lib$rsvp$all$settled$$default,\n 'hash': lib$rsvp$hash$$default,\n 'hashSettled': lib$rsvp$hash$settled$$default,\n 'denodeify': lib$rsvp$node$$default,\n 'on': lib$rsvp$$on,\n 'off': lib$rsvp$$off,\n 'map': lib$rsvp$map$$default,\n 'filter': lib$rsvp$filter$$default,\n 'resolve': lib$rsvp$resolve$$default,\n 'reject': lib$rsvp$reject$$default,\n 'all': lib$rsvp$all$$default,\n 'rethrow': lib$rsvp$rethrow$$default,\n 'defer': lib$rsvp$defer$$default,\n 'EventTarget': lib$rsvp$events$$default,\n 'configure': lib$rsvp$config$$configure,\n 'async': lib$rsvp$$async\n };\n\n /* global define:true module:true window: true */\n if (typeof define === 'function' && define['amd']) {\n define(function() { return lib$rsvp$umd$$RSVP; });\n } else if (typeof module !== 'undefined' && module['exports']) {\n module['exports'] = lib$rsvp$umd$$RSVP;\n } else if (typeof lib$rsvp$platform$$default !== 'undefined') {\n lib$rsvp$platform$$default['RSVP'] = lib$rsvp$umd$$RSVP;\n }\n}).call(this);\n\n\n}).call(this,require('_process'),typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n\n},{\"_process\":71}]},{},[29])\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","js/app/cache.js","js/app/constructor.js","js/app/index.js","js/dom/add_categories.js","js/dom/add_files.js","js/dom/index.js","js/dom/loading_slider.js","js/dom/module_container.js","js/dom/setup/index.js","js/dom/setup/setup_dividers.js","js/dom/setup/setup_document.js","js/dom/setup/setup_files_bar.js","js/dom/setup/setup_interval.js","js/dom/setup/setup_module_container.js","js/dom/setup/setup_side_menu.js","js/dom/setup/setup_tab_container.js","js/dom/setup/setup_top_menu.js","js/dom/setup/setup_window.js","js/dom/show_algorithm.js","js/dom/show_description.js","js/dom/show_first_algorithm.js","js/dom/show_requested_algorithm.js","js/dom/show_wiki.js","js/dom/toast.js","js/dom/top_menu.js","js/editor/create.js","js/editor/executor.js","js/editor/index.js","js/index.js","js/module/data/array1d.js","js/module/data/array2d.js","js/module/data/coordinate_system.js","js/module/data/directed_graph.js","js/module/data/index.js","js/module/data/integer.js","js/module/data/undirected_graph.js","js/module/data/weighted_directed_graph.js","js/module/data/weighted_undirected_graph.js","js/module/index.js","js/module/tracer/array1d.js","js/module/tracer/array2d.js","js/module/tracer/chart.js","js/module/tracer/coordinate_system.js","js/module/tracer/directed_graph.js","js/module/tracer/index.js","js/module/tracer/log.js","js/module/tracer/tracer.js","js/module/tracer/undirected_graph.js","js/module/tracer/weighted_directed_graph.js","js/module/tracer/weighted_undirected_graph.js","js/server/ajax/get.js","js/server/ajax/get_json.js","js/server/ajax/post_json.js","js/server/ajax/request.js","js/server/helpers.js","js/server/index.js","js/server/load_algorithm.js","js/server/load_categories.js","js/server/load_file.js","js/server/load_scratch_paper.js","js/server/load_wiki.js","js/server/load_wiki_list.js","js/server/share_scratch_paper.js","js/tracer_manager/index.js","js/tracer_manager/manager.js","js/tracer_manager/util/from_json.js","js/tracer_manager/util/index.js","js/tracer_manager/util/refine_by_type.js","js/tracer_manager/util/to_json.js","js/utils/index.js","node_modules/process/browser.js","node_modules/rsvp/dist/rsvp.js"],"names":[],"mappings":"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AGF,IAAM,SAAS,SAAT,MAAS,CAAC,GAAD,EAAS;AACtB,SAAO,UAAU,GAAV,EAAe,UAAC,GAAD,EAAM,KAAN,EAAgB;AACpC,WAAO,UAAU,QAAV,GAAqB,UAArB,GAAkC,KAAzC;AACD,GAFM,CAAP;AAGD,CAJD;;AAMA,OAAO,OAAP,GAAiB,MAAjB;;;ACZA;;AAEA,IAAM,iBAAiB,SAAjB,cAAiB,CAAC,QAAD,EAAW,SAAX,EAAyB;AAC9C,SAAO,YAAY,SAAnB;AACD,CAFD;;AAIA,IAAM,kBAAkB,SAAlB,eAAkB,CAAC,QAAD,EAAW,SAAX,EAAyB;AAC/C,MAAI,eAAe,QAAf,CAAJ,EAA8B,OAAO,4BAAP;AAC9B,0BAAsB,QAAtB,SAAkC,SAAlC;AACD,CAHD;;AAKA,IAAM,aAAa,SAAb,UAAa,CAAC,QAAD,EAAW,SAAX,EAAsB,IAAtB,EAA+B;AAChD,MAAI,eAAe,QAAf,CAAJ,EAA8B,OAAO,4BAAP;AAC9B,0BAAsB,QAAtB,SAAkC,SAAlC,SAA+C,IAA/C;AACD,CAHD;;AAKA,OAAO,OAAP,GAAiB;AACf,gCADe;AAEf,kCAFe;AAGf;AAHe,CAAjB;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC9FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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})","'use strict';\n\nconst {\n  extend\n} = $;\n\nconst cache = {\n  lastFileUsed: '',\n  files: {}\n};\n\nconst assertFileName = (name) => {\n  if (!name) {\n    throw 'Missing file name';\n  }\n};\n\n\n/**\n * Global application cache\n */\nmodule.exports = {\n\n  getCachedFile(name) {\n    assertFileName(name);\n    return cache.files[name];\n  },\n\n  updateCachedFile(name, updates) {\n    assertFileName(name);\n    if (!cache.files[name]) {\n      cache.files[name] = {};\n    }\n    extend(cache.files[name], updates);\n  },\n\n  getLastFileUsed() {\n    return cache.lastFileUsed;\n  },\n\n  setLastFileUsed(file) {\n    cache.lastFileUsed = file;\n  }\n};","'use strict';\n\nconst Editor = require('../editor');\nconst TracerManager = require('../tracer_manager');\nconst DOM = require('../dom/setup');\n\nconst {\n  showLoadingSlider,\n  hideLoadingSlider\n} = require('../dom/loading_slider');\n\nconst Cache = require('./cache');\n\nconst state = {\n  isLoading: null,\n  editor: null,\n  tracerManager: null,\n  categories: null,\n  loadedScratch: null,\n  wikiList: null\n};\n\nconst initState = (tracerManager) => {\n  state.isLoading = false;\n  state.editor = new Editor(tracerManager);\n  state.tracerManager = tracerManager;\n  state.categories = {};\n  state.loadedScratch = null;\n  state.wikiList = [];\n};\n\n/**\n * Global application singleton.\n */\nconst App = function () {\n\n  this.getIsLoading = () => {\n    return state.isLoading;\n  };\n\n  this.setIsLoading = (loading) => {\n    state.isLoading = loading;\n    if (loading) {\n      showLoadingSlider();\n    } else {\n      hideLoadingSlider();\n    }\n  };\n\n  this.getEditor = () => {\n    return state.editor;\n  };\n\n  this.getCategories = () => {\n    return state.categories;\n  };\n\n  this.getCategory = (name) => {\n    return state.categories[name];\n  };\n\n  this.setCategories = (categories) => {\n    state.categories = categories;\n  };\n\n  this.updateCategory = (name, updates) => {\n    $.extend(state.categories[name], updates);\n  };\n\n  this.getTracerManager = () => {\n    return state.tracerManager;\n  };\n\n  this.getLoadedScratch = () => {\n    return state.loadedScratch;\n  };\n\n  this.setLoadedScratch = (loadedScratch) => {\n    state.loadedScratch = loadedScratch;\n  };\n\n  this.getWikiList = () => {\n    return state.wikiList;\n  };\n\n  this.setWikiList = (wikiList) => {\n    state.wikiList = wikiList;\n  };\n\n  this.hasWiki = (wiki) => {\n    return ~state.wikiList.indexOf(wiki);\n  };\n\n  const tracerManager = TracerManager.init();\n\n  initState(tracerManager);\n  DOM.setup(tracerManager);\n\n};\n\nApp.prototype = Cache;\n\nmodule.exports = App;\n","'use strict';\n\n/**\n * This is the main application instance.\n * Gets populated on page load. \n */\nmodule.exports = {};","'use strict';\n\nconst app = require('../app');\nconst Server = require('../server');\nconst showAlgorithm = require('./show_algorithm');\n\nconst {\n  each\n} = $;\n\nconst getAlgorithmDOM = (category, subList, algorithm) => {\n  return $('<button class=\"indent\">')\n    .append(subList[algorithm])\n    .attr('data-algorithm', algorithm)\n    .attr('data-category', category)\n    .click(function () {\n      Server.loadAlgorithm(category, algorithm).then((data) => {\n        showAlgorithm(category, algorithm, data);\n      });\n    });\n\n  $('#list').append($algorithm);\n};\n\nconst addCategoryToDOM = (category) => {\n\n  const {\n    name: categoryName,\n    list: categorySubList\n  } = app.getCategory(category);\n\n  const $category = $('<button class=\"category\">')\n    .append('<i class=\"fa fa-fw fa-caret-right\">')\n    .append(categoryName)\n    .attr('data-category', category);\n\n  $category.click(function () {\n    const $self = $(this);\n    $self.toggleClass('open');\n    $self.next().toggleClass('collapse');\n    $self.find('i.fa').toggleClass('fa-caret-right fa-caret-down');\n  });\n\n  const $algorithms = $('<div class=\"algorithms collapse\">');\n  $('#list').append($category).append($algorithms);\n\n  each(categorySubList, (algorithm) => {\n    const $algorithm = getAlgorithmDOM(category, categorySubList, algorithm);\n    $algorithms.append($algorithm);\n  });\n};\n\nmodule.exports = () => {\n  each(app.getCategories(), addCategoryToDOM);\n};\n","'use strict';\n\nconst Server = require('../server');\n\nconst {\n  each\n} = $;\n\nconst addFileToDOM = (category, algorithm, file, explanation) => {\n  var $file = $('<button>')\n    .append(file)\n    .attr('data-file', file)\n    .click(function () {\n      Server.loadFile(category, algorithm, file, explanation);\n      $('.files_bar > .wrapper > button').removeClass('active');\n      $(this).addClass('active');\n    });\n  $('.files_bar > .wrapper').append($file);\n  return $file;\n};\n\nmodule.exports = (category, algorithm, files, requestedFile) => {\n  $('.files_bar > .wrapper').empty();\n\n  each(files, (file, explanation) => {\n    var $file = addFileToDOM(category, algorithm, file, explanation);\n    if (requestedFile && requestedFile == file) $file.click();\n  });\n\n  if (!requestedFile) $('.files_bar > .wrapper > button').first().click();\n  $('.files_bar > .wrapper').scroll();\n};","'use strict';\n\nconst showAlgorithm = require('./show_algorithm');\nconst addCategories = require('./add_categories');\nconst showDescription = require('./show_description');\nconst addFiles = require('./add_files');\nconst showFirstAlgorithm = require('./show_first_algorithm');\nconst showRequestedAlgorithm = require('./show_requested_algorithm');\nconst showWiki = require('./show_wiki');\n\nmodule.exports = {\n  showAlgorithm,\n  addCategories,\n  showDescription,\n  addFiles,\n  showFirstAlgorithm,\n  showRequestedAlgorithm,\n  showWiki\n};","'use strict';\n\nconst showLoadingSlider = () => {\n  $('#loading-slider').removeClass('loaded');\n};\n\nconst hideLoadingSlider = () => {\n  $('#loading-slider').addClass('loaded');\n};\n\nmodule.exports = {\n  showLoadingSlider,\n  hideLoadingSlider\n};\n","'use strict';\n\nconst create = () => {\n  const $container = $('<section class=\"module_wrapper\">');\n  $('.module_container').append($container);\n  return $container;\n};\n\nmodule.exports = {\n  create\n};\n","'use strict';\n\nconst setupDividers = require('./setup_dividers');\nconst setupDocument = require('./setup_document');\nconst setupFilesBar = require('./setup_files_bar');\nconst setupInterval = require('./setup_interval');\nconst setupModuleContainer = require('./setup_module_container');\nconst setupTabContainer = require('./setup_tab_container');\nconst setupSideMenu = require('./setup_side_menu');\nconst setupTopMenu = require('./setup_top_menu');\nconst setupWindow = require('./setup_window');\n\n/**\n * Initializes elements once the app loads in the DOM.\n */\nconst setup = () => {\n\n  $('.btn input').click((e) => {\n    e.stopPropagation();\n  });\n\n  // dividers\n  setupDividers();\n\n  // document\n  setupDocument();\n\n  // files bar\n  setupFilesBar();\n\n  // interval\n  setupInterval();\n\n  // module container\n  setupModuleContainer();\n\n  // tab container\n  setupTabContainer();\n\n  // side menu\n  setupSideMenu();\n\n  // top menu\n  setupTopMenu();\n\n  // window\n  setupWindow();\n\n};\n\nmodule.exports = {\n  setup\n};\n","'use strict';\n\nconst app = require('../../app');\n\nconst addDividerToDom = (divider) => {\n  const [vertical, $first, $second] = divider;\n  const $parent = $first.parent();\n  const thickness = 5;\n\n  const $divider = $('<div class=\"divider\">');\n\n  let dragging = false;\n  if (vertical) {\n    $divider.addClass('vertical');\n\n    let _left = -thickness / 2;\n    $divider.css({\n      top: 0,\n      bottom: 0,\n      left: _left,\n      width: thickness\n    });\n\n    let x;\n    $divider.mousedown(({\n      pageX\n    }) => {\n      x = pageX;\n      dragging = true;\n    });\n\n    $(document).mousemove(({\n      pageX\n    }) => {\n      if (dragging) {\n        const new_left = $second.position().left + pageX - x;\n        let percent = new_left / $parent.width() * 100;\n        percent = Math.min(90, Math.max(10, percent));\n        $first.css('right', (100 - percent) + '%');\n        $second.css('left', percent + '%');\n        x = pageX;\n        app.getTracerManager().resize();\n        $('.files_bar > .wrapper').scroll();\n      }\n    });\n\n    $(document).mouseup(function(e) {\n      dragging = false;\n    });\n\n  } else {\n\n    $divider.addClass('horizontal');\n    const _top = -thickness / 2;\n    $divider.css({\n      top: _top,\n      height: thickness,\n      left: 0,\n      right: 0\n    });\n\n    let y;\n    $divider.mousedown(function({\n      pageY\n    }) {\n      y = pageY;\n      dragging = true;\n    });\n\n    $(document).mousemove(function({\n      pageY\n    }) {\n      if (dragging) {\n        const new_top = $second.position().top + pageY - y;\n        let percent = new_top / $parent.height() * 100;\n        percent = Math.min(90, Math.max(10, percent));\n        $first.css('bottom', (100 - percent) + '%');\n        $second.css('top', percent + '%');\n        y = pageY;\n        app.getTracerManager().resize();\n      }\n    });\n\n    $(document).mouseup(function(e) {\n      dragging = false;\n    });\n  }\n\n  $second.append($divider);\n};\n\nmodule.exports = () => {\n  const dividers = [\n    ['v', $('.sidemenu'), $('.workspace')],\n    ['v', $('.viewer_container'), $('.editor_container')],\n    ['h', $('.data_container'), $('.code_container')]\n  ];\n  for (let i = 0; i < dividers.length; i++) {\n    addDividerToDom(dividers[i]);\n  }\n};","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = () => {\n  $(document).on('click', 'a', function (e) {\n    const href = $(this).attr('href');\n    if (/^(https?:\\/\\/).+/.test(href)) {\n      e.preventDefault();\n      if (!window.open(href, '_blank')) {\n        alert('Please allow popups for this site');\n      }\n    }\n  });\n\n  $(document).mouseup(function (e) {\n    app.getTracerManager().command('mouseup', e);\n  });\n};\n","'use strict';\n\nconst definitelyBigger = (x, y) => x > (y + 2);\n\nmodule.exports = () => {\n\n  $('.files_bar > .btn-left').click(() => {\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const scrollLeft = $wrapper.scrollLeft();\n\n    $($wrapper.children('button').get().reverse()).each(function() {\n      const left = $(this).position().left;\n      const right = left + $(this).outerWidth();\n      if (0 > left) {\n        $wrapper.scrollLeft(scrollLeft + right - clipWidth);\n        return false;\n      }\n    });\n  });\n\n  $('.files_bar > .btn-right').click(() => {\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const scrollLeft = $wrapper.scrollLeft();\n\n    $wrapper.children('button').each(function() {\n      const left = $(this).position().left;\n      const right = left + $(this).outerWidth();\n      if (clipWidth < right) {\n        $wrapper.scrollLeft(scrollLeft + left);\n        return false;\n      }\n    });\n  });\n\n  $('.files_bar > .wrapper').scroll(function() {\n\n    const $wrapper = $('.files_bar > .wrapper');\n    const clipWidth = $wrapper.width();\n    const $left = $wrapper.children('button:first-child');\n    const $right = $wrapper.children('button:last-child');\n    const left = $left.position().left;\n    const right = $right.position().left + $right.outerWidth();\n\n    if (definitelyBigger(0, left) && definitelyBigger(clipWidth, right)) {\n      const scrollLeft = $wrapper.scrollLeft();\n      $wrapper.scrollLeft(scrollLeft + clipWidth - right);\n      return;\n    }\n\n    const lefter = definitelyBigger(0, left);\n    const righter = definitelyBigger(right, clipWidth);\n    $wrapper.toggleClass('shadow-left', lefter);\n    $wrapper.toggleClass('shadow-right', righter);\n    $('.files_bar > .btn-left').attr('disabled', !lefter);\n    $('.files_bar > .btn-right').attr('disabled', !righter);\n  });\n}\n","'use strict';\n\nconst app = require('../../app');\nconst Toast = require('../toast');\n\nconst {\n  parseFloat\n} = Number;\n\nconst minInterval = 0.1;\nconst maxInterval = 10;\nconst startInterval = 0.5;\nconst stepInterval = 0.1;\n\nconst normalize = (sec) => {\n\n\n  let interval;\n  let message;\n  if (sec < minInterval) {\n    interval = minInterval;\n    message = `Interval of ${sec} seconds is too low. Setting to min allowed interval of ${minInterval} second(s).`;\n  } else if (sec > maxInterval) {\n    interval = maxInterval;\n    message = `Interval of ${sec} seconds is too high. Setting to max allowed interval of ${maxInterval} second(s).`;\n  } else {\n    interval = sec;\n    message = `Interval has been set to ${sec} second(s).`\n  }\n\n  return [interval, message];\n};\n\nmodule.exports = () => {\n\n  const $interval = $('#interval');\n  $interval.val(startInterval);\n  $interval.attr({\n    max: maxInterval,\n    min: minInterval,\n    step: stepInterval\n  });\n\n  $('#interval').on('change', function() {\n    const tracerManager = app.getTracerManager();\n    const [seconds, message] = normalize(parseFloat($(this).val()));\n\n    $(this).val(seconds);\n    tracerManager.interval = seconds * 1000;\n    Toast.showInfoToast(message);\n  });\n};\n","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = () => {\n\n  const $module_container = $('.module_container');\n\n  $module_container.on('mousedown', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousedown(e);\n  });\n\n  $module_container.on('mousemove', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousemove(e);\n  });\n\n  $module_container.on('DOMMouseScroll mousewheel', '.module_wrapper', function(e) {\n    app.getTracerManager().findOwner(this).mousewheel(e);\n  });\n}\n","'use strict';\n\nconst app = require('../../app');\nconst Server = require('../../server');\nconst showAlgorithm = require('../show_algorithm');\n\nlet sidemenu_percent;\n\nmodule.exports = () => {\n  $('#navigation').click(() => {\n    const $sidemenu = $('.sidemenu');\n    const $workspace = $('.workspace');\n\n    $sidemenu.toggleClass('active');\n    $('.nav-dropdown').toggleClass('fa-caret-down fa-caret-up');\n\n    if ($sidemenu.hasClass('active')) {\n      $sidemenu.css('right', (100 - sidemenu_percent) + '%');\n      $workspace.css('left', sidemenu_percent + '%');\n\n    } else {\n      sidemenu_percent = $workspace.position().left / $('body').width() * 100;\n      $sidemenu.css('right', 0);\n      $workspace.css('left', 0);\n    }\n\n    app.getTracerManager().resize();\n  });\n\n  $('#documentation').click(function () {\n    $('#btn_doc').click();\n  });\n\n  $('#powered-by').click(() => {\n    $('#powered-by-list button').toggleClass('collapse');\n  });\n\n  $('#scratch-paper').click(() => {\n    const category = 'scratch';\n    const algorithm = app.getLoadedScratch();\n    Server.loadAlgorithm(category, algorithm).then((data) => {\n      showAlgorithm(category, algorithm, data);\n    });\n  });\n};","'use strict';\n\nmodule.exports = () => {\n  $('.tab_bar > button').click(function () {\n    $('.tab_bar > button').removeClass('active');\n    $('.tab_container > .tab').removeClass('active');\n    $(this).addClass('active');\n    $($(this).attr('data-target')).addClass('active');\n  });\n};","'use strict';\n\nconst app = require('../../app');\nconst Server = require('../../server');\nconst Toast = require('../toast');\nconst TopMenu = require('../top_menu');\n\nmodule.exports = () => {\n\n  // shared\n  $('#shared').mouseup(function () {\n    $(this).select();\n  });\n\n  $('#btn_share').click(function () {\n\n    const $icon = $(this).find('.fa-share');\n    $icon.addClass('fa-spin fa-spin-faster');\n\n    Server.shareScratchPaper().then((url) => {\n      $icon.removeClass('fa-spin fa-spin-faster');\n      $('#shared').removeClass('collapse');\n      $('#shared').val(url);\n      Toast.showInfoToast('Shareable link is created.');\n    });\n  });\n\n  // control\n\n  const $btnRun = $('#btn_run');\n  const $btnTrace = $('#btn_trace');\n  const $btnPause = $('#btn_pause');\n  const $btnPrev = $('#btn_prev');\n  const $btnNext = $('#btn_next');\n\n  // initially, control buttons are disabled\n  TopMenu.disableFlowControl();\n\n  $btnRun.click(() => {\n    $btnTrace.click();\n    $btnPause.removeClass('active');\n    $btnRun.addClass('active');\n    TopMenu.enableFlowControl();\n    var err = app.getEditor().execute();\n    if (err) {\n      console.error(err);\n      Toast.showErrorToast(err);\n      TopMenu.resetTopMenuButtons();\n    }\n  });\n\n  $btnPause.click(() => {\n    $btnRun.toggleClass('active');\n    $btnPause.toggleClass('active');\n    if (app.getTracerManager().isPause()) {\n      app.getTracerManager().resumeStep();\n    } else {\n      app.getTracerManager().pauseStep();\n    }\n  });\n\n  $btnPrev.click(() => {\n    $btnRun.removeClass('active');\n    $btnPause.addClass('active');\n    app.getTracerManager().pauseStep();\n    app.getTracerManager().prevStep();\n  });\n\n  $btnNext.click(() => {\n    $btnRun.removeClass('active');\n    $btnPause.addClass('active');\n    app.getTracerManager().pauseStep();\n    app.getTracerManager().nextStep();\n  });\n\n};\n","'use strict';\n\nconst app = require('../../app');\n\nmodule.exports = function() {\n  $(window).resize(function() {\n    app.getTracerManager().resize();\n  });\n};\n","'use strict';\n\nconst app = require('../app');\n\nconst {\n  isScratchPaper\n} = require('../utils');\n\nconst showDescription = require('./show_description');\nconst addFiles = require('./add_files');\n\nmodule.exports = (category, algorithm, data, requestedFile) => {\n  let $menu;\n  let category_name;\n  let algorithm_name;\n\n  if (isScratchPaper(category)) {\n    $menu = $('#scratch-paper');\n    category_name = 'Scratch Paper';\n    algorithm_name = algorithm ? 'Shared' : 'Temporary';\n  } else {\n    $menu = $(`[data-category=\"${category}\"][data-algorithm=\"${algorithm}\"]`);\n    const categoryObj = app.getCategory(category);\n    category_name = categoryObj.name;\n    algorithm_name = categoryObj.list[algorithm];\n  }\n\n  $('.sidemenu button').removeClass('active');\n  $menu.addClass('active');\n\n  $('#category').html(category_name);\n  $('#algorithm').html(algorithm_name);\n  $('#tab_desc > .wrapper').empty();\n  $('.files_bar > .wrapper').empty();\n  $('#explanation').html('');\n\n  app.setLastFileUsed(null);\n  app.getEditor().clearContent();\n\n  const {\n    files\n  } = data;\n\n  delete data.files;\n\n  showDescription(data);\n  addFiles(category, algorithm, files, requestedFile);\n};","'use strict';\n\nconst {\n  isArray\n} = Array;\n\nconst {\n  each\n} = $;\n\nmodule.exports = (data) => {\n  const $container = $('#tab_desc > .wrapper');\n  $container.empty();\n\n  each(data, (key, value) => {\n\n    if (key) {\n      $container.append($('<h3>').html(key));\n    }\n\n    if (typeof value === 'string') {\n      $container.append($('<p>').html(value));\n\n    } else if (isArray(value)) {\n\n      const $ul = $('<ul class=\"applications\">');\n      $container.append($ul);\n\n      value.forEach((li) => {\n        $ul.append($('<li>').html(li));\n      });\n\n    } else if (typeof value === 'object') {\n\n      const $ul = $('<ul class=\"complexities\">');\n      $container.append($ul);\n\n      each(value, (prop) => {\n        const $wrapper = $('<div class=\"complexity\">');\n        const $type = $('<span class=\"complexity-type\">').html(`${prop}: `);\n        const $value = $('<span class=\"complexity-value\">').html(`${value[prop]}`);\n\n        $wrapper.append($type).append($value);\n\n        $ul.append($('<li>').append($wrapper));\n      });\n    }\n  });\n};\n","'use strict';\n\n// click the first algorithm in the first category\nmodule.exports = () => {\n  $('#list .category').first().click();\n  $('#list .category + .algorithms > .indent').first().click();\n};\n","'use strict';\n\nconst Server = require('../server');\nconst showAlgorithm = require('./show_algorithm');\n\nmodule.exports = (category, algorithm, file) => {\n  $(`.category[data-category=\"${category}\"]`).click();\n  Server.loadAlgorithm(category, algorithm).then((data) => {\n    showAlgorithm(category, algorithm, data, file);\n  });\n};\n","'use strict';\n\nconst app = require('../app');\nconst Server = require('../server');\nconst converter = new showdown.Converter({tables: true});\n\nmodule.exports = (wiki) => {\n  Server.loadWiki(wiki).then((data) => {\n    $('#tab_doc > .wrapper').html(converter.makeHtml(`#${wiki}\\n${data}`));\n    $('#tab_doc').scrollTop(0);\n    $('#tab_doc > .wrapper a').click(function (e) {\n      const href = $(this).attr('href');\n      if (app.hasWiki(href)) {\n        e.preventDefault();\n        module.exports(href);\n      }\n    });\n  });\n};","'use strict';\n\nconst showToast = (data, type) => {\n  const $toast = $(`<div class=\"toast ${type}\">`).append(data);\n\n  $('.toast_container').append($toast);\n  setTimeout(() => {\n    $toast.fadeOut(() => {\n      $toast.remove();\n    });\n  }, 3000);\n};\n\nconst showErrorToast = (err) => {\n  showToast(err, 'error');\n};\n\nconst showInfoToast = (err) => {\n  showToast(err, 'info');\n};\n\nmodule.exports = {\n  showErrorToast,\n  showInfoToast\n};","'use strict';\n\nconst app = require('../app');\n\nconst flowControlBtns = [ $('#btn_pause'), $('#btn_prev'), $('#btn_next') ];\nconst setFlowControlState = (isDisabled) => {\n  flowControlBtns.forEach($btn => $btn.attr('disabled', isDisabled));\n};\n\nconst enableFlowControl = () => {\n  setFlowControlState(false);\n};\n\nconst disableFlowControl = () => {\n  setFlowControlState(true);\n};\n\nconst resetTopMenuButtons = () => {\n  $('.top-menu-buttons button').removeClass('active');\n  disableFlowControl();\n  app.getEditor().unhighlightLine();\n};\n\nconst setInterval = (val) => {\n  $('#interval').val(interval);\n};\n\nconst activateBtnPause = () => {\n  $('#btn_pause').addClass('active');\n};\n\nconst deactivateBtnPause = () => {\n  $('#btn_pause').removeClass('active');\n};\n\nmodule.exports = {\n  enableFlowControl,\n  disableFlowControl,\n  resetTopMenuButtons,\n  setInterval,\n  activateBtnPause,\n  deactivateBtnPause\n};\n","'use strict';\n\nmodule.exports = function(id) {\n  const editor = ace.edit(id);\n\n  editor.setOptions({\n    enableBasicAutocompletion: true,\n    enableSnippets: true,\n    enableLiveAutocompletion: true\n  });\n\n  editor.setTheme('ace/theme/tomorrow_night_eighties');\n  editor.session.setMode('ace/mode/javascript');\n  editor.$blockScrolling = Infinity;\n\n  return editor;\n};","'use strict';\n\nconst execute = (tracerManager, code, dataLines) => {\n  // all modules available to eval are obtained from window\n  try {\n    tracerManager.deallocateAll();\n    const lines = code.split('\\n');\n    const newLines = [];\n    lines.forEach((line, i) => {\n      newLines.push(line.replace(/(.+\\. *_wait *)(\\( *\\))/g, `$1(${i - dataLines})`));\n    });\n    eval(newLines.join('\\n'));\n    tracerManager.visualize();\n  } catch (err) {\n    return err;\n  } finally {\n    tracerManager.removeUnallocated();\n  }\n};\n\nconst executeData = (tracerManager, algoData) => {\n  return execute(tracerManager, algoData);\n};\n\nconst executeDataAndCode = (tracerManager, algoData, algoCode) => {\n  const dataLines = algoData.split('\\n').length;\n  return execute(tracerManager, `${algoData}\\n${algoCode}`, dataLines);\n};\n\nmodule.exports = {\n  executeData,\n  executeDataAndCode\n};","'use strict';\n\nconst app = require('../app');\nconst createEditor = require('./create');\nconst Executor = require('./executor');\nconst TopMenu = require('../dom/top_menu');\n\nfunction Editor(tracerManager) {\n  if (!tracerManager) {\n    throw 'Cannot create Editor. Missing the tracerManager';\n  }\n\n  ace.require('ace/ext/language_tools');\n  const Range = ace.require(\"ace/range\").Range;\n\n  this.dataEditor = createEditor('data');\n  this.codeEditor = createEditor('code');\n\n  // Setting data\n\n  this.setData = (data) => {\n    this.dataEditor.setValue(data, -1);\n  };\n\n  this.setCode = (code) => {\n    this.codeEditor.setValue(code, -1);\n  };\n\n  this.setContent = (({\n    data,\n    code\n  }) => {\n    this.setData(data);\n    this.setCode(code);\n  });\n\n  // Clearing data\n\n  this.clearData = () => {\n    this.dataEditor.setValue('');\n  };\n\n  this.clearCode = () => {\n    this.codeEditor.setValue('');\n  };\n\n  this.clearContent = () => {\n    this.clearData();\n    this.clearCode();\n  };\n\n  this.execute = () => {\n    const data = this.dataEditor.getValue();\n    const code = this.codeEditor.getValue();\n    return Executor.executeDataAndCode(tracerManager, data, code);\n  };\n\n  this.highlightLine = (lineNumber) => {\n    const session = this.codeEditor.getSession();\n    if (this.marker) session.removeMarker(this.marker);\n    this.marker = session.addMarker(new Range(lineNumber, 0, lineNumber, Infinity), \"executing\", \"line\", true);\n  };\n\n  this.unhighlightLine = () => {\n    const session = this.codeEditor.getSession();\n    if (this.marker) session.removeMarker(this.marker);\n  };\n\n  // listeners\n\n  this.dataEditor.on('change', () => {\n    const data = this.dataEditor.getValue();\n    const lastFileUsed = app.getLastFileUsed();\n    if (lastFileUsed) {\n      app.updateCachedFile(lastFileUsed, {\n        data\n      });\n    }\n    Executor.executeData(tracerManager, data);\n    TopMenu.resetTopMenuButtons();\n  });\n\n  this.codeEditor.on('change', () => {\n    const code = this.codeEditor.getValue();\n    const lastFileUsed = app.getLastFileUsed();\n    if (lastFileUsed) {\n      app.updateCachedFile(lastFileUsed, {\n        code\n      });\n    }\n    tracerManager.reset();\n    TopMenu.resetTopMenuButtons();\n  });\n}\n\nmodule.exports = Editor;","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('./app');\nconst AppConstructor = require('./app/constructor');\nconst DOM = require('./dom');\nconst Server = require('./server');\n\nconst modules = require('./module');\n\nconst {\n  extend\n} = $;\n\n$.ajaxSetup({\n  cache: false,\n  dataType: 'text'\n});\n\nconst {\n  isScratchPaper\n} = require('./utils');\n\nconst {\n  getHashValue,\n  getParameterByName,\n  getPath\n} = require('./server/helpers');\n\n// set global promise error handler\nRSVP.on('error', function (reason) {\n  console.assert(false, reason);\n});\n\n$(() => {\n\n  // initialize the application and attach in to the instance module\n  const appConstructor = new AppConstructor();\n  extend(true, app, appConstructor);\n\n  // load modules to the global scope so they can be evaled\n  extend(true, window, modules);\n\n  Server.loadCategories().then((data) => {\n    app.setCategories(data);\n    DOM.addCategories();\n\n    // determine if the app is loading a pre-existing scratch-pad\n    // or the home page\n    const {\n      category,\n      algorithm,\n      file\n    } = getPath();\n    if (isScratchPaper(category)) {\n      if (algorithm) {\n        Server.loadScratchPaper(algorithm).then(({category, algorithm, data}) => {\n          DOM.showAlgorithm(category, algorithm, data);\n        });\n      } else {\n        Server.loadAlgorithm(category).then((data) => {\n          DOM.showAlgorithm(category, null, data);\n        });\n      }\n    } else if (category && algorithm) {\n      DOM.showRequestedAlgorithm(category, algorithm, file);\n    } else {\n      DOM.showFirstAlgorithm();\n    }\n  });\n\n  Server.loadWikiList().then((data) => {\n    app.setWikiList(data.wikis);\n\n    DOM.showWiki('Tracer');\n  });\n\n  var v1LoadedScratch = getHashValue('scratch-paper');\n  var v2LoadedScratch = getParameterByName('scratch-paper');\n  var vLoadedScratch = v1LoadedScratch || v2LoadedScratch;\n  if (vLoadedScratch) {\n    window.location.href = window.location.protocol + '//' + window.location.host + window.location.pathname + '#path=scratch/' + vLoadedScratch;\n  }\n\n});","'use strict';\n\nconst Array2D = require('./array2d');\n\nconst random = (N, min, max) => {\n  return Array2D.random(1, N, min, max)[0];\n};\n\nconst randomSorted = (N, min, max)=> {\n  return Array2D.randomSorted(1, N, min, max)[0];\n};\n\nmodule.exports = {\n  random,\n  randomSorted\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, M, min, max) => {\n  if (!N) N = 10;\n  if (!M) M = 10;\n  if (min === undefined) min = 1;\n  if (max === undefined) max = 9;\n  var D = [];\n  for (var i = 0; i < N; i++) {\n    D.push([]);\n    for (var j = 0; j < M; j++) {\n      D[i].push(Integer.random(min, max));\n    }\n  }\n  return D;\n};\n\nconst randomSorted = (N, M, min, max) => {\n  return random(N, M, min, max).map(function (arr) {\n    return arr.sort(function (a, b) {\n      return a - b;\n    });\n  });\n};\n\nmodule.exports = {\n  random,\n  randomSorted\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, min, max) => {\n  if (!N) N = 7;\n  if (!min) min = 1;\n  if (!max) max = 10;\n  var C = new Array(N);\n  for (var i = 0; i < N; i++) C[i] = new Array(2);\n  for (var i = 0; i < N; i++)\n    for (var j = 0; j < C[i].length; j++)\n      C[i][j] = Integer.random(min, max);\n  return C;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst random = (N, ratio) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) {\n    G[i] = new Array(N);\n    for (var j = 0; j < N; j++) {\n      if (i != j) {\n        G[i][j] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\nconst Array1D = require('./array1d');\nconst Array2D = require('./array2d');\nconst CoordinateSystem = require('./coordinate_system');\nconst DirectedGraph = require('./directed_graph');\nconst UndirectedGraph = require('./undirected_graph');\nconst WeightedDirectedGraph = require('./weighted_directed_graph');\nconst WeightedUndirectedGraph = require('./weighted_undirected_graph');\n\nmodule.exports = {\n  Integer,\n  Array1D,\n  Array2D,\n  CoordinateSystem,\n  DirectedGraph,\n  UndirectedGraph,\n  WeightedDirectedGraph,\n  WeightedUndirectedGraph\n};","'use strict';\n\nconst random = (min, max) => {\n  return (Math.random() * (max - min + 1) | 0) + min;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst random = (N, ratio) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) G[i] = new Array(N);\n  for (var i = 0; i < N; i++) {\n    for (var j = 0; j < N; j++) {\n      if (i > j) {\n        G[i][j] = G[j][i] = (Math.random() * (1 / ratio) | 0) == 0 ? 1 : 0;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, ratio, min, max) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  if (!min) min = 1;\n  if (!max) max = 5;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) {\n    G[i] = new Array(N);\n    for (var j = 0; j < N; j++) {\n      if (i != j && (Math.random() * (1 / ratio) | 0) == 0) {\n        G[i][j] = Integer.random(min, max);\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nconst Integer = require('./integer');\n\nconst random = (N, ratio, min, max) => {\n  if (!N) N = 5;\n  if (!ratio) ratio = .3;\n  if (!min) min = 1;\n  if (!max) max = 5;\n  var G = new Array(N);\n  for (var i = 0; i < N; i++) G[i] = new Array(N);\n  for (var i = 0; i < N; i++) {\n    for (var j = 0; j < N; j++) {\n      if (i > j && (Math.random() * (1 / ratio) | 0) == 0) {\n        G[i][j] = G[j][i] = Integer.random(min, max);\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};\n","'use strict';\n\nvar tracers = require('./tracer');\nvar datas = require('./data');\n\nconst {\n  extend\n} = $;\n\nmodule.exports = extend(true, {}, tracers, datas);","'use strict';\n\nconst Array2DTracer = require('./array2d');\n\nclass Array1DTracer extends Array2DTracer {\n  static getClassName() {\n    return 'Array1DTracer';\n  }\n\n  constructor(name) {\n    super(name);\n  }\n\n  _notify(idx, v) {\n    super._notify(0, idx, v);\n    return this;\n  }\n\n  _denotify(idx) {\n    super._denotify(0, idx);\n    return this;\n  }\n\n  _select(s, e) {\n    if (e === undefined) {\n      super._select(0, s);\n    } else {\n      super._selectRow(0, s, e);\n    }\n    return this;\n  }\n\n  _deselect(s, e) {\n    if (e === undefined) {\n      super._deselect(0, s);\n    } else {\n      super._deselectRow(0, s, e);\n    }\n    return this;\n  }\n\n  processStep(step, options) {\n    super.processStep(step, options);\n    if (this.chartTracer) {\n      const newStep = $.extend(true, {}, step);\n      newStep.capsule = this.chartTracer.capsule;\n      newStep.s = newStep.sy;\n      newStep.e = newStep.ey;\n      if (newStep.s === undefined) newStep.s = newStep.y;\n      delete newStep.x;\n      delete newStep.y;\n      delete newStep.sx;\n      delete newStep.sy;\n      delete newStep.ex;\n      delete newStep.ey;\n      this.chartTracer.processStep(newStep, options);\n    }\n  }\n\n  setData(D) {\n    return super.setData([D]);\n  }\n}\n\nmodule.exports = Array1DTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass Array2DTracer extends Tracer {\n  static getClassName() {\n    return 'Array2DTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.colorClass = {\n      selected: 'selected',\n      notified: 'notified'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  _notify(x, y, v) {\n    this.manager.pushStep(this.capsule, {\n      type: 'notify',\n      x: x,\n      y: y,\n      v: v\n    });\n    return this;\n  }\n\n  _denotify(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'denotify',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _select(sx, sy, ex, ey) {\n    this.pushSelectingStep('select', null, arguments);\n    return this;\n  }\n\n  _selectRow(x, sy, ey) {\n    this.pushSelectingStep('select', 'row', arguments);\n    return this;\n  }\n\n  _selectCol(y, sx, ex) {\n    this.pushSelectingStep('select', 'col', arguments);\n    return this;\n  }\n\n  _deselect(sx, sy, ex, ey) {\n    this.pushSelectingStep('deselect', null, arguments);\n    return this;\n  }\n\n  _deselectRow(x, sy, ey) {\n    this.pushSelectingStep('deselect', 'row', arguments);\n    return this;\n  }\n\n  _deselectCol(y, sx, ex) {\n    this.pushSelectingStep('deselect', 'col', arguments);\n    return this;\n  }\n\n  _separate(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'separate',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _separateRow(x) {\n    this._separate(x, -1);\n    return this;\n  }\n\n  _separateCol(y) {\n    this._separate(-1, y);\n    return this;\n  }\n\n  _deseparate(x, y) {\n    this.manager.pushStep(this.capsule, {\n      type: 'deseparate',\n      x: x,\n      y: y\n    });\n    return this;\n  }\n\n  _deseparateRow(x) {\n    this._deseparate(x, -1);\n    return this;\n  }\n\n  _deseparateCol(y) {\n    this._deseparate(-1, y);\n    return this;\n  }\n\n  pushSelectingStep() {\n    var args = Array.prototype.slice.call(arguments);\n    var type = args.shift();\n    var mode = args.shift();\n    args = Array.prototype.slice.call(args.shift());\n    var coord;\n    switch (mode) {\n      case 'row':\n        coord = {\n          x: args[0],\n          sy: args[1],\n          ey: args[2]\n        };\n        break;\n      case 'col':\n        coord = {\n          y: args[0],\n          sx: args[1],\n          ex: args[2]\n        };\n        break;\n      default:\n        if (args[2] === undefined && args[3] === undefined) {\n          coord = {\n            x: args[0],\n            y: args[1]\n          };\n        } else {\n          coord = {\n            sx: args[0],\n            sy: args[1],\n            ex: args[2],\n            ey: args[3]\n          };\n        }\n    }\n    var step = {\n      type: type\n    };\n    $.extend(step, coord);\n    this.manager.pushStep(this.capsule, step);\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'notify':\n        if (step.v !== undefined) {\n          var $row = this.$table.find('.mtbl-row').eq(step.x);\n          var $col = $row.find('.mtbl-col').eq(step.y);\n          $col.text(refineByType(step.v));\n        }\n      case 'denotify':\n      case 'select':\n      case 'deselect':\n        var colorClass = step.type == 'select' || step.type == 'deselect' ? this.colorClass.selected : this.colorClass.notified;\n        var addClass = step.type == 'select' || step.type == 'notify';\n        var sx = step.sx;\n        var sy = step.sy;\n        var ex = step.ex;\n        var ey = step.ey;\n        if (sx === undefined) sx = step.x;\n        if (sy === undefined) sy = step.y;\n        if (ex === undefined) ex = step.x;\n        if (ey === undefined) ey = step.y;\n        this.paintColor(sx, sy, ex, ey, colorClass, addClass);\n        break;\n      case 'separate':\n        this.deseparate(step.x, step.y);\n        this.separate(step.x, step.y);\n        break;\n      case 'deseparate':\n        this.deseparate(step.x, step.y);\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  setData(D) {\n    this.viewX = this.viewY = 0;\n    this.paddingH = 6;\n    this.paddingV = 3;\n    this.fontSize = 16;\n\n    if (super.setData.apply(this, arguments)) {\n      this.$table.find('.mtbl-row').each(function (i) {\n        $(this).find('.mtbl-col').each(function (j) {\n          $(this).text(refineByType(D[i][j]));\n        });\n      });\n      return true;\n    }\n\n    this.$table.empty();\n    for (var i = 0; i < D.length; i++) {\n      var $row = $('<div class=\"mtbl-row\">');\n      this.$table.append($row);\n      for (var j = 0; j < D[i].length; j++) {\n        var $col = $('<div class=\"mtbl-col\">')\n          .css(this.getCellCss())\n          .text(refineByType(D[i][j]));\n        $row.append($col);\n      }\n    }\n    this.resize();\n\n    return false;\n  }\n\n  resize() {\n    super.resize();\n\n    this.refresh();\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearColor();\n    this.deseparateAll();\n  }\n\n  getCellCss() {\n    return {\n      padding: this.paddingV.toFixed(1) + 'px ' + this.paddingH.toFixed(1) + 'px',\n      'font-size': this.fontSize.toFixed(1) + 'px'\n    };\n  }\n\n  refresh() {\n    super.refresh();\n\n    var $parent = this.$table.parent();\n    var top = $parent.height() / 2 - this.$table.height() / 2 + this.viewY;\n    var left = $parent.width() / 2 - this.$table.width() / 2 + this.viewX;\n    this.$table.css('margin-top', top);\n    this.$table.css('margin-left', left);\n  }\n\n  mousedown(e) {\n    super.mousedown(e);\n\n    this.dragX = e.pageX;\n    this.dragY = e.pageY;\n    this.dragging = true;\n  }\n\n  mousemove(e) {\n    super.mousemove(e);\n\n    if (this.dragging) {\n      this.viewX += e.pageX - this.dragX;\n      this.viewY += e.pageY - this.dragY;\n      this.dragX = e.pageX;\n      this.dragY = e.pageY;\n      this.refresh();\n    }\n  }\n\n  mouseup(e) {\n    super.mouseup(e);\n\n    this.dragging = false;\n  }\n\n  mousewheel(e) {\n    super.mousewheel(e);\n\n    e.preventDefault();\n    e = e.originalEvent;\n    var delta = (e.wheelDelta !== undefined && e.wheelDelta) ||\n      (e.detail !== undefined && -e.detail);\n    var weight = 1.01;\n    var ratio = delta > 0 ? 1 / weight : weight;\n    if (this.fontSize < 4 && ratio < 1) return;\n    if (this.fontSize > 40 && ratio > 1) return;\n    this.paddingV *= ratio;\n    this.paddingH *= ratio;\n    this.fontSize *= ratio;\n    this.$table.find('.mtbl-col').css(this.getCellCss());\n    this.refresh();\n  }\n\n  paintColor(sx, sy, ex, ey, colorClass, addClass) {\n    for (var i = sx; i <= ex; i++) {\n      var $row = this.$table.find('.mtbl-row').eq(i);\n      for (var j = sy; j <= ey; j++) {\n        var $col = $row.find('.mtbl-col').eq(j);\n        if (addClass) $col.addClass(colorClass);\n        else $col.removeClass(colorClass);\n      }\n    }\n  }\n\n  clearColor() {\n    this.$table.find('.mtbl-col').removeClass(Object.keys(this.colorClass).join(' '));\n  }\n\n  separate(x, y) {\n    this.$table.find('.mtbl-row').each(function (i) {\n      var $row = $(this);\n      if (i == x) {\n        $row.after($('<div class=\"mtbl-empty-row\">').attr('data-row', i))\n      }\n      $row.find('.mtbl-col').each(function (j) {\n        var $col = $(this);\n        if (j == y) {\n          $col.after($('<div class=\"mtbl-empty-col\">').attr('data-col', j));\n        }\n      });\n    });\n  }\n\n  deseparate(x, y) {\n    this.$table.find('[data-row=' + x + ']').remove();\n    this.$table.find('[data-col=' + y + ']').remove();\n  }\n\n  deseparateAll() {\n    this.$table.find('.mtbl-empty-row, .mtbl-empty-col').remove();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$table = tracer.capsule.$table = $('<div class=\"mtbl-table\">');\n  tracer.$container.append(tracer.$table);\n};\n\nmodule.exports = Array2DTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nclass ChartTracer extends Tracer {\n  static getClassName() {\n    return 'ChartTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.color = {\n      selected: 'rgb(0, 0, 255)',\n      notified: 'rgb(255, 0, 0)',\n      default: 'rgb(136, 136, 136)'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (super.setData.apply(this, arguments)) {\n      this.chart.config.data.datasets[0].data = C;\n      this.chart.update();\n      return true;\n    }\n\n    var color = [];\n    for (var i = 0; i < C.length; i++) color.push(this.color.default);\n    this.chart.config.data = {\n      labels: C.map(String),\n      datasets: [{\n        backgroundColor: color,\n        data: C\n      }]\n    };\n    this.chart.update();\n  }\n\n  _notify(s, v) {\n    this.manager.pushStep(this.capsule, {\n      type: 'notify',\n      s: s,\n      v: v\n    });\n    return this;\n  }\n\n  _denotify(s) {\n    this.manager.pushStep(this.capsule, {\n      type: 'denotify',\n      s: s\n    });\n    return this;\n  }\n\n  _select(s, e) {\n    this.manager.pushStep(this.capsule, {\n      type: 'select',\n      s: s,\n      e: e\n    });\n    return this;\n  }\n\n  _deselect(s, e) {\n    this.manager.pushStep(this.capsule, {\n      type: 'deselect',\n      s: s,\n      e: e\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'notify':\n        if (step.v !== undefined) {\n          this.chart.config.data.datasets[0].data[step.s] = step.v;\n          this.chart.config.data.labels[step.s] = step.v.toString();\n        }\n      case 'denotify':\n      case 'select':\n      case 'deselect':\n        let color = step.type == 'notify' ? this.color.notified : step.type == 'select' ? this.color.selected : this.color.default;\n        if (step.e !== undefined)\n          for (var i = step.s; i <= step.e; i++)\n            this.chart.config.data.datasets[0].backgroundColor[i] = color;\n        else\n          this.chart.config.data.datasets[0].backgroundColor[step.s] = color;\n        this.chart.update();\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  resize() {\n    super.resize();\n\n    this.chart.resize();\n  }\n\n  clear() {\n    super.clear();\n\n    const data = this.chart.config.data;\n    if (data.datasets.length) {\n      const backgroundColor = data.datasets[0].backgroundColor;\n      for (let i = 0; i < backgroundColor.length; i++) {\n        backgroundColor[i] = this.color.default;\n      }\n      this.chart.update();\n    }\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$wrapper = tracer.capsule.$wrapper = $('<canvas class=\"mchrt-chart\">');\n  tracer.$container.append(tracer.$wrapper);\n  tracer.chart = tracer.capsule.chart = new Chart(tracer.$wrapper, {\n    type: 'bar',\n    data: {\n      labels: [],\n      datasets: []\n    },\n    options: {\n      scales: {\n        yAxes: [{\n          ticks: {\n            beginAtZero: true\n          }\n        }]\n      },\n      animation: false,\n      legend: false,\n      responsive: true,\n      maintainAspectRatio: false\n    }\n  });\n};\n\nmodule.exports = ChartTracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nclass CoordinateSystemTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'CoordinateSystemTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (Tracer.prototype.setData.apply(this, arguments)) return true;\n\n    this.graph.clear();\n    var nodes = [];\n    var edges = [];\n    for (var i = 0; i < C.length; i++)\n      nodes.push({\n        id: this.n(i),\n        x: C[i][0],\n        y: C[i][1],\n        label: '' + i,\n        size: 1,\n        color: this.color.default\n      });\n    this.graph.read({\n      nodes: nodes,\n      edges: edges\n    });\n    this.s.camera.goTo({\n      x: 0,\n      y: 0,\n      angle: 0,\n      ratio: 1\n    });\n    this.refresh();\n\n    return false;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          if (this.graph.edges(edgeId)) {\n            var edge = this.graph.edges(edgeId);\n            edge.color = color;\n            this.graph.dropEdge(edgeId).addEdge(edge);\n          } else {\n            this.graph.addEdge({\n              id: this.e(step.target, step.source),\n              source: this.n(step.source),\n              target: this.n(step.target),\n              color: color,\n              size: 1\n            });\n          }\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  e(v1, v2) {\n    if (v1 > v2) {\n      var temp = v1;\n      v1 = v2;\n      v2 = temp;\n    }\n    return 'e' + v1 + '_' + v2;\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#0ff';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n\n  drawEdge(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(\n      source[prefix + 'x'],\n      source[prefix + 'y']\n    );\n    context.lineTo(\n      target[prefix + 'x'],\n      target[prefix + 'y']\n    );\n    context.stroke();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = CoordinateSystemTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass DirectedGraphTracer extends Tracer {\n  static getClassName() {\n    return 'DirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.color = {\n      selected: '#0f0',\n      visited: '#f00',\n      left: '#000',\n      default: '#888'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  _setTreeData(G, root) {\n    this.manager.pushStep(this.capsule, {\n      type: 'setTreeData',\n      arguments: arguments\n    });\n    return this;\n  }\n\n  _visit(target, source) {\n    this.manager.pushStep(this.capsule, {\n      type: 'visit',\n      target: target,\n      source: source\n    });\n    return this;\n  }\n\n  _leave(target, source) {\n    this.manager.pushStep(this.capsule, {\n      type: 'leave',\n      target: target,\n      source: source\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'setTreeData':\n        this.setTreeData.apply(this, step.arguments);\n        break;\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          var edge = this.graph.edges(edgeId);\n          edge.color = color;\n          this.graph.dropEdge(edgeId).addEdge(edge);\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  setTreeData(G, root, undirected) {\n    var tracer = this;\n\n    root = root || 0;\n    var maxDepth = -1;\n\n    var chk = new Array(G.length);\n    var getDepth = function (node, depth) {\n      if (chk[node]) throw \"the given graph is not a tree because it forms a circuit\";\n      chk[node] = true;\n      if (maxDepth < depth) maxDepth = depth;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) getDepth(i, depth + 1);\n      }\n    };\n    getDepth(root, 1);\n\n    if (this.setData(G, undirected)) return true;\n\n    var place = function (node, x, y) {\n      var temp = tracer.graph.nodes(tracer.n(node));\n      temp.x = x;\n      temp.y = y;\n    };\n\n    var wgap = 1 / (maxDepth - 1);\n    var dfs = function (node, depth, top, bottom) {\n      place(node, top + bottom, depth * wgap);\n      var children = 0;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) children++;\n      }\n      var vgap = (bottom - top) / children;\n      var cnt = 0;\n      for (var i = 0; i < G[node].length; i++) {\n        if (G[node][i]) dfs(i, depth + 1, top + vgap * cnt, top + vgap * ++cnt);\n      }\n    };\n    dfs(root, 0, 0, 1);\n\n    this.refresh();\n  }\n\n  setData(G, undirected) {\n    if (super.setData.apply(this, arguments)) return true;\n\n    this.graph.clear();\n    const nodes = [];\n    const edges = [];\n    const unitAngle = 2 * Math.PI / G.length;\n    let currentAngle = 0;\n    for (let i = 0; i < G.length; i++) {\n      currentAngle += unitAngle;\n      nodes.push({\n        id: this.n(i),\n        label: '' + i,\n        x: .5 + Math.sin(currentAngle) / 2,\n        y: .5 + Math.cos(currentAngle) / 2,\n        size: 1,\n        color: this.color.default,\n        weight: 0\n      });\n\n      if (undirected) {\n        for (let j = 0; j <= i; j++) {\n          const value = G[i][j] || G[j][i];\n          if (value) {\n            edges.push({\n              id: this.e(i, j),\n              source: this.n(i),\n              target: this.n(j),\n              color: this.color.default,\n              size: 1,\n              weight: refineByType(value)\n            });\n          }\n        }\n      } else {\n        for (let j = 0; j < G[i].length; j++) {\n          if (G[i][j]) {\n            edges.push({\n              id: this.e(i, j),\n              source: this.n(i),\n              target: this.n(j),\n              color: this.color.default,\n              size: 1,\n              weight: refineByType(G[i][j])\n            });\n          }\n        }\n      }\n    }\n\n    this.graph.read({\n      nodes: nodes,\n      edges: edges\n    });\n    this.s.camera.goTo({\n      x: 0,\n      y: 0,\n      angle: 0,\n      ratio: 1\n    });\n    this.refresh();\n\n    return false;\n  }\n\n  resize() {\n    super.resize();\n\n    this.s.renderers[0].resize();\n    this.refresh();\n  }\n\n  refresh() {\n    super.refresh();\n\n    this.s.refresh();\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearGraphColor();\n    this.refresh();\n  }\n\n  clearGraphColor() {\n    var tracer = this;\n\n    this.graph.nodes().forEach(function (node) {\n      node.color = tracer.color.default;\n    });\n    this.graph.edges().forEach(function (edge) {\n      edge.color = tracer.color.default;\n    });\n  }\n\n  n(v) {\n    return 'n' + v;\n  }\n\n  e(v1, v2) {\n    return 'e' + v1 + '_' + v2;\n  }\n\n  getColor(edge, source, target, settings) {\n    var color = edge.color,\n      edgeColor = settings('edgeColor'),\n      defaultNodeColor = settings('defaultNodeColor'),\n      defaultEdgeColor = settings('defaultEdgeColor');\n    if (!color)\n      switch (edgeColor) {\n        case 'source':\n          color = source.color || defaultNodeColor;\n          break;\n        case 'target':\n          color = target.color || defaultNodeColor;\n          break;\n        default:\n          color = defaultEdgeColor;\n          break;\n      }\n\n    return color;\n  }\n\n  drawLabel(node, context, settings) {\n    var fontSize,\n      prefix = settings('prefix') || '',\n      size = node[prefix + 'size'];\n\n    if (size < settings('labelThreshold'))\n      return;\n\n    if (!node.label || typeof node.label !== 'string')\n      return;\n\n    fontSize = (settings('labelSize') === 'fixed') ?\n      settings('defaultLabelSize') :\n    settings('labelSizeRatio') * size;\n\n    context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') +\n      fontSize + 'px ' + settings('font');\n    context.fillStyle = (settings('labelColor') === 'node') ?\n      (node.color || settings('defaultNodeColor')) :\n      settings('defaultLabelColor');\n\n    context.textAlign = 'center';\n    context.fillText(\n      node.label,\n      Math.round(node[prefix + 'x']),\n      Math.round(node[prefix + 'y'] + fontSize / 3)\n    );\n  }\n\n  drawArrow(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1,\n      tSize = target[prefix + 'size'],\n      sX = source[prefix + 'x'],\n      sY = source[prefix + 'y'],\n      tX = target[prefix + 'x'],\n      tY = target[prefix + 'y'],\n      angle = Math.atan2(tY - sY, tX - sX),\n      dist = 3;\n    sX += Math.sin(angle) * dist;\n    tX += Math.sin(angle) * dist;\n    sY += -Math.cos(angle) * dist;\n    tY += -Math.cos(angle) * dist;\n    var aSize = Math.max(size * 2.5, settings('minArrowSize')),\n      d = Math.sqrt(Math.pow(tX - sX, 2) + Math.pow(tY - sY, 2)),\n      aX = sX + (tX - sX) * (d - aSize - tSize) / d,\n      aY = sY + (tY - sY) * (d - aSize - tSize) / d,\n      vX = (tX - sX) * aSize / d,\n      vY = (tY - sY) * aSize / d;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(sX, sY);\n    context.lineTo(\n      aX,\n      aY\n    );\n    context.stroke();\n\n    context.fillStyle = color;\n    context.beginPath();\n    context.moveTo(aX + vX, aY + vY);\n    context.lineTo(aX + vY * 0.6, aY - vX * 0.6);\n    context.lineTo(aX - vY * 0.6, aY + vX * 0.6);\n    context.lineTo(aX + vX, aY + vY);\n    context.closePath();\n    context.fill();\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawArrow(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#ff0';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawArrow(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s = tracer.capsule.s = new sigma({\n    renderer: {\n      container: tracer.$container[0],\n      type: 'canvas'\n    },\n    settings: {\n      minArrowSize: 8,\n      defaultEdgeType: 'arrow',\n      maxEdgeSize: 2.5,\n      labelThreshold: 4,\n      font: 'Roboto',\n      defaultLabelColor: '#fff',\n      zoomMin: 0.6,\n      zoomMax: 1.2,\n      skipErrors: true,\n      minNodeSize: .5,\n      maxNodeSize: 12,\n      labelSize: 'proportional',\n      labelSizeRatio: 1.3,\n      funcLabelsDef(node, context, settings) {\n        tracer.drawLabel(node, context, settings);\n      },\n      funcHoversDef(node, context, settings, next) {\n        tracer.drawOnHover(node, context, settings, next);\n      },\n      funcEdgesArrow(edge, source, target, context, settings) {\n        var color = tracer.getColor(edge, source, target, settings);\n        tracer.drawArrow(edge, source, target, color, context, settings);\n      }\n    }\n  });\n  sigma.plugins.dragNodes(tracer.s, tracer.s.renderers[0]);\n  tracer.graph = tracer.capsule.graph = tracer.s.graph;\n};\n\nsigma.canvas.labels.def = function (node, context, settings) {\n  var func = settings('funcLabelsDef');\n  if (func) {\n    func(node, context, settings);\n  }\n};\nsigma.canvas.hovers.def = function (node, context, settings) {\n  var func = settings('funcHoversDef');\n  if (func) {\n    func(node, context, settings);\n  }\n};\nsigma.canvas.edges.def = function (edge, source, target, context, settings) {\n  var func = settings('funcEdgesDef');\n  if (func) {\n    func(edge, source, target, context, settings);\n  }\n};\nsigma.canvas.edges.arrow = function (edge, source, target, context, settings) {\n  var func = settings('funcEdgesArrow');\n  if (func) {\n    func(edge, source, target, context, settings);\n  }\n};\n\nmodule.exports = DirectedGraphTracer;\n","'use strict';\n\nconst Tracer = require('./tracer');\nconst LogTracer = require('./log');\nconst Array1DTracer = require('./array1d');\nconst Array2DTracer = require('./array2d');\nconst ChartTracer = require('./chart');\nconst CoordinateSystemTracer = require('./coordinate_system');\nconst DirectedGraphTracer = require('./directed_graph');\nconst UndirectedGraphTracer = require('./undirected_graph');\nconst WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nconst WeightedUndirectedGraphTracer = require('./weighted_undirected_graph');\n\nmodule.exports = {\n  Tracer,\n  LogTracer,\n  Array1DTracer,\n  Array2DTracer,\n  ChartTracer,\n  CoordinateSystemTracer,\n  DirectedGraphTracer,\n  UndirectedGraphTracer,\n  WeightedDirectedGraphTracer,\n  WeightedUndirectedGraphTracer\n};","'use strict';\n\nconst Tracer = require('./tracer');\n\nclass LogTracer extends Tracer {\n  static getClassName() {\n    return 'LogTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  _print(msg) {\n    this.manager.pushStep(this.capsule, {\n      type: 'print',\n      msg: msg\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'print':\n        this.print(step.msg);\n        break;\n    }\n  }\n\n  refresh() {\n    this.scrollToEnd(Math.min(50, this.interval));\n  }\n\n  clear() {\n    super.clear();\n\n    this.$wrapper.empty();\n  }\n\n  print(message) {\n    this.$wrapper.append($('<span>').append(message + '<br/>'));\n  }\n\n  scrollToEnd(duration) {\n    this.$container.animate({\n      scrollTop: this.$container[0].scrollHeight\n    }, duration);\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.$wrapper = tracer.capsule.$wrapper = $('<div class=\"wrapper\">');\n  tracer.$container.append(tracer.$wrapper);\n};\n\nmodule.exports = LogTracer;\n","'use strict';\n\nconst app = require('../../app');\n\nconst {\n  toJSON,\n  fromJSON\n} = require('../../tracer_manager/util/index');\n\nclass Tracer {\n  static getClassName() {\n    return 'Tracer';\n  }\n\n  constructor(name) {\n    this.module = this.constructor;\n\n    this.manager = app.getTracerManager();\n    this.capsule = this.manager.allocate(this);\n    $.extend(this, this.capsule);\n\n    this.setName(name);\n  }\n\n  _setData(...args) {\n    this.manager.pushStep(this.capsule, {\n      type: 'setData',\n      args: toJSON(args)\n    });\n    return this;\n  }\n\n  _clear() {\n    this.manager.pushStep(this.capsule, {\n      type: 'clear'\n    });\n    return this;\n  }\n\n  _wait(line) {\n    this.manager.newStep(line);\n    return this;\n  }\n\n  processStep(step, options) {\n    const {\n      type,\n      args\n    } = step;\n\n    switch (type) {\n      case 'setData':\n        this.setData(...fromJSON(args));\n        break;\n      case 'clear':\n        this.clear();\n        break;\n    }\n  }\n\n  setName(name) {\n    let $name;\n    if (this.isNew) {\n      $name = $('<span class=\"name\">');\n      this.$container.append($name);\n    } else {\n      $name = this.$container.find('span.name');\n    }\n    $name.text(name || this.defaultName);\n  }\n\n  setData() {\n    const data = toJSON(arguments);\n    if (!this.isNew && this.lastData === data) {\n      return true;\n    }\n    this.lastData = this.capsule.lastData = data;\n    return false;\n  }\n\n  resize() {\n  }\n\n  refresh() {\n  }\n\n  clear() {\n  }\n\n  attach(tracer) {\n    switch (tracer.module) {\n      case LogTracer:\n        this.logTracer = tracer;\n        break;\n      case ChartTracer:\n        this.chartTracer = tracer;\n        break;\n    }\n    return this;\n  }\n\n  mousedown(e) {\n  }\n\n  mousemove(e) {\n  }\n\n  mouseup(e) {\n  }\n\n  mousewheel(e) {\n  }\n}\n\nmodule.exports = Tracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nclass UndirectedGraphTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'UndirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  setTreeData(G, root) {\n    return super.setTreeData(G, root, true);\n  }\n\n  setData(G) {\n    return super.setData(G, true);\n  }\n\n  e(v1, v2) {\n    if (v1 > v2) {\n      var temp = v1;\n      v1 = v2;\n      v2 = temp;\n    }\n    return 'e' + v1 + '_' + v2;\n  }\n\n  drawOnHover(node, context, settings, next) {\n    var tracer = this;\n\n    context.setLineDash([5, 5]);\n    var nodeIdx = node.id.substring(1);\n    this.graph.edges().forEach(function (edge) {\n      var ends = edge.id.substring(1).split(\"_\");\n      if (ends[0] == nodeIdx) {\n        var color = '#0ff';\n        var source = node;\n        var target = tracer.graph.nodes('n' + ends[1]);\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      } else if (ends[1] == nodeIdx) {\n        var color = '#0ff';\n        var source = tracer.graph.nodes('n' + ends[0]);\n        var target = node;\n        tracer.drawEdge(edge, source, target, color, context, settings);\n        if (next) next(edge, source, target, color, context, settings);\n      }\n    });\n  }\n\n  drawEdge(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    context.strokeStyle = color;\n    context.lineWidth = size;\n    context.beginPath();\n    context.moveTo(\n      source[prefix + 'x'],\n      source[prefix + 'y']\n    );\n    context.lineTo(\n      target[prefix + 'x'],\n      target[prefix + 'y']\n    );\n    context.stroke();\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = UndirectedGraphTracer;\n","'use strict';\n\nconst DirectedGraphTracer = require('./directed_graph');\n\nconst {\n  refineByType\n} = require('../../tracer_manager/util/index');\n\nclass WeightedDirectedGraphTracer extends DirectedGraphTracer {\n  static getClassName() {\n    return 'WeightedDirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    if (this.isNew) initView(this);\n  }\n\n  _weight(target, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'weight',\n      target: target,\n      weight: weight\n    });\n    return this;\n  }\n\n  _visit(target, source, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'visit',\n      target: target,\n      source: source,\n      weight: weight\n    });\n    return this;\n  }\n\n  _leave(target, source, weight) {\n    this.manager.pushStep(this.capsule, {\n      type: 'leave',\n      target: target,\n      source: source,\n      weight: weight\n    });\n    return this;\n  }\n\n  processStep(step, options) {\n    switch (step.type) {\n      case 'weight':\n        var targetNode = this.graph.nodes(this.n(step.target));\n        if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n        break;\n      case 'visit':\n      case 'leave':\n        var visit = step.type == 'visit';\n        var targetNode = this.graph.nodes(this.n(step.target));\n        var color = visit ? step.weight === undefined ? this.color.selected : this.color.visited : this.color.left;\n        targetNode.color = color;\n        if (step.weight !== undefined) targetNode.weight = refineByType(step.weight);\n        if (step.source !== undefined) {\n          var edgeId = this.e(step.source, step.target);\n          var edge = this.graph.edges(edgeId);\n          edge.color = color;\n          this.graph.dropEdge(edgeId).addEdge(edge);\n        }\n        if (this.logTracer) {\n          var source = step.source;\n          if (source === undefined) source = '';\n          this.logTracer.print(visit ? source + ' -> ' + step.target : source + ' <- ' + step.target);\n        }\n        break;\n      default:\n        super.processStep(step, options);\n    }\n  }\n\n  clear() {\n    super.clear();\n\n    this.clearWeights();\n  }\n\n  clearWeights() {\n    this.graph.nodes().forEach(function (node) {\n      node.weight = 0;\n    });\n  }\n\n  drawEdgeWeight(edge, source, target, color, context, settings) {\n    if (source == target)\n      return;\n\n    var prefix = settings('prefix') || '',\n      size = edge[prefix + 'size'] || 1;\n\n    if (size < settings('edgeLabelThreshold'))\n      return;\n\n    if (0 === settings('edgeLabelSizePowRatio'))\n      throw '\"edgeLabelSizePowRatio\" must not be 0.';\n\n    var fontSize,\n      x = (source[prefix + 'x'] + target[prefix + 'x']) / 2,\n      y = (source[prefix + 'y'] + target[prefix + 'y']) / 2,\n      dX = target[prefix + 'x'] - source[prefix + 'x'],\n      dY = target[prefix + 'y'] - source[prefix + 'y'],\n      angle = Math.atan2(dY, dX);\n\n    fontSize = (settings('edgeLabelSize') === 'fixed') ?\n      settings('defaultEdgeLabelSize') :\n    settings('defaultEdgeLabelSize') *\n    size *\n    Math.pow(size, -1 / settings('edgeLabelSizePowRatio'));\n\n    context.save();\n\n    if (edge.active) {\n      context.font = [\n        settings('activeFontStyle'),\n        fontSize + 'px',\n        settings('activeFont') || settings('font')\n      ].join(' ');\n\n      context.fillStyle = color;\n    } else {\n      context.font = [\n        settings('fontStyle'),\n        fontSize + 'px',\n        settings('font')\n      ].join(' ');\n\n      context.fillStyle = color;\n    }\n\n    context.textAlign = 'center';\n    context.textBaseline = 'alphabetic';\n\n    context.translate(x, y);\n    context.rotate(angle);\n    context.fillText(\n      edge.weight,\n      0,\n      (-size / 2) - 3\n    );\n\n    context.restore();\n  }\n\n  drawNodeWeight(node, context, settings) {\n    var fontSize,\n      prefix = settings('prefix') || '',\n      size = node[prefix + 'size'];\n\n    if (size < settings('labelThreshold'))\n      return;\n\n    fontSize = (settings('labelSize') === 'fixed') ?\n      settings('defaultLabelSize') :\n    settings('labelSizeRatio') * size;\n\n    context.font = (settings('fontStyle') ? settings('fontStyle') + ' ' : '') +\n      fontSize + 'px ' + settings('font');\n    context.fillStyle = (settings('labelColor') === 'node') ?\n      (node.color || settings('defaultNodeColor')) :\n      settings('defaultLabelColor');\n\n    context.textAlign = 'left';\n    context.fillText(\n      node.weight,\n      Math.round(node[prefix + 'x'] + size * 1.5),\n      Math.round(node[prefix + 'y'] + fontSize / 3)\n    );\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    edgeLabelSize: 'proportional',\n    defaultEdgeLabelSize: 20,\n    edgeLabelSizePowRatio: 0.8,\n    funcLabelsDef(node, context, settings) {\n      tracer.drawNodeWeight(node, context, settings);\n      tracer.drawLabel(node, context, settings);\n    },\n    funcHoversDef(node, context, settings) {\n      tracer.drawOnHover(node, context, settings, tracer.drawEdgeWeight);\n    },\n    funcEdgesArrow(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawArrow(edge, source, target, color, context, settings);\n      tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = WeightedDirectedGraphTracer;\n","'use strict';\n\nconst WeightedDirectedGraphTracer = require('./weighted_directed_graph');\nconst UndirectedGraphTracer = require('./undirected_graph');\n\nclass WeightedUndirectedGraphTracer extends WeightedDirectedGraphTracer {\n  static getClassName() {\n    return 'WeightedUndirectedGraphTracer';\n  }\n\n  constructor(name) {\n    super(name);\n\n    this.e = UndirectedGraphTracer.prototype.e;\n    this.drawOnHover = UndirectedGraphTracer.prototype.drawOnHover;\n    this.drawEdge = UndirectedGraphTracer.prototype.drawEdge;\n\n    if (this.isNew) initView(this);\n  }\n\n  setTreeData(G, root) {\n    return super.setTreeData(G, root, true);\n  }\n\n  setData(G) {\n    return super.setData(G, true);\n  }\n\n  drawEdgeWeight(edge, source, target, color, context, settings) {\n    var prefix = settings('prefix') || '';\n    if (source[prefix + 'x'] > target[prefix + 'x']) {\n      var temp = source;\n      source = target;\n      target = temp;\n    }\n    WeightedDirectedGraphTracer.prototype.drawEdgeWeight.call(this, edge, source, target, color, context, settings);\n  }\n}\n\nconst initView = (tracer) => {\n  tracer.s.settings({\n    defaultEdgeType: 'def',\n    funcEdgesDef(edge, source, target, context, settings) {\n      var color = tracer.getColor(edge, source, target, settings);\n      tracer.drawEdge(edge, source, target, color, context, settings);\n      tracer.drawEdgeWeight(edge, source, target, color, context, settings);\n    }\n  });\n};\n\nmodule.exports = WeightedUndirectedGraphTracer;\n","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = (url) => {\n  return request(url, {\n    type: 'GET'\n  });\n};","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = function(url) {\n  return request(url, {\n    dataType: 'json',\n    type: 'GET'\n  });\n};","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = function(url, data) {\n  return request(url, {\n    dataType: 'json',\n    type: 'POST',\n    data: JSON.stringify(data),\n  });\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../../app');\n\nconst {\n  ajax,\n  extend\n} = $;\n\nconst defaults = {\n\n};\n\nmodule.exports = function(url, options = {}) {\n  app.setIsLoading(true);\n\n  return new RSVP.Promise((resolve, reject) => {\n    const callbacks = {\n      success(response) {\n        app.setIsLoading(false);\n        resolve(response);\n      },\n      error(reason) {\n        app.setIsLoading(false);\n        reject(reason);\n      }\n    };\n\n    const opts = extend({}, defaults, options, callbacks, {\n      url\n    });\n\n    ajax(opts);\n  });\n};","'use strict';\n\nconst app = require('../app');\nconst Toast = require('../dom/toast');\n\nconst checkLoading = () => {\n  if (app.getIsLoading()) {\n    Toast.showErrorToast('Wait until it completes loading of previous file.');\n    return true;\n  }\n  return false;\n};\n\nconst getParameterByName = (name) => {\n  const url = window.location.href;\n  const regex = new RegExp(`[?&]${name}(=([^&#]*)|&|#|$)`);\n\n  const results = regex.exec(url);\n\n  if (!results || results.length !== 3) {\n    return null;\n  }\n\n  const [, , id] = results;\n\n  return id;\n};\n\nconst getHashValue = (key)=> {\n  if (!key) return null;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n  for (let i = 0; i < params.length; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      return pair[1];\n    }\n  }\n  return null;\n};\n\nconst setHashValue = (key, value)=> {\n  if (!key || !value) return;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n\n  let found = false;\n  for (let i = 0; i < params.length && !found; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      pair[1] = value;\n      params[i] = pair.join('=');\n      found = true;\n    }\n  }\n  if (!found) {\n    params.push([key, value].join('='));\n  }\n\n  const newHash = params.join('&');\n  window.location.hash = `#${newHash}`;\n};\n\nconst removeHashValue = (key) => {\n  if (!key) return;\n  const hash = window.location.hash.substr(1);\n  const params = hash ? hash.split('&') : [];\n\n  for (let i = 0; i < params.length; i++) {\n    const pair = params[i].split('=');\n    if (pair[0] === key) {\n      params.splice(i, 1);\n      break;\n    }\n  }\n\n  const newHash = params.join('&');\n  window.location.hash = `#${newHash}`;\n};\n\nconst setPath = (category, algorithm, file) => {\n  const path = category ? category + (algorithm ? `/${algorithm}` + (file ? `/${file}` : '') : '') : '';\n  setHashValue('path', path);\n};\n\nconst getPath = () => {\n  const hash = getHashValue('path');\n  if (hash) {\n    const [ category, algorithm, file ] = hash.split('/');\n    return { category, algorithm, file };\n  } else {\n    return false;\n  }\n};\n\nmodule.exports = {\n  checkLoading,\n  getParameterByName,\n  getHashValue,\n  setHashValue,\n  removeHashValue,\n  setPath,\n  getPath\n};\n","'use strict';\n\nconst loadAlgorithm = require('./load_algorithm');\nconst loadCategories = require('./load_categories');\nconst loadFile = require('./load_file');\nconst loadScratchPaper = require('./load_scratch_paper');\nconst shareScratchPaper = require('./share_scratch_paper');\nconst loadWikiList = require('./load_wiki_list');\nconst loadWiki = require('./load_wiki');\n\nmodule.exports = {\n  loadAlgorithm,\n  loadCategories,\n  loadFile,\n  loadScratchPaper,\n  shareScratchPaper,\n  loadWikiList,\n  loadWiki\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nconst {\n  getAlgorithmDir\n} = require('../utils');\n\nmodule.exports = (category, algorithm) => {\n  const dir = getAlgorithmDir(category, algorithm);\n  return getJSON(`${dir}desc.json`);\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nmodule.exports = () => {\n  return getJSON('./algorithm/category.json');\n};","'use strict';\n\nconst RSVP = require('rsvp');\n\nconst app = require('../app');\n\nconst {\n  getFileDir,\n  isScratchPaper\n} = require('../utils');\n\nconst {\n  checkLoading,\n  setPath\n} = require('./helpers');\n\nconst get = require('./ajax/get');\n\nconst loadDataAndCode = (dir) => {\n  return RSVP.hash({\n    data: get(`${dir}data.js`),\n    code: get(`${dir}code.js`)\n  });\n};\n\nconst loadFileAndUpdateContent = (dir) => {\n  app.getEditor().clearContent();\n\n  return loadDataAndCode(dir).then((content) => {\n    app.updateCachedFile(dir, content);\n    app.getEditor().setContent(content);\n  });\n};\n\nconst cachedContentExists = (cachedFile) => {\n  return cachedFile &&\n    cachedFile.data !== undefined &&\n    cachedFile.code !== undefined;\n};\n\nmodule.exports = (category, algorithm, file, explanation) => {\n  return new RSVP.Promise((resolve, reject) => {\n    if (checkLoading()) {\n      reject();\n    } else {\n      if (isScratchPaper(category)) {\n        setPath(category, app.getLoadedScratch());\n      } else {\n        setPath(category, algorithm, file);\n      }\n      $('#explanation').html(explanation);\n\n      let dir = getFileDir(category, algorithm, file);\n      app.setLastFileUsed(dir);\n      const cachedFile = app.getCachedFile(dir);\n\n      if (cachedContentExists(cachedFile)) {\n        app.getEditor().setContent(cachedFile);\n        resolve();\n      } else {\n        loadFileAndUpdateContent(dir).then(resolve, reject);\n      }\n    }\n  });\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../app');\n\nconst {\n  getFileDir\n} = require('../utils');\n\nconst getJSON = require('./ajax/get_json');\nconst loadAlgorithm = require('./load_algorithm');\n\nconst extractGistCode = (files, name) => files[`${name}.js`].content;\n\nmodule.exports = (gistID) => {\n  return new RSVP.Promise((resolve, reject) => {\n    app.setLoadedScratch(gistID);\n\n    getJSON(`https://api.github.com/gists/${gistID}`).then(({\n      files\n    }) => {\n\n      const category = 'scratch';\n      const algorithm = gistID;\n\n      loadAlgorithm(category, algorithm).then((data) => {\n\n        const algoData = extractGistCode(files, 'data');\n        const algoCode = extractGistCode(files, 'code');\n\n        // update scratch paper algo code with the loaded gist code\n        const dir = getFileDir(category, algorithm, 'scratch_paper');\n        app.updateCachedFile(dir, {\n          data: algoData,\n          code: algoCode,\n          'CREDIT.md': 'Shared by an anonymous user from http://parkjs814.github.io/AlgorithmVisualizer'\n        });\n\n        resolve({\n          category,\n          algorithm,\n          data\n        });\n      });\n    });\n  });\n\n};","'use strict';\n\nconst get = require('./ajax/get');\n\nmodule.exports = (wiki) => {\n  return get(`./AlgorithmVisualizer.wiki/${wiki}.md`);\n};","'use strict';\n\nconst getJSON = require('./ajax/get_json');\n\nmodule.exports = () => {\n  return getJSON('./wiki.json');\n};","'use strict';\n\nconst RSVP = require('rsvp');\nconst app = require('../app');\n\nconst postJSON = require('./ajax/post_json');\n\nconst {\n  setPath\n} = require('./helpers');\n\nmodule.exports = () => {\n  return new RSVP.Promise((resolve, reject) => {\n\n    const {\n      dataEditor,\n      codeEditor\n    } = app.getEditor();\n\n    const gist = {\n      'description': 'temp',\n      'public': true,\n      'files': {\n        'data.js': {\n          'content': dataEditor.getValue()\n        },\n        'code.js': {\n          'content': codeEditor.getValue()\n        }\n      }\n    };\n\n    postJSON('https://api.github.com/gists', gist).then(({\n      id\n    }) => {\n      app.setLoadedScratch(id);\n      setPath('scratch', id);\n      const {\n        href\n      } = location;\n      $('#algorithm').html('Shared');\n      resolve(href);\n    });\n  });\n};","'use strict';\n\nconst TracerManager = require('./manager');\nconst Tracer = require('../module/tracer/tracer');\n\nmodule.exports = {\n\n  init() {\n    const tm = new TracerManager();\n    Tracer.prototype.manager = tm;\n    return tm;\n  }\n\n};","'use strict';\n\nconst app = require('../app');\nconst ModuleContainer = require('../dom/module_container');\nconst TopMenu = require('../dom/top_menu');\n\nconst {\n  each,\n  extend,\n  grep\n} = $;\n\nconst stepLimit = 1e6;\n\nconst TracerManager = function () {\n  this.timer = null;\n  this.pause = false;\n  this.capsules = [];\n  this.interval = 500;\n};\n\nTracerManager.prototype = {\n\n  add(tracer) {\n\n    const $container = ModuleContainer.create();\n\n    const capsule = {\n      module: tracer.module,\n      tracer,\n      allocated: true,\n      defaultName: null,\n      $container,\n      isNew: true\n    };\n\n    this.capsules.push(capsule);\n    return capsule;\n  },\n\n  allocate(newTracer) {\n    let selectedCapsule = null;\n    let count = 0;\n\n    each(this.capsules, (i, capsule) => {\n      if (capsule.module === newTracer.module) {\n        count++;\n        if (!capsule.allocated) {\n          capsule.tracer = newTracer;\n          capsule.allocated = true;\n          capsule.isNew = false;\n          selectedCapsule = capsule;\n          return false;\n        }\n      }\n    });\n\n    if (selectedCapsule === null) {\n      count++;\n      selectedCapsule = this.add(newTracer);\n    }\n\n    const className = newTracer.module.getClassName();\n    selectedCapsule.defaultName = `${className} ${count}`;\n    selectedCapsule.order = this.order++;\n    return selectedCapsule;\n  },\n\n  deallocateAll() {\n    this.order = 0;\n    this.reset();\n    each(this.capsules, (i, capsule) => {\n      capsule.allocated = false;\n    });\n  },\n\n  removeUnallocated() {\n    let changed = false;\n\n    this.capsules = grep(this.capsules, (capsule) => {\n      let removed = !capsule.allocated;\n\n      if (capsule.isNew || removed) {\n        changed = true;\n      }\n      if (removed) {\n        capsule.$container.remove();\n      }\n\n      return !removed;\n    });\n\n    if (changed) {\n      this.place();\n    }\n  },\n\n  place() {\n    const {\n      capsules\n    } = this;\n\n    each(capsules, (i, capsule) => {\n      let width = 100;\n      let height = (100 / capsules.length);\n      let top = height * capsule.order;\n\n      capsule.$container.css({\n        top: `${top}%`,\n        width: `${width}%`,\n        height: `${height}%`\n      });\n\n      capsule.tracer.resize();\n    });\n  },\n\n  resize() {\n    this.command('resize');\n  },\n\n  isPause() {\n    return this.pause;\n  },\n\n  setInterval(interval) {\n    TopMenu.setInterval(interval);\n  },\n\n  reset() {\n    this.traces = [];\n    this.traceIndex = -1;\n    this.stepCnt = 0;\n    if (this.timer) {\n      clearTimeout(this.timer);\n    }\n    this.command('clear');\n  },\n\n  pushStep(capsule, step) {\n    if (this.stepCnt++ > stepLimit) throw \"Tracer's stack overflow\";\n    let len = this.traces.length;\n    if (len == 0) len += this.newStep();\n    const last = this.traces[len - 1];\n    last.push(extend(step, {\n      capsule\n    }));\n  },\n\n  newStep(line = -1) {\n    let len = this.traces.length;\n    if (len > 0 && ~line) {\n      this.traces[len - 1].push(line);\n    }\n    return this.traces.push([]);\n  },\n\n  pauseStep() {\n    if (this.traceIndex < 0) return;\n    this.pause = true;\n    if (this.timer) {\n      clearTimeout(this.timer);\n    }\n    TopMenu.activateBtnPause();\n  },\n\n  resumeStep() {\n    this.pause = false;\n    this.step(this.traceIndex + 1);\n    TopMenu.deactivateBtnPause();\n  },\n\n  step(i, options = {}) {\n    const tracer = this;\n\n    if (isNaN(i) || i >= this.traces.length || i < 0) return;\n\n    this.traceIndex = i;\n    const trace = this.traces[i];\n    trace.forEach((step) => {\n      if (typeof step === 'number') {\n        app.getEditor().highlightLine(step);\n        return;\n      }\n      step.capsule.tracer.processStep(step, options);\n    });\n\n    if (!options.virtual) {\n      this.command('refresh');\n    }\n\n    if (this.pause) return;\n\n    this.timer = setTimeout(() => {\n      if (!tracer.nextStep(options)) {\n        TopMenu.resetTopMenuButtons();\n      }\n    }, this.interval);\n  },\n\n  prevStep(options = {}) {\n    this.command('clear');\n\n    const finalIndex = this.traceIndex - 1;\n    if (finalIndex < 0) {\n      this.traceIndex = -1;\n      this.command('refresh');\n      return false;\n    }\n\n    for (let i = 0; i < finalIndex; i++) {\n      this.step(i, extend(options, {\n        virtual: true\n      }));\n    }\n\n    this.step(finalIndex);\n    return true;\n  },\n\n  nextStep(options = {}) {\n    const finalIndex = this.traceIndex + 1;\n    if (finalIndex >= this.traces.length) {\n      this.traceIndex = this.traces.length - 1;\n      return false;\n    }\n\n    this.step(finalIndex, options);\n    return true;\n  },\n\n  visualize() {\n    this.traceIndex = -1;\n    this.resumeStep();\n  },\n\n  command(...args) {\n    const functionName = args.shift();\n    each(this.capsules, (i, capsule) => {\n      if (capsule.allocated) {\n        capsule.tracer.module.prototype[functionName].apply(capsule.tracer, args);\n      }\n    });\n  },\n\n  findOwner(container) {\n    let selectedCapsule = null;\n    each(this.capsules, (i, capsule) => {\n      if (capsule.$container[0] === container) {\n        selectedCapsule = capsule;\n        return false;\n      }\n    });\n    return selectedCapsule.tracer;\n  }\n};\n\nmodule.exports = TracerManager;\n","'use strict';\n\nconst {\n  parse\n} = JSON;\n\nconst fromJSON = (obj) => {\n  return parse(obj, (key, value) => {\n    return value === 'Infinity' ? Infinity : value;\n  });\n};\n\nmodule.exports = fromJSON;\n","'use strict';\n\nconst toJSON = require('./to_json');\nconst fromJSON = require('./from_json');\nconst refineByType = require('./refine_by_type');\n\nmodule.exports = {\n  toJSON,\n  fromJSON,\n  refineByType\n};\n","'use strict';\n\nconst refineByType = (item) => {\n  switch (typeof(item)) {\n    case 'number':\n      return refineNumber(item);\n    case 'boolean':\n      return refineBoolean(item);\n    default:\n      return refineString(item);\n  }\n};\n\nconst refineString = (str) => {\n  return str === '' ? ' ' : str;\n};\n\nconst refineNumber = (num) => {\n  return num === Infinity ? '∞' : num;\n};\n\nconst refineBoolean = (bool) => {\n  return bool ? 'T' : 'F';\n};\n\nmodule.exports = refineByType;\n","'use strict';\n\nconst {\n  stringify\n} = JSON;\n\nconst toJSON = (obj) => {\n  return stringify(obj, (key, value) => {\n    return value === Infinity ? 'Infinity' : value;\n  });\n};\n\nmodule.exports = toJSON;\n","'use strict';\n\nconst isScratchPaper = (category, algorithm) => {\n  return category == 'scratch';\n};\n\nconst getAlgorithmDir = (category, algorithm) => {\n  if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n  return `./algorithm/${category}/${algorithm}/`;\n};\n\nconst getFileDir = (category, algorithm, file) => {\n  if (isScratchPaper(category)) return './algorithm/scratch_paper/';\n  return `./algorithm/${category}/${algorithm}/${file}/`;\n};\n\nmodule.exports = {\n  isScratchPaper,\n  getAlgorithmDir,\n  getFileDir\n};","// shim for using process in browser\n\nvar process = module.exports = {};\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = setTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    clearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        setTimeout(drainQueue, 0);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\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\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","/*!\n * @overview RSVP - a tiny implementation of Promises/A+.\n * @copyright Copyright (c) 2014 Yehuda Katz, Tom Dale, Stefan Penner and contributors\n * @license   Licensed under MIT license\n *            See https://raw.githubusercontent.com/tildeio/rsvp.js/master/LICENSE\n * @version   3.2.1\n */\n\n(function() {\n    \"use strict\";\n    function lib$rsvp$utils$$objectOrFunction(x) {\n      return typeof x === 'function' || (typeof x === 'object' && x !== null);\n    }\n\n    function lib$rsvp$utils$$isFunction(x) {\n      return typeof x === 'function';\n    }\n\n    function lib$rsvp$utils$$isMaybeThenable(x) {\n      return typeof x === 'object' && x !== null;\n    }\n\n    var lib$rsvp$utils$$_isArray;\n    if (!Array.isArray) {\n      lib$rsvp$utils$$_isArray = function (x) {\n        return Object.prototype.toString.call(x) === '[object Array]';\n      };\n    } else {\n      lib$rsvp$utils$$_isArray = Array.isArray;\n    }\n\n    var lib$rsvp$utils$$isArray = lib$rsvp$utils$$_isArray;\n\n    var lib$rsvp$utils$$now = Date.now || function() { return new Date().getTime(); };\n\n    function lib$rsvp$utils$$F() { }\n\n    var lib$rsvp$utils$$o_create = (Object.create || function (o) {\n      if (arguments.length > 1) {\n        throw new Error('Second argument not supported');\n      }\n      if (typeof o !== 'object') {\n        throw new TypeError('Argument must be an object');\n      }\n      lib$rsvp$utils$$F.prototype = o;\n      return new lib$rsvp$utils$$F();\n    });\n    function lib$rsvp$events$$indexOf(callbacks, callback) {\n      for (var i=0, l=callbacks.length; i<l; i++) {\n        if (callbacks[i] === callback) { return i; }\n      }\n\n      return -1;\n    }\n\n    function lib$rsvp$events$$callbacksFor(object) {\n      var callbacks = object._promiseCallbacks;\n\n      if (!callbacks) {\n        callbacks = object._promiseCallbacks = {};\n      }\n\n      return callbacks;\n    }\n\n    var lib$rsvp$events$$default = {\n\n      /**\n        `RSVP.EventTarget.mixin` extends an object with EventTarget methods. For\n        Example:\n\n        ```javascript\n        var object = {};\n\n        RSVP.EventTarget.mixin(object);\n\n        object.on('finished', function(event) {\n          // handle event\n        });\n\n        object.trigger('finished', { detail: value });\n        ```\n\n        `EventTarget.mixin` also works with prototypes:\n\n        ```javascript\n        var Person = function() {};\n        RSVP.EventTarget.mixin(Person.prototype);\n\n        var yehuda = new Person();\n        var tom = new Person();\n\n        yehuda.on('poke', function(event) {\n          console.log('Yehuda says OW');\n        });\n\n        tom.on('poke', function(event) {\n          console.log('Tom says OW');\n        });\n\n        yehuda.trigger('poke');\n        tom.trigger('poke');\n        ```\n\n        @method mixin\n        @for RSVP.EventTarget\n        @private\n        @param {Object} object object to extend with EventTarget methods\n      */\n      'mixin': function(object) {\n        object['on']      = this['on'];\n        object['off']     = this['off'];\n        object['trigger'] = this['trigger'];\n        object._promiseCallbacks = undefined;\n        return object;\n      },\n\n      /**\n        Registers a callback to be executed when `eventName` is triggered\n\n        ```javascript\n        object.on('event', function(eventInfo){\n          // handle the event\n        });\n\n        object.trigger('event');\n        ```\n\n        @method on\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName name of the event to listen for\n        @param {Function} callback function to be called when the event is triggered.\n      */\n      'on': function(eventName, callback) {\n        if (typeof callback !== 'function') {\n          throw new TypeError('Callback must be a function');\n        }\n\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks;\n\n        callbacks = allCallbacks[eventName];\n\n        if (!callbacks) {\n          callbacks = allCallbacks[eventName] = [];\n        }\n\n        if (lib$rsvp$events$$indexOf(callbacks, callback) === -1) {\n          callbacks.push(callback);\n        }\n      },\n\n      /**\n        You can use `off` to stop firing a particular callback for an event:\n\n        ```javascript\n        function doStuff() { // do stuff! }\n        object.on('stuff', doStuff);\n\n        object.trigger('stuff'); // doStuff will be called\n\n        // Unregister ONLY the doStuff callback\n        object.off('stuff', doStuff);\n        object.trigger('stuff'); // doStuff will NOT be called\n        ```\n\n        If you don't pass a `callback` argument to `off`, ALL callbacks for the\n        event will not be executed when the event fires. For example:\n\n        ```javascript\n        var callback1 = function(){};\n        var callback2 = function(){};\n\n        object.on('stuff', callback1);\n        object.on('stuff', callback2);\n\n        object.trigger('stuff'); // callback1 and callback2 will be executed.\n\n        object.off('stuff');\n        object.trigger('stuff'); // callback1 and callback2 will not be executed!\n        ```\n\n        @method off\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName event to stop listening to\n        @param {Function} callback optional argument. If given, only the function\n        given will be removed from the event's callback queue. If no `callback`\n        argument is given, all callbacks will be removed from the event's callback\n        queue.\n      */\n      'off': function(eventName, callback) {\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, index;\n\n        if (!callback) {\n          allCallbacks[eventName] = [];\n          return;\n        }\n\n        callbacks = allCallbacks[eventName];\n\n        index = lib$rsvp$events$$indexOf(callbacks, callback);\n\n        if (index !== -1) { callbacks.splice(index, 1); }\n      },\n\n      /**\n        Use `trigger` to fire custom events. For example:\n\n        ```javascript\n        object.on('foo', function(){\n          console.log('foo event happened!');\n        });\n        object.trigger('foo');\n        // 'foo event happened!' logged to the console\n        ```\n\n        You can also pass a value as a second argument to `trigger` that will be\n        passed as an argument to all event listeners for the event:\n\n        ```javascript\n        object.on('foo', function(value){\n          console.log(value.name);\n        });\n\n        object.trigger('foo', { name: 'bar' });\n        // 'bar' logged to the console\n        ```\n\n        @method trigger\n        @for RSVP.EventTarget\n        @private\n        @param {String} eventName name of the event to be triggered\n        @param {*} options optional value to be passed to any event handlers for\n        the given `eventName`\n      */\n      'trigger': function(eventName, options, label) {\n        var allCallbacks = lib$rsvp$events$$callbacksFor(this), callbacks, callback;\n\n        if (callbacks = allCallbacks[eventName]) {\n          // Don't cache the callbacks.length since it may grow\n          for (var i=0; i<callbacks.length; i++) {\n            callback = callbacks[i];\n\n            callback(options, label);\n          }\n        }\n      }\n    };\n\n    var lib$rsvp$config$$config = {\n      instrument: false\n    };\n\n    lib$rsvp$events$$default['mixin'](lib$rsvp$config$$config);\n\n    function lib$rsvp$config$$configure(name, value) {\n      if (name === 'onerror') {\n        // handle for legacy users that expect the actual\n        // error to be passed to their function added via\n        // `RSVP.configure('onerror', someFunctionHere);`\n        lib$rsvp$config$$config['on']('error', value);\n        return;\n      }\n\n      if (arguments.length === 2) {\n        lib$rsvp$config$$config[name] = value;\n      } else {\n        return lib$rsvp$config$$config[name];\n      }\n    }\n\n    var lib$rsvp$instrument$$queue = [];\n\n    function lib$rsvp$instrument$$scheduleFlush() {\n      setTimeout(function() {\n        var entry;\n        for (var i = 0; i < lib$rsvp$instrument$$queue.length; i++) {\n          entry = lib$rsvp$instrument$$queue[i];\n\n          var payload = entry.payload;\n\n          payload.guid = payload.key + payload.id;\n          payload.childGuid = payload.key + payload.childId;\n          if (payload.error) {\n            payload.stack = payload.error.stack;\n          }\n\n          lib$rsvp$config$$config['trigger'](entry.name, entry.payload);\n        }\n        lib$rsvp$instrument$$queue.length = 0;\n      }, 50);\n    }\n\n    function lib$rsvp$instrument$$instrument(eventName, promise, child) {\n      if (1 === lib$rsvp$instrument$$queue.push({\n        name: eventName,\n        payload: {\n          key: promise._guidKey,\n          id:  promise._id,\n          eventName: eventName,\n          detail: promise._result,\n          childId: child && child._id,\n          label: promise._label,\n          timeStamp: lib$rsvp$utils$$now(),\n          error: lib$rsvp$config$$config[\"instrument-with-stack\"] ? new Error(promise._label) : null\n        }})) {\n          lib$rsvp$instrument$$scheduleFlush();\n        }\n      }\n    var lib$rsvp$instrument$$default = lib$rsvp$instrument$$instrument;\n    function lib$rsvp$then$$then(onFulfillment, onRejection, label) {\n      var parent = this;\n      var state = parent._state;\n\n      if (state === lib$rsvp$$internal$$FULFILLED && !onFulfillment || state === lib$rsvp$$internal$$REJECTED && !onRejection) {\n        lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, parent);\n        return parent;\n      }\n\n      parent._onError = null;\n\n      var child = new parent.constructor(lib$rsvp$$internal$$noop, label);\n      var result = parent._result;\n\n      lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('chained', parent, child);\n\n      if (state) {\n        var callback = arguments[state - 1];\n        lib$rsvp$config$$config.async(function(){\n          lib$rsvp$$internal$$invokeCallback(state, child, callback, result);\n        });\n      } else {\n        lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection);\n      }\n\n      return child;\n    }\n    var lib$rsvp$then$$default = lib$rsvp$then$$then;\n    function lib$rsvp$promise$resolve$$resolve(object, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n\n      if (object && typeof object === 'object' && object.constructor === Constructor) {\n        return object;\n      }\n\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      lib$rsvp$$internal$$resolve(promise, object);\n      return promise;\n    }\n    var lib$rsvp$promise$resolve$$default = lib$rsvp$promise$resolve$$resolve;\n    function lib$rsvp$enumerator$$makeSettledResult(state, position, value) {\n      if (state === lib$rsvp$$internal$$FULFILLED) {\n        return {\n          state: 'fulfilled',\n          value: value\n        };\n      } else {\n         return {\n          state: 'rejected',\n          reason: value\n        };\n      }\n    }\n\n    function lib$rsvp$enumerator$$Enumerator(Constructor, input, abortOnReject, label) {\n      this._instanceConstructor = Constructor;\n      this.promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      this._abortOnReject = abortOnReject;\n\n      if (this._validateInput(input)) {\n        this._input     = input;\n        this.length     = input.length;\n        this._remaining = input.length;\n\n        this._init();\n\n        if (this.length === 0) {\n          lib$rsvp$$internal$$fulfill(this.promise, this._result);\n        } else {\n          this.length = this.length || 0;\n          this._enumerate();\n          if (this._remaining === 0) {\n            lib$rsvp$$internal$$fulfill(this.promise, this._result);\n          }\n        }\n      } else {\n        lib$rsvp$$internal$$reject(this.promise, this._validationError());\n      }\n    }\n\n    var lib$rsvp$enumerator$$default = lib$rsvp$enumerator$$Enumerator;\n\n    lib$rsvp$enumerator$$Enumerator.prototype._validateInput = function(input) {\n      return lib$rsvp$utils$$isArray(input);\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._validationError = function() {\n      return new Error('Array Methods must be provided an Array');\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._init = function() {\n      this._result = new Array(this.length);\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._enumerate = function() {\n      var length     = this.length;\n      var promise    = this.promise;\n      var input      = this._input;\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        this._eachEntry(input[i], i);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._settleMaybeThenable = function(entry, i) {\n      var c = this._instanceConstructor;\n      var resolve = c.resolve;\n\n      if (resolve === lib$rsvp$promise$resolve$$default) {\n        var then = lib$rsvp$$internal$$getThen(entry);\n\n        if (then === lib$rsvp$then$$default &&\n            entry._state !== lib$rsvp$$internal$$PENDING) {\n          entry._onError = null;\n          this._settledAt(entry._state, i, entry._result);\n        } else if (typeof then !== 'function') {\n          this._remaining--;\n          this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n        } else if (c === lib$rsvp$promise$$default) {\n          var promise = new c(lib$rsvp$$internal$$noop);\n          lib$rsvp$$internal$$handleMaybeThenable(promise, entry, then);\n          this._willSettleAt(promise, i);\n        } else {\n          this._willSettleAt(new c(function(resolve) { resolve(entry); }), i);\n        }\n      } else {\n        this._willSettleAt(resolve(entry), i);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._eachEntry = function(entry, i) {\n      if (lib$rsvp$utils$$isMaybeThenable(entry)) {\n        this._settleMaybeThenable(entry, i);\n      } else {\n        this._remaining--;\n        this._result[i] = this._makeResult(lib$rsvp$$internal$$FULFILLED, i, entry);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._settledAt = function(state, i, value) {\n      var promise = this.promise;\n\n      if (promise._state === lib$rsvp$$internal$$PENDING) {\n        this._remaining--;\n\n        if (this._abortOnReject && state === lib$rsvp$$internal$$REJECTED) {\n          lib$rsvp$$internal$$reject(promise, value);\n        } else {\n          this._result[i] = this._makeResult(state, i, value);\n        }\n      }\n\n      if (this._remaining === 0) {\n        lib$rsvp$$internal$$fulfill(promise, this._result);\n      }\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._makeResult = function(state, i, value) {\n      return value;\n    };\n\n    lib$rsvp$enumerator$$Enumerator.prototype._willSettleAt = function(promise, i) {\n      var enumerator = this;\n\n      lib$rsvp$$internal$$subscribe(promise, undefined, function(value) {\n        enumerator._settledAt(lib$rsvp$$internal$$FULFILLED, i, value);\n      }, function(reason) {\n        enumerator._settledAt(lib$rsvp$$internal$$REJECTED, i, reason);\n      });\n    };\n    function lib$rsvp$promise$all$$all(entries, label) {\n      return new lib$rsvp$enumerator$$default(this, entries, true /* abort on reject */, label).promise;\n    }\n    var lib$rsvp$promise$all$$default = lib$rsvp$promise$all$$all;\n    function lib$rsvp$promise$race$$race(entries, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n\n      if (!lib$rsvp$utils$$isArray(entries)) {\n        lib$rsvp$$internal$$reject(promise, new TypeError('You must pass an array to race.'));\n        return promise;\n      }\n\n      var length = entries.length;\n\n      function onFulfillment(value) {\n        lib$rsvp$$internal$$resolve(promise, value);\n      }\n\n      function onRejection(reason) {\n        lib$rsvp$$internal$$reject(promise, reason);\n      }\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        lib$rsvp$$internal$$subscribe(Constructor.resolve(entries[i]), undefined, onFulfillment, onRejection);\n      }\n\n      return promise;\n    }\n    var lib$rsvp$promise$race$$default = lib$rsvp$promise$race$$race;\n    function lib$rsvp$promise$reject$$reject(reason, label) {\n      /*jshint validthis:true */\n      var Constructor = this;\n      var promise = new Constructor(lib$rsvp$$internal$$noop, label);\n      lib$rsvp$$internal$$reject(promise, reason);\n      return promise;\n    }\n    var lib$rsvp$promise$reject$$default = lib$rsvp$promise$reject$$reject;\n\n    var lib$rsvp$promise$$guidKey = 'rsvp_' + lib$rsvp$utils$$now() + '-';\n    var lib$rsvp$promise$$counter = 0;\n\n    function lib$rsvp$promise$$needsResolver() {\n      throw new TypeError('You must pass a resolver function as the first argument to the promise constructor');\n    }\n\n    function lib$rsvp$promise$$needsNew() {\n      throw new TypeError(\"Failed to construct 'Promise': Please use the 'new' operator, this object constructor cannot be called as a function.\");\n    }\n\n    function lib$rsvp$promise$$Promise(resolver, label) {\n      this._id = lib$rsvp$promise$$counter++;\n      this._label = label;\n      this._state = undefined;\n      this._result = undefined;\n      this._subscribers = [];\n\n      lib$rsvp$config$$config.instrument && lib$rsvp$instrument$$default('created', this);\n\n      if (lib$rsvp$$internal$$noop !== resolver) {\n        typeof resolver !== 'function' && lib$rsvp$promise$$needsResolver();\n        this instanceof lib$rsvp$promise$$Promise ? lib$rsvp$$internal$$initializePromise(this, resolver) : lib$rsvp$promise$$needsNew();\n      }\n    }\n\n    var lib$rsvp$promise$$default = lib$rsvp$promise$$Promise;\n\n    // deprecated\n    lib$rsvp$promise$$Promise.cast = lib$rsvp$promise$resolve$$default;\n    lib$rsvp$promise$$Promise.all = lib$rsvp$promise$all$$default;\n    lib$rsvp$promise$$Promise.race = lib$rsvp$promise$race$$default;\n    lib$rsvp$promise$$Promise.resolve = lib$rsvp$promise$resolve$$default;\n    lib$rsvp$promise$$Promise.reject = lib$rsvp$promise$reject$$default;\n\n    lib$rsvp$promise$$Promise.prototype = {\n      constructor: lib$rsvp$promise$$Promise,\n\n      _guidKey: lib$rsvp$promise$$guidKey,\n\n      _onError: function (reason) {\n        var promise = this;\n        lib$rsvp$config$$config.after(function() {\n          if (promise._onError) {\n            lib$rsvp$config$$config['trigger']('error', reason, promise._label);\n          }\n        });\n      },\n\n    /**\n      The primary way of interacting with a promise is through its `then` method,\n      which registers callbacks to receive either a promise's eventual value or the\n      reason why the promise cannot be fulfilled.\n\n      ```js\n      findUser().then(function(user){\n        // user is available\n      }, function(reason){\n        // user is unavailable, and you are given the reason why\n      });\n      ```\n\n      Chaining\n      --------\n\n      The return value of `then` is itself a promise.  This second, 'downstream'\n      promise is resolved with the return value of the first promise's fulfillment\n      or rejection handler, or rejected if the handler throws an exception.\n\n      ```js\n      findUser().then(function (user) {\n        return user.name;\n      }, function (reason) {\n        return 'default name';\n      }).then(function (userName) {\n        // If `findUser` fulfilled, `userName` will be the user's name, otherwise it\n        // will be `'default name'`\n      });\n\n      findUser().then(function (user) {\n        throw new Error('Found user, but still unhappy');\n      }, function (reason) {\n        throw new Error('`findUser` rejected and we're unhappy');\n      }).then(function (value) {\n        // never reached\n      }, function (reason) {\n        // if `findUser` fulfilled, `reason` will be 'Found user, but still unhappy'.\n        // If `findUser` rejected, `reason` will be '`findUser` rejected and we're unhappy'.\n      });\n      ```\n      If the downstream promise does not specify a rejection handler, rejection reasons will be propagated further downstream.\n\n      ```js\n      findUser().then(function (user) {\n        throw new PedagogicalException('Upstream error');\n      }).then(function (value) {\n        // never reached\n      }).then(function (value) {\n        // never reached\n      }, function (reason) {\n        // The `PedgagocialException` is propagated all the way down to here\n      });\n      ```\n\n      Assimilation\n      ------------\n\n      Sometimes the value you want to propagate to a downstream promise can only be\n      retrieved asynchronously. This can be achieved by returning a promise in the\n      fulfillment or rejection handler. The downstream promise will then be pending\n      until the returned promise is settled. This is called *assimilation*.\n\n      ```js\n      findUser().then(function (user) {\n        return findCommentsByAuthor(user);\n      }).then(function (comments) {\n        // The user's comments are now available\n      });\n      ```\n\n      If the assimliated promise rejects, then the downstream promise will also reject.\n\n      ```js\n      findUser().then(function (user) {\n        return findCommentsByAuthor(user);\n      }).then(function (comments) {\n        // If `findCommentsByAuthor` fulfills, we'll have the value here\n      }, function (reason) {\n        // If `findCommentsByAuthor` rejects, we'll have the reason here\n      });\n      ```\n\n      Simple Example\n      --------------\n\n      Synchronous Example\n\n      ```javascript\n      var result;\n\n      try {\n        result = findResult();\n        // success\n      } catch(reason) {\n        // failure\n      }\n      ```\n\n      Errback Example\n\n      ```js\n      findResult(function(result, err){\n        if (err) {\n          // failure\n        } else {\n          // success\n        }\n      });\n      ```\n\n      Promise Example;\n\n      ```javascript\n      findResult().then(function(result){\n        // success\n      }, function(reason){\n        // failure\n      });\n      ```\n\n      Advanced Example\n      --------------\n\n      Synchronous Example\n\n      ```javascript\n      var author, books;\n\n      try {\n        author = findAuthor();\n        books  = findBooksByAuthor(author);\n        // success\n      } catch(reason) {\n        // failure\n      }\n      ```\n\n      Errback Example\n\n      ```js\n\n      function foundBooks(books) {\n\n      }\n\n      function failure(reason) {\n\n      }\n\n      findAuthor(function(author, err){\n        if (err) {\n          failure(err);\n          // failure\n        } else {\n          try {\n            findBoooksByAuthor(author, function(books, err) {\n              if (err) {\n                failure(err);\n              } else {\n                try {\n                  foundBooks(books);\n                } catch(reason) {\n                  failure(reason);\n                }\n              }\n            });\n          } catch(error) {\n            failure(err);\n          }\n          // success\n        }\n      });\n      ```\n\n      Promise Example;\n\n      ```javascript\n      findAuthor().\n        then(findBooksByAuthor).\n        then(function(books){\n          // found books\n      }).catch(function(reason){\n        // something went wrong\n      });\n      ```\n\n      @method then\n      @param {Function} onFulfillment\n      @param {Function} onRejection\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      then: lib$rsvp$then$$default,\n\n    /**\n      `catch` is simply sugar for `then(undefined, onRejection)` which makes it the same\n      as the catch block of a try/catch statement.\n\n      ```js\n      function findAuthor(){\n        throw new Error('couldn't find that author');\n      }\n\n      // synchronous\n      try {\n        findAuthor();\n      } catch(reason) {\n        // something went wrong\n      }\n\n      // async with promises\n      findAuthor().catch(function(reason){\n        // something went wrong\n      });\n      ```\n\n      @method catch\n      @param {Function} onRejection\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      'catch': function(onRejection, label) {\n        return this.then(undefined, onRejection, label);\n      },\n\n    /**\n      `finally` will be invoked regardless of the promise's fate just as native\n      try/catch/finally behaves\n\n      Synchronous example:\n\n      ```js\n      findAuthor() {\n        if (Math.random() > 0.5) {\n          throw new Error();\n        }\n        return new Author();\n      }\n\n      try {\n        return findAuthor(); // succeed or fail\n      } catch(error) {\n        return findOtherAuther();\n      } finally {\n        // always runs\n        // doesn't affect the return value\n      }\n      ```\n\n      Asynchronous example:\n\n      ```js\n      findAuthor().catch(function(reason){\n        return findOtherAuther();\n      }).finally(function(){\n        // author was either found, or not\n      });\n      ```\n\n      @method finally\n      @param {Function} callback\n      @param {String} label optional string for labeling the promise.\n      Useful for tooling.\n      @return {Promise}\n    */\n      'finally': function(callback, label) {\n        var promise = this;\n        var constructor = promise.constructor;\n\n        return promise.then(function(value) {\n          return constructor.resolve(callback()).then(function() {\n            return value;\n          });\n        }, function(reason) {\n          return constructor.resolve(callback()).then(function() {\n            return constructor.reject(reason);\n          });\n        }, label);\n      }\n    };\n    function  lib$rsvp$$internal$$withOwnPromise() {\n      return new TypeError('A promises callback cannot return that same promise.');\n    }\n\n    function lib$rsvp$$internal$$noop() {}\n\n    var lib$rsvp$$internal$$PENDING   = void 0;\n    var lib$rsvp$$internal$$FULFILLED = 1;\n    var lib$rsvp$$internal$$REJECTED  = 2;\n\n    var lib$rsvp$$internal$$GET_THEN_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n    function lib$rsvp$$internal$$getThen(promise) {\n      try {\n        return promise.then;\n      } catch(error) {\n        lib$rsvp$$internal$$GET_THEN_ERROR.error = error;\n        return lib$rsvp$$internal$$GET_THEN_ERROR;\n      }\n    }\n\n    function lib$rsvp$$internal$$tryThen(then, value, fulfillmentHandler, rejectionHandler) {\n      try {\n        then.call(value, fulfillmentHandler, rejectionHandler);\n      } catch(e) {\n        return e;\n      }\n    }\n\n    function lib$rsvp$$internal$$handleForeignThenable(promise, thenable, then) {\n      lib$rsvp$config$$config.async(function(promise) {\n        var sealed = false;\n        var error = lib$rsvp$$internal$$tryThen(then, thenable, function(value) {\n          if (sealed) { return; }\n          sealed = true;\n          if (thenable !== value) {\n            lib$rsvp$$internal$$resolve(promise, value, undefined);\n          } else {\n            lib$rsvp$$internal$$fulfill(promise, value);\n          }\n        }, function(reason) {\n          if (sealed) { return; }\n          sealed = true;\n\n          lib$rsvp$$internal$$reject(promise, reason);\n        }, 'Settle: ' + (promise._label || ' unknown promise'));\n\n        if (!sealed && error) {\n          sealed = true;\n          lib$rsvp$$internal$$reject(promise, error);\n        }\n      }, promise);\n    }\n\n    function lib$rsvp$$internal$$handleOwnThenable(promise, thenable) {\n      if (thenable._state === lib$rsvp$$internal$$FULFILLED) {\n        lib$rsvp$$internal$$fulfill(promise, thenable._result);\n      } else if (thenable._state === lib$rsvp$$internal$$REJECTED) {\n        thenable._onError = null;\n        lib$rsvp$$internal$$reject(promise, thenable._result);\n      } else {\n        lib$rsvp$$internal$$subscribe(thenable, undefined, function(value) {\n          if (thenable !== value) {\n            lib$rsvp$$internal$$resolve(promise, value, undefined);\n          } else {\n            lib$rsvp$$internal$$fulfill(promise, value);\n          }\n        }, function(reason) {\n          lib$rsvp$$internal$$reject(promise, reason);\n        });\n      }\n    }\n\n    function lib$rsvp$$internal$$handleMaybeThenable(promise, maybeThenable, then) {\n      if (maybeThenable.constructor === promise.constructor &&\n          then === lib$rsvp$then$$default &&\n          constructor.resolve === lib$rsvp$promise$resolve$$default) {\n        lib$rsvp$$internal$$handleOwnThenable(promise, maybeThenable);\n      } else {\n        if (then === lib$rsvp$$internal$$GET_THEN_ERROR) {\n          lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$GET_THEN_ERROR.error);\n        } else if (then === undefined) {\n          lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n        } else if (lib$rsvp$utils$$isFunction(then)) {\n          lib$rsvp$$internal$$handleForeignThenable(promise, maybeThenable, then);\n        } else {\n          lib$rsvp$$internal$$fulfill(promise, maybeThenable);\n        }\n      }\n    }\n\n    function lib$rsvp$$internal$$resolve(promise, value) {\n      if (promise === value) {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      } else if (lib$rsvp$utils$$objectOrFunction(value)) {\n        lib$rsvp$$internal$$handleMaybeThenable(promise, value, lib$rsvp$$internal$$getThen(value));\n      } else {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      }\n    }\n\n    function lib$rsvp$$internal$$publishRejection(promise) {\n      if (promise._onError) {\n        promise._onError(promise._result);\n      }\n\n      lib$rsvp$$internal$$publish(promise);\n    }\n\n    function lib$rsvp$$internal$$fulfill(promise, value) {\n      if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n\n      promise._result = value;\n      promise._state = lib$rsvp$$internal$$FULFILLED;\n\n      if (promise._subscribers.length === 0) {\n        if (lib$rsvp$config$$config.instrument) {\n          lib$rsvp$instrument$$default('fulfilled', promise);\n        }\n      } else {\n        lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, promise);\n      }\n    }\n\n    function lib$rsvp$$internal$$reject(promise, reason) {\n      if (promise._state !== lib$rsvp$$internal$$PENDING) { return; }\n      promise._state = lib$rsvp$$internal$$REJECTED;\n      promise._result = reason;\n      lib$rsvp$config$$config.async(lib$rsvp$$internal$$publishRejection, promise);\n    }\n\n    function lib$rsvp$$internal$$subscribe(parent, child, onFulfillment, onRejection) {\n      var subscribers = parent._subscribers;\n      var length = subscribers.length;\n\n      parent._onError = null;\n\n      subscribers[length] = child;\n      subscribers[length + lib$rsvp$$internal$$FULFILLED] = onFulfillment;\n      subscribers[length + lib$rsvp$$internal$$REJECTED]  = onRejection;\n\n      if (length === 0 && parent._state) {\n        lib$rsvp$config$$config.async(lib$rsvp$$internal$$publish, parent);\n      }\n    }\n\n    function lib$rsvp$$internal$$publish(promise) {\n      var subscribers = promise._subscribers;\n      var settled = promise._state;\n\n      if (lib$rsvp$config$$config.instrument) {\n        lib$rsvp$instrument$$default(settled === lib$rsvp$$internal$$FULFILLED ? 'fulfilled' : 'rejected', promise);\n      }\n\n      if (subscribers.length === 0) { return; }\n\n      var child, callback, detail = promise._result;\n\n      for (var i = 0; i < subscribers.length; i += 3) {\n        child = subscribers[i];\n        callback = subscribers[i + settled];\n\n        if (child) {\n          lib$rsvp$$internal$$invokeCallback(settled, child, callback, detail);\n        } else {\n          callback(detail);\n        }\n      }\n\n      promise._subscribers.length = 0;\n    }\n\n    function lib$rsvp$$internal$$ErrorObject() {\n      this.error = null;\n    }\n\n    var lib$rsvp$$internal$$TRY_CATCH_ERROR = new lib$rsvp$$internal$$ErrorObject();\n\n    function lib$rsvp$$internal$$tryCatch(callback, detail) {\n      try {\n        return callback(detail);\n      } catch(e) {\n        lib$rsvp$$internal$$TRY_CATCH_ERROR.error = e;\n        return lib$rsvp$$internal$$TRY_CATCH_ERROR;\n      }\n    }\n\n    function lib$rsvp$$internal$$invokeCallback(settled, promise, callback, detail) {\n      var hasCallback = lib$rsvp$utils$$isFunction(callback),\n          value, error, succeeded, failed;\n\n      if (hasCallback) {\n        value = lib$rsvp$$internal$$tryCatch(callback, detail);\n\n        if (value === lib$rsvp$$internal$$TRY_CATCH_ERROR) {\n          failed = true;\n          error = value.error;\n          value = null;\n        } else {\n          succeeded = true;\n        }\n\n        if (promise === value) {\n          lib$rsvp$$internal$$reject(promise, lib$rsvp$$internal$$withOwnPromise());\n          return;\n        }\n\n      } else {\n        value = detail;\n        succeeded = true;\n      }\n\n      if (promise._state !== lib$rsvp$$internal$$PENDING) {\n        // noop\n      } else if (hasCallback && succeeded) {\n        lib$rsvp$$internal$$resolve(promise, value);\n      } else if (failed) {\n        lib$rsvp$$internal$$reject(promise, error);\n      } else if (settled === lib$rsvp$$internal$$FULFILLED) {\n        lib$rsvp$$internal$$fulfill(promise, value);\n      } else if (settled === lib$rsvp$$internal$$REJECTED) {\n        lib$rsvp$$internal$$reject(promise, value);\n      }\n    }\n\n    function lib$rsvp$$internal$$initializePromise(promise, resolver) {\n      var resolved = false;\n      try {\n        resolver(function resolvePromise(value){\n          if (resolved) { return; }\n          resolved = true;\n          lib$rsvp$$internal$$resolve(promise, value);\n        }, function rejectPromise(reason) {\n          if (resolved) { return; }\n          resolved = true;\n          lib$rsvp$$internal$$reject(promise, reason);\n        });\n      } catch(e) {\n        lib$rsvp$$internal$$reject(promise, e);\n      }\n    }\n\n    function lib$rsvp$all$settled$$AllSettled(Constructor, entries, label) {\n      this._superConstructor(Constructor, entries, false /* don't abort on reject */, label);\n    }\n\n    lib$rsvp$all$settled$$AllSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n    lib$rsvp$all$settled$$AllSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$all$settled$$AllSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n    lib$rsvp$all$settled$$AllSettled.prototype._validationError = function() {\n      return new Error('allSettled must be called with an array');\n    };\n\n    function lib$rsvp$all$settled$$allSettled(entries, label) {\n      return new lib$rsvp$all$settled$$AllSettled(lib$rsvp$promise$$default, entries, label).promise;\n    }\n    var lib$rsvp$all$settled$$default = lib$rsvp$all$settled$$allSettled;\n    function lib$rsvp$all$$all(array, label) {\n      return lib$rsvp$promise$$default.all(array, label);\n    }\n    var lib$rsvp$all$$default = lib$rsvp$all$$all;\n    var lib$rsvp$asap$$len = 0;\n    var lib$rsvp$asap$$toString = {}.toString;\n    var lib$rsvp$asap$$vertxNext;\n    function lib$rsvp$asap$$asap(callback, arg) {\n      lib$rsvp$asap$$queue[lib$rsvp$asap$$len] = callback;\n      lib$rsvp$asap$$queue[lib$rsvp$asap$$len + 1] = arg;\n      lib$rsvp$asap$$len += 2;\n      if (lib$rsvp$asap$$len === 2) {\n        // If len is 1, that means that we need to schedule an async flush.\n        // If additional callbacks are queued before the queue is flushed, they\n        // will be processed by this flush that we are scheduling.\n        lib$rsvp$asap$$scheduleFlush();\n      }\n    }\n\n    var lib$rsvp$asap$$default = lib$rsvp$asap$$asap;\n\n    var lib$rsvp$asap$$browserWindow = (typeof window !== 'undefined') ? window : undefined;\n    var lib$rsvp$asap$$browserGlobal = lib$rsvp$asap$$browserWindow || {};\n    var lib$rsvp$asap$$BrowserMutationObserver = lib$rsvp$asap$$browserGlobal.MutationObserver || lib$rsvp$asap$$browserGlobal.WebKitMutationObserver;\n    var lib$rsvp$asap$$isNode = typeof self === 'undefined' &&\n      typeof process !== 'undefined' && {}.toString.call(process) === '[object process]';\n\n    // test for web worker but not in IE10\n    var lib$rsvp$asap$$isWorker = typeof Uint8ClampedArray !== 'undefined' &&\n      typeof importScripts !== 'undefined' &&\n      typeof MessageChannel !== 'undefined';\n\n    // node\n    function lib$rsvp$asap$$useNextTick() {\n      var nextTick = process.nextTick;\n      // node version 0.10.x displays a deprecation warning when nextTick is used recursively\n      // setImmediate should be used instead instead\n      var version = process.versions.node.match(/^(?:(\\d+)\\.)?(?:(\\d+)\\.)?(\\*|\\d+)$/);\n      if (Array.isArray(version) && version[1] === '0' && version[2] === '10') {\n        nextTick = setImmediate;\n      }\n      return function() {\n        nextTick(lib$rsvp$asap$$flush);\n      };\n    }\n\n    // vertx\n    function lib$rsvp$asap$$useVertxTimer() {\n      return function() {\n        lib$rsvp$asap$$vertxNext(lib$rsvp$asap$$flush);\n      };\n    }\n\n    function lib$rsvp$asap$$useMutationObserver() {\n      var iterations = 0;\n      var observer = new lib$rsvp$asap$$BrowserMutationObserver(lib$rsvp$asap$$flush);\n      var node = document.createTextNode('');\n      observer.observe(node, { characterData: true });\n\n      return function() {\n        node.data = (iterations = ++iterations % 2);\n      };\n    }\n\n    // web worker\n    function lib$rsvp$asap$$useMessageChannel() {\n      var channel = new MessageChannel();\n      channel.port1.onmessage = lib$rsvp$asap$$flush;\n      return function () {\n        channel.port2.postMessage(0);\n      };\n    }\n\n    function lib$rsvp$asap$$useSetTimeout() {\n      return function() {\n        setTimeout(lib$rsvp$asap$$flush, 1);\n      };\n    }\n\n    var lib$rsvp$asap$$queue = new Array(1000);\n    function lib$rsvp$asap$$flush() {\n      for (var i = 0; i < lib$rsvp$asap$$len; i+=2) {\n        var callback = lib$rsvp$asap$$queue[i];\n        var arg = lib$rsvp$asap$$queue[i+1];\n\n        callback(arg);\n\n        lib$rsvp$asap$$queue[i] = undefined;\n        lib$rsvp$asap$$queue[i+1] = undefined;\n      }\n\n      lib$rsvp$asap$$len = 0;\n    }\n\n    function lib$rsvp$asap$$attemptVertex() {\n      try {\n        var r = require;\n        var vertx = r('vertx');\n        lib$rsvp$asap$$vertxNext = vertx.runOnLoop || vertx.runOnContext;\n        return lib$rsvp$asap$$useVertxTimer();\n      } catch(e) {\n        return lib$rsvp$asap$$useSetTimeout();\n      }\n    }\n\n    var lib$rsvp$asap$$scheduleFlush;\n    // Decide what async method to use to triggering processing of queued callbacks:\n    if (lib$rsvp$asap$$isNode) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useNextTick();\n    } else if (lib$rsvp$asap$$BrowserMutationObserver) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMutationObserver();\n    } else if (lib$rsvp$asap$$isWorker) {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useMessageChannel();\n    } else if (lib$rsvp$asap$$browserWindow === undefined && typeof require === 'function') {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$attemptVertex();\n    } else {\n      lib$rsvp$asap$$scheduleFlush = lib$rsvp$asap$$useSetTimeout();\n    }\n    function lib$rsvp$defer$$defer(label) {\n      var deferred = {};\n\n      deferred['promise'] = new lib$rsvp$promise$$default(function(resolve, reject) {\n        deferred['resolve'] = resolve;\n        deferred['reject'] = reject;\n      }, label);\n\n      return deferred;\n    }\n    var lib$rsvp$defer$$default = lib$rsvp$defer$$defer;\n    function lib$rsvp$filter$$filter(promises, filterFn, label) {\n      return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n        if (!lib$rsvp$utils$$isFunction(filterFn)) {\n          throw new TypeError(\"You must pass a function as filter's second argument.\");\n        }\n\n        var length = values.length;\n        var filtered = new Array(length);\n\n        for (var i = 0; i < length; i++) {\n          filtered[i] = filterFn(values[i]);\n        }\n\n        return lib$rsvp$promise$$default.all(filtered, label).then(function(filtered) {\n          var results = new Array(length);\n          var newLength = 0;\n\n          for (var i = 0; i < length; i++) {\n            if (filtered[i]) {\n              results[newLength] = values[i];\n              newLength++;\n            }\n          }\n\n          results.length = newLength;\n\n          return results;\n        });\n      });\n    }\n    var lib$rsvp$filter$$default = lib$rsvp$filter$$filter;\n\n    function lib$rsvp$promise$hash$$PromiseHash(Constructor, object, label) {\n      this._superConstructor(Constructor, object, true, label);\n    }\n\n    var lib$rsvp$promise$hash$$default = lib$rsvp$promise$hash$$PromiseHash;\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype = lib$rsvp$utils$$o_create(lib$rsvp$enumerator$$default.prototype);\n    lib$rsvp$promise$hash$$PromiseHash.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$promise$hash$$PromiseHash.prototype._init = function() {\n      this._result = {};\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._validateInput = function(input) {\n      return input && typeof input === 'object';\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._validationError = function() {\n      return new Error('Promise.hash must be called with an object');\n    };\n\n    lib$rsvp$promise$hash$$PromiseHash.prototype._enumerate = function() {\n      var enumerator = this;\n      var promise    = enumerator.promise;\n      var input      = enumerator._input;\n      var results    = [];\n\n      for (var key in input) {\n        if (promise._state === lib$rsvp$$internal$$PENDING && Object.prototype.hasOwnProperty.call(input, key)) {\n          results.push({\n            position: key,\n            entry: input[key]\n          });\n        }\n      }\n\n      var length = results.length;\n      enumerator._remaining = length;\n      var result;\n\n      for (var i = 0; promise._state === lib$rsvp$$internal$$PENDING && i < length; i++) {\n        result = results[i];\n        enumerator._eachEntry(result.entry, result.position);\n      }\n    };\n\n    function lib$rsvp$hash$settled$$HashSettled(Constructor, object, label) {\n      this._superConstructor(Constructor, object, false, label);\n    }\n\n    lib$rsvp$hash$settled$$HashSettled.prototype = lib$rsvp$utils$$o_create(lib$rsvp$promise$hash$$default.prototype);\n    lib$rsvp$hash$settled$$HashSettled.prototype._superConstructor = lib$rsvp$enumerator$$default;\n    lib$rsvp$hash$settled$$HashSettled.prototype._makeResult = lib$rsvp$enumerator$$makeSettledResult;\n\n    lib$rsvp$hash$settled$$HashSettled.prototype._validationError = function() {\n      return new Error('hashSettled must be called with an object');\n    };\n\n    function lib$rsvp$hash$settled$$hashSettled(object, label) {\n      return new lib$rsvp$hash$settled$$HashSettled(lib$rsvp$promise$$default, object, label).promise;\n    }\n    var lib$rsvp$hash$settled$$default = lib$rsvp$hash$settled$$hashSettled;\n    function lib$rsvp$hash$$hash(object, label) {\n      return new lib$rsvp$promise$hash$$default(lib$rsvp$promise$$default, object, label).promise;\n    }\n    var lib$rsvp$hash$$default = lib$rsvp$hash$$hash;\n    function lib$rsvp$map$$map(promises, mapFn, label) {\n      return lib$rsvp$promise$$default.all(promises, label).then(function(values) {\n        if (!lib$rsvp$utils$$isFunction(mapFn)) {\n          throw new TypeError(\"You must pass a function as map's second argument.\");\n        }\n\n        var length = values.length;\n        var results = new Array(length);\n\n        for (var i = 0; i < length; i++) {\n          results[i] = mapFn(values[i]);\n        }\n\n        return lib$rsvp$promise$$default.all(results, label);\n      });\n    }\n    var lib$rsvp$map$$default = lib$rsvp$map$$map;\n\n    function lib$rsvp$node$$Result() {\n      this.value = undefined;\n    }\n\n    var lib$rsvp$node$$ERROR = new lib$rsvp$node$$Result();\n    var lib$rsvp$node$$GET_THEN_ERROR = new lib$rsvp$node$$Result();\n\n    function lib$rsvp$node$$getThen(obj) {\n      try {\n       return obj.then;\n      } catch(error) {\n        lib$rsvp$node$$ERROR.value= error;\n        return lib$rsvp$node$$ERROR;\n      }\n    }\n\n\n    function lib$rsvp$node$$tryApply(f, s, a) {\n      try {\n        f.apply(s, a);\n      } catch(error) {\n        lib$rsvp$node$$ERROR.value = error;\n        return lib$rsvp$node$$ERROR;\n      }\n    }\n\n    function lib$rsvp$node$$makeObject(_, argumentNames) {\n      var obj = {};\n      var name;\n      var i;\n      var length = _.length;\n      var args = new Array(length);\n\n      for (var x = 0; x < length; x++) {\n        args[x] = _[x];\n      }\n\n      for (i = 0; i < argumentNames.length; i++) {\n        name = argumentNames[i];\n        obj[name] = args[i + 1];\n      }\n\n      return obj;\n    }\n\n    function lib$rsvp$node$$arrayResult(_) {\n      var length = _.length;\n      var args = new Array(length - 1);\n\n      for (var i = 1; i < length; i++) {\n        args[i - 1] = _[i];\n      }\n\n      return args;\n    }\n\n    function lib$rsvp$node$$wrapThenable(then, promise) {\n      return {\n        then: function(onFulFillment, onRejection) {\n          return then.call(promise, onFulFillment, onRejection);\n        }\n      };\n    }\n\n    function lib$rsvp$node$$denodeify(nodeFunc, options) {\n      var fn = function() {\n        var self = this;\n        var l = arguments.length;\n        var args = new Array(l + 1);\n        var arg;\n        var promiseInput = false;\n\n        for (var i = 0; i < l; ++i) {\n          arg = arguments[i];\n\n          if (!promiseInput) {\n            // TODO: clean this up\n            promiseInput = lib$rsvp$node$$needsPromiseInput(arg);\n            if (promiseInput === lib$rsvp$node$$GET_THEN_ERROR) {\n              var p = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n              lib$rsvp$$internal$$reject(p, lib$rsvp$node$$GET_THEN_ERROR.value);\n              return p;\n            } else if (promiseInput && promiseInput !== true) {\n              arg = lib$rsvp$node$$wrapThenable(promiseInput, arg);\n            }\n          }\n          args[i] = arg;\n        }\n\n        var promise = new lib$rsvp$promise$$default(lib$rsvp$$internal$$noop);\n\n        args[l] = function(err, val) {\n          if (err)\n            lib$rsvp$$internal$$reject(promise, err);\n          else if (options === undefined)\n            lib$rsvp$$internal$$resolve(promise, val);\n          else if (options === true)\n            lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$arrayResult(arguments));\n          else if (lib$rsvp$utils$$isArray(options))\n            lib$rsvp$$internal$$resolve(promise, lib$rsvp$node$$makeObject(arguments, options));\n          else\n            lib$rsvp$$internal$$resolve(promise, val);\n        };\n\n        if (promiseInput) {\n          return lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self);\n        } else {\n          return lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self);\n        }\n      };\n\n      fn.__proto__ = nodeFunc;\n\n      return fn;\n    }\n\n    var lib$rsvp$node$$default = lib$rsvp$node$$denodeify;\n\n    function lib$rsvp$node$$handleValueInput(promise, args, nodeFunc, self) {\n      var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n      if (result === lib$rsvp$node$$ERROR) {\n        lib$rsvp$$internal$$reject(promise, result.value);\n      }\n      return promise;\n    }\n\n    function lib$rsvp$node$$handlePromiseInput(promise, args, nodeFunc, self){\n      return lib$rsvp$promise$$default.all(args).then(function(args){\n        var result = lib$rsvp$node$$tryApply(nodeFunc, self, args);\n        if (result === lib$rsvp$node$$ERROR) {\n          lib$rsvp$$internal$$reject(promise, result.value);\n        }\n        return promise;\n      });\n    }\n\n    function lib$rsvp$node$$needsPromiseInput(arg) {\n      if (arg && typeof arg === 'object') {\n        if (arg.constructor === lib$rsvp$promise$$default) {\n          return true;\n        } else {\n          return lib$rsvp$node$$getThen(arg);\n        }\n      } else {\n        return false;\n      }\n    }\n    var lib$rsvp$platform$$platform;\n\n    /* global self */\n    if (typeof self === 'object') {\n      lib$rsvp$platform$$platform = self;\n\n    /* global global */\n    } else if (typeof global === 'object') {\n      lib$rsvp$platform$$platform = global;\n    } else {\n      throw new Error('no global: `self` or `global` found');\n    }\n\n    var lib$rsvp$platform$$default = lib$rsvp$platform$$platform;\n    function lib$rsvp$race$$race(array, label) {\n      return lib$rsvp$promise$$default.race(array, label);\n    }\n    var lib$rsvp$race$$default = lib$rsvp$race$$race;\n    function lib$rsvp$reject$$reject(reason, label) {\n      return lib$rsvp$promise$$default.reject(reason, label);\n    }\n    var lib$rsvp$reject$$default = lib$rsvp$reject$$reject;\n    function lib$rsvp$resolve$$resolve(value, label) {\n      return lib$rsvp$promise$$default.resolve(value, label);\n    }\n    var lib$rsvp$resolve$$default = lib$rsvp$resolve$$resolve;\n    function lib$rsvp$rethrow$$rethrow(reason) {\n      setTimeout(function() {\n        throw reason;\n      });\n      throw reason;\n    }\n    var lib$rsvp$rethrow$$default = lib$rsvp$rethrow$$rethrow;\n\n    // defaults\n    lib$rsvp$config$$config.async = lib$rsvp$asap$$default;\n    lib$rsvp$config$$config.after = function(cb) {\n      setTimeout(cb, 0);\n    };\n    var lib$rsvp$$cast = lib$rsvp$resolve$$default;\n    function lib$rsvp$$async(callback, arg) {\n      lib$rsvp$config$$config.async(callback, arg);\n    }\n\n    function lib$rsvp$$on() {\n      lib$rsvp$config$$config['on'].apply(lib$rsvp$config$$config, arguments);\n    }\n\n    function lib$rsvp$$off() {\n      lib$rsvp$config$$config['off'].apply(lib$rsvp$config$$config, arguments);\n    }\n\n    // Set up instrumentation through `window.__PROMISE_INTRUMENTATION__`\n    if (typeof window !== 'undefined' && typeof window['__PROMISE_INSTRUMENTATION__'] === 'object') {\n      var lib$rsvp$$callbacks = window['__PROMISE_INSTRUMENTATION__'];\n      lib$rsvp$config$$configure('instrument', true);\n      for (var lib$rsvp$$eventName in lib$rsvp$$callbacks) {\n        if (lib$rsvp$$callbacks.hasOwnProperty(lib$rsvp$$eventName)) {\n          lib$rsvp$$on(lib$rsvp$$eventName, lib$rsvp$$callbacks[lib$rsvp$$eventName]);\n        }\n      }\n    }\n\n    var lib$rsvp$umd$$RSVP = {\n      'race': lib$rsvp$race$$default,\n      'Promise': lib$rsvp$promise$$default,\n      'allSettled': lib$rsvp$all$settled$$default,\n      'hash': lib$rsvp$hash$$default,\n      'hashSettled': lib$rsvp$hash$settled$$default,\n      'denodeify': lib$rsvp$node$$default,\n      'on': lib$rsvp$$on,\n      'off': lib$rsvp$$off,\n      'map': lib$rsvp$map$$default,\n      'filter': lib$rsvp$filter$$default,\n      'resolve': lib$rsvp$resolve$$default,\n      'reject': lib$rsvp$reject$$default,\n      'all': lib$rsvp$all$$default,\n      'rethrow': lib$rsvp$rethrow$$default,\n      'defer': lib$rsvp$defer$$default,\n      'EventTarget': lib$rsvp$events$$default,\n      'configure': lib$rsvp$config$$configure,\n      'async': lib$rsvp$$async\n    };\n\n    /* global define:true module:true window: true */\n    if (typeof define === 'function' && define['amd']) {\n      define(function() { return lib$rsvp$umd$$RSVP; });\n    } else if (typeof module !== 'undefined' && module['exports']) {\n      module['exports'] = lib$rsvp$umd$$RSVP;\n    } else if (typeof lib$rsvp$platform$$default !== 'undefined') {\n      lib$rsvp$platform$$default['RSVP'] = lib$rsvp$umd$$RSVP;\n    }\n}).call(this);\n\n"]}\n"],"sourceRoot":"/source/"} \ No newline at end of file -- GitLab