从无法访问的项目Fork
{"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};\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};\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 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\":8,\"../editor\":27,\"../tracer_manager\":60,\"./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 addAlgorithmToCategoryDOM = function addAlgorithmToCategoryDOM(category, subList, algorithm) {\n var $algorithm = $('<button class=\"indent collapse\">').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 $('.indent[data-category=\"' + category + '\"]').toggleClass('collapse');\n $(this).find('i.fa').toggleClass('fa-caret-right fa-caret-down');\n });\n\n $('#list').append($category);\n\n each(categorySubList, function (algorithm) {\n addAlgorithmToCategoryDOM(category, categorySubList, algorithm);\n });\n};\n\nmodule.exports = function () {\n each(app.getCategories(), addCategoryToDOM);\n};\n\n},{\"../app\":3,\"../server\":54,\"./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\":54}],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');\n\nmodule.exports = {\n showAlgorithm: showAlgorithm,\n addCategories: addCategories,\n showDescription: showDescription,\n addFiles: addFiles,\n showFirstAlgorithm: showFirstAlgorithm,\n showRequestedAlgorithm: showRequestedAlgorithm\n};\n\n},{\"./add_categories\":4,\"./add_files\":5,\"./show_algorithm\":19,\"./show_description\":20,\"./show_first_algorithm\":21,\"./show_requested_algorithm\":22}],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 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 setupPoweredBy = require('./setup_powered_by');\nvar setupScratchPaper = require('./setup_scratch_paper');\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 // powered by\n setupPoweredBy();\n\n // scratch paper\n setupScratchPaper();\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\":9,\"./setup_document\":10,\"./setup_files_bar\":11,\"./setup_interval\":12,\"./setup_module_container\":13,\"./setup_powered_by\":14,\"./setup_scratch_paper\":15,\"./setup_side_menu\":16,\"./setup_top_menu\":17,\"./setup_window\":18}],9:[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}],10:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\n\nmodule.exports = function () {\n $(document).on('click', 'a', function (e) {\n e.preventDefault();\n if (!window.open($(this).attr('href'), '_blank')) {\n alert('Please allow popups for this site');\n }\n });\n\n $(document).mouseup(function (e) {\n app.getTracerManager().command('mouseup', e);\n });\n};\n\n},{\"../../app\":3}],11:[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},{}],12:[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\":23}],13:[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}],14:[function(require,module,exports){\n'use strict';\n\nmodule.exports = function () {\n $('#powered-by').click(function () {\n $('#powered-by-list button').toggleClass('collapse');\n });\n};\n\n},{}],15:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\nvar Server = require('../../server');\nvar showAlgorithm = require('../show_algorithm');\n\nmodule.exports = function () {\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\":54,\"../show_algorithm\":19}],16:[function(require,module,exports){\n'use strict';\n\nvar app = require('../../app');\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\n},{\"../../app\":3}],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 var $btnDesc = $('#btn_desc');\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 }\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 // description & trace\n\n $btnDesc.click(function () {\n $('.tab_container > .tab').removeClass('active');\n $('#tab_desc').addClass('active');\n $('.tab_bar > button').removeClass('active');\n $btnDesc.addClass('active');\n });\n\n $btnTrace.click(function () {\n $('.tab_container > .tab').removeClass('active');\n $('#tab_module').addClass('active');\n $('.tab_bar > button').removeClass('active');\n $btnTrace.addClass('active');\n });\n};\n\n},{\"../../app\":3,\"../../server\":54,\"../toast\":23,\"../top_menu\":24}],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\":66,\"./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 button.category').first().click();\n $('#list button.category + .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\":54,\"./show_algorithm\":19}],23:[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},{}],24:[function(require,module,exports){\n'use strict';\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};\n\nmodule.exports = {\n enableFlowControl: enableFlowControl,\n disableFlowControl: disableFlowControl,\n resetTopMenuButtons: resetTopMenuButtons\n};\n\n},{}],25:[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},{}],26:[function(require,module,exports){\n'use strict';\n\nvar execute = function execute(tracerManager, code) {\n // all modules available to eval are obtained from window\n try {\n tracerManager.deallocateAll();\n eval(code);\n tracerManager.visualize();\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 return execute(tracerManager, algoData + ';' + algoCode);\n};\n\nmodule.exports = {\n executeData: executeData,\n executeDataAndCode: executeDataAndCode\n};\n\n},{}],27:[function(require,module,exports){\n'use strict';\n\nvar app = require('../app');\nvar createEditor = require('./create');\nvar Executor = require('./executor');\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\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 // 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 });\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 });\n};\n\nmodule.exports = Editor;\n\n},{\"../app\":3,\"./create\":25,\"./executor\":26}],28:[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\n},{\"./app\":3,\"./app/constructor\":2,\"./dom\":6,\"./module\":37,\"./server\":54,\"./server/helpers\":53,\"./utils\":66,\"rsvp\":68}],29:[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\":30}],30:[function(require,module,exports){\n\"use strict\";\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((Math.random() * (max - min + 1) | 0) + min);\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},{}],31:[function(require,module,exports){\n\"use strict\";\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] = (Math.random() * (max - min + 1) | 0) + min;\n }\n }return C;\n};\n\nmodule.exports = {\n random: random\n};\n\n},{}],32:[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},{}],33:[function(require,module,exports){\n'use strict';\n\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 Array1D: Array1D,\n Array2D: Array2D,\n CoordinateSystem: CoordinateSystem,\n DirectedGraph: DirectedGraph,\n UndirectedGraph: UndirectedGraph,\n WeightedDirectedGraph: WeightedDirectedGraph,\n WeightedUndirectedGraph: WeightedUndirectedGraph\n};\n\n},{\"./array1d\":29,\"./array2d\":30,\"./coordinate_system\":31,\"./directed_graph\":32,\"./undirected_graph\":34,\"./weighted_directed_graph\":35,\"./weighted_undirected_graph\":36}],34:[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},{}],35:[function(require,module,exports){\n\"use strict\";\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] = (Math.random() * (max - min + 1) | 0) + min;\n }\n }\n }\n return G;\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, 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] = (Math.random() * (max - min + 1) | 0) + min;\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 tracers = require('./tracer');\nvar datas = require('./data');\n\nvar _$ = $;\nvar extend = _$.extend;\n\n\nmodule.exports = extend(true, {}, tracers, datas);\n\n},{\"./data\":33,\"./tracer\":43}],38:[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: '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\":39}],39:[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\":63,\"./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 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: 'rgba(255, 0, 0, 1)',\n notified: 'rgba(0, 0, 255, 1)',\n default: 'rgba(136, 136, 136, 1)'\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)) return true;\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 'deselect':\n case 'select':\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\":45}],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 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\":42}],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 _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 }\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\":63,\"./tracer\":45}],43:[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\":38,\"./array2d\":39,\"./chart\":40,\"./coordinate_system\":41,\"./directed_graph\":42,\"./log\":44,\"./tracer\":45,\"./undirected_graph\":46,\"./weighted_directed_graph\":47,\"./weighted_undirected_graph\":48}],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 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\":45}],45:[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() {\n this.manager.newStep();\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 if (tracer.module === LogTracer) {\n this.logTracer = tracer;\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\":63}],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 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\":42}],47:[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\":63,\"./directed_graph\":42}],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 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\":46,\"./weighted_directed_graph\":47}],49:[function(require,module,exports){\n'use strict';\n\nvar request = require('./request');\n\nmodule.exports = function (url) {\n\n return request(url, {\n type: 'GET'\n });\n};\n\n},{\"./request\":52}],50:[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\":52}],51:[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\":52}],52:[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\":68}],53:[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\":23}],54:[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');\n\nmodule.exports = {\n loadAlgorithm: loadAlgorithm,\n loadCategories: loadCategories,\n loadFile: loadFile,\n loadScratchPaper: loadScratchPaper,\n shareScratchPaper: shareScratchPaper\n};\n\n},{\"./load_algorithm\":55,\"./load_categories\":56,\"./load_file\":57,\"./load_scratch_paper\":58,\"./share_scratch_paper\":59}],55:[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\":66,\"./ajax/get_json\":50}],56:[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\":50}],57:[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\":66,\"./ajax/get\":49,\"./helpers\":53,\"rsvp\":68}],58:[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\":66,\"./ajax/get_json\":50,\"./load_algorithm\":55,\"rsvp\":68}],59:[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\":51,\"./helpers\":53,\"rsvp\":68}],60:[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\":45,\"./manager\":61}],61:[function(require,module,exports){\n'use strict';\n\nvar TopMenu = require('../dom/top_menu');\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 = $('<section class=\"module_wrapper\">');\n $('.module_container').append($container);\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 $('#interval').val(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 var last = [];\n if (len === 0) {\n this.traces.push(last);\n } else {\n last = this.traces[len - 1];\n }\n last.push($.extend(step, {\n capsule: capsule\n }));\n },\n newStep: function newStep() {\n 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 $('#btn_pause').addClass('active');\n },\n resumeStep: function resumeStep() {\n this.pause = false;\n this.step(this.traceIndex + 1);\n $('#btn_pause').removeClass('active');\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 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},{\"../dom/top_menu\":24}],62:[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},{}],63:[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\":62,\"./refine_by_type\":64,\"./to_json\":65}],64:[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},{}],65:[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},{}],66:[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},{}],67:[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},{}],68:[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\":67}]},{},[28])\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/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_powered_by.js","js/dom/setup/setup_scratch_paper.js","js/dom/setup/setup_side_menu.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/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/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/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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AAiB;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};\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};\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  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 addAlgorithmToCategoryDOM = (category, subList, algorithm) => {\n  const $algorithm = $('<button class=\"indent collapse\">')\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    $(`.indent[data-category=\"${category}\"]`).toggleClass('collapse');\n    $(this).find('i.fa').toggleClass('fa-caret-right fa-caret-down');\n  });\n\n  $('#list').append($category);\n\n  each(categorySubList, (algorithm) => {\n    addAlgorithmToCategoryDOM(category, categorySubList, algorithm);\n  });\n};\n\nmodule.exports = () => {\n  each(app.getCategories(), addCategoryToDOM);\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');\n\nmodule.exports = {\n  showAlgorithm,\n  addCategories,\n  showDescription,\n  addFiles,\n  showFirstAlgorithm,\n  showRequestedAlgorithm\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","const 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 setupPoweredBy = require('./setup_powered_by');\nconst setupScratchPaper = require('./setup_scratch_paper');\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  // powered by\n  setupPoweredBy();\n\n  // scratch paper\n  setupScratchPaper();\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};","const 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}","const app = require('../../app');\n\nmodule.exports = () => {\n  $(document).on('click', 'a', function (e) {\n    e.preventDefault();\n    if (!window.open($(this).attr('href'), '_blank')) {\n      alert('Please allow popups for this site');\n    }\n  });\n\n  $(document).mouseup(function (e) {\n    app.getTracerManager().command('mouseup', e);\n  });\n};","const 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}","const 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};","const 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}","module.exports = () => {\n  $('#powered-by').click(function() {\n    $('#powered-by-list button').toggleClass('collapse');\n  });\n};","const app = require('../../app');\nconst Server = require('../../server');\nconst showAlgorithm = require('../show_algorithm');\n\nmodule.exports = () => {\n  $('#scratch-paper').click(function() {\n    const category = 'scratch';\n    const algorithm = app.getLoadedScratch();\n    Server.loadAlgorithm(category, algorithm).then((data) => {\n      showAlgorithm(category, algorithm, data);\n    });\n  });\n};","const app = require('../../app');\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}","const 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  const $btnDesc  = $('#btn_desc');\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    }\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  // description & trace\n\n  $btnDesc.click(() => {\n    $('.tab_container > .tab').removeClass('active');\n    $('#tab_desc').addClass('active');\n    $('.tab_bar > button').removeClass('active');\n    $btnDesc.addClass('active');\n  });\n\n  $btnTrace.click(() => {\n    $('.tab_container > .tab').removeClass('active');\n    $('#tab_module').addClass('active');\n    $('.tab_bar > button').removeClass('active');\n    $btnTrace.addClass('active');\n  });\n\n};\n","const app = require('../../app');\n\nmodule.exports = function() {\n  $(window).resize(function() {\n    app.getTracerManager().resize();\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 button.category').first().click();\n  $('#list button.category + .indent').first().click();\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 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 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};\n\nmodule.exports = {\n  enableFlowControl,\n  disableFlowControl,\n  resetTopMenuButtons\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) => {\n  // all modules available to eval are obtained from window\n  try {\n    tracerManager.deallocateAll();\n    eval(code);\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  return execute(tracerManager, `${algoData};${algoCode}`);\n};\n\nmodule.exports = {\n  executeData,\n  executeDataAndCode\n};","'use strict';\n\nconst app = require('../app');\nconst createEditor = require('./create');\nconst Executor = require('./executor');\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\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  // 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  });\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  });\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});","const 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","const 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((Math.random() * (max - min + 1) | 0) + min);\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};","const 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] = (Math.random() * (max - min + 1) | 0) + min;\n  return C;\n};\n\nmodule.exports = {\n  random\n};","const 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};","'use strict';\n\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  Array1D,\n  Array2D,\n  CoordinateSystem,\n  DirectedGraph,\n  UndirectedGraph,\n  WeightedDirectedGraph,\n  WeightedUndirectedGraph\n};","const 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};","const 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] = (Math.random() * (max - min + 1) | 0) + min;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};","const 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] = (Math.random() * (max - min + 1) | 0) + min;\n      }\n    }\n  }\n  return G;\n};\n\nmodule.exports = {\n  random\n};","'use strict';\n\nvar tracers = require('./tracer');\nvar datas = require('./data');\n\nconst {\n  extend\n} = $;\n\nmodule.exports = extend(true, {}, tracers, datas);","const 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  setData(D) {\n    return super.setData([D]);\n  }\n}\n\nmodule.exports = Array1DTracer;","const 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;","const 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: 'rgba(255, 0, 0, 1)',\n      notified: 'rgba(0, 0, 255, 1)',\n      default: 'rgba(136, 136, 136, 1)'\n    };\n\n    if (this.isNew) initView(this);\n  }\n\n  setData(C) {\n    if (super.setData.apply(this, arguments)) return true;\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 'deselect':\n      case 'select':\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;","const 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;","const 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  }\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;","'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};","const 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;","const 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() {\n    this.manager.newStep();\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    if (tracer.module === LogTracer) {\n      this.logTracer = tracer;\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;","const 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;","const 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;","const 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;","'use strict';\n\nconst request = require('./request');\n\nmodule.exports = (url) => {\n\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');\n\nmodule.exports = {\n  loadAlgorithm,\n  loadCategories,\n  loadFile,\n  loadScratchPaper,\n  shareScratchPaper\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 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 TopMenu = require('../dom/top_menu');\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 = $('<section class=\"module_wrapper\">');\n    $('.module_container').append($container);\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    $('#interval').val(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    let last = [];\n    if (len === 0) {\n      this.traces.push(last);\n    } else {\n      last = this.traces[len - 1];\n    }\n    last.push($.extend(step, {\n      capsule\n    }));\n  },\n\n  newStep() {\n    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    $('#btn_pause').addClass('active');\n  },\n\n  resumeStep() {\n    this.pause = false;\n    this.step(this.traceIndex + 1);\n    $('#btn_pause').removeClass('active');\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      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","const {\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;","const 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};","const 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","const {\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;","'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/"}