diff --git a/GitMerge-Roboto b/GitMerge-Roboto new file mode 100644 index 0000000..792db96 --- /dev/null +++ b/GitMerge-Roboto @@ -0,0 +1,34 @@ +# This Strategy helps you merge 2 branches in githup and resolve conflicts +STRATEGY GitMerge() + # Open the teminal, and use cd(change directory) command to move to the local git project directory + Run the terminal and navigate to your git project directory + IF you are not in Master branch + # Run the command git checkout master + checkout to master branch + IF you are in master branch + # To merge the second branch with master branch run the command "git merge secondBranch", which secondBranch is the name of your git second branch + Merge two branches + IF the merge has confilict + SET confilictedFile TO the files in project that have confilict + FOR EACH 'file' IN 'confilictedFile' + DO fixConfilict('file') + # Run GIT STATUS to see the latest changes + # Run GIT ADD + # Run GIT PUSH + Commit and push the changes + # If you made it to this line, then you must have missed something. Is it possible you made a mistake above? If so, go back and verify your work, because something caused the faulty output. + RETURN nothing + +STRATEGY fixConfilict(conflictedFile) + Open the conflictedFile with your favorite text editor + # To find a line with conflict in your file, search the file for the conflict marker <<<<<<< HEAD + SET 'line' TO a line number that has conflict + # until there is no line with <<<<<<< HEAD tag in the file + UNTIL the file has no lines of conflict + # You'll see the changes from the master branch after the line <<<<<<< HEAD + # Next youll see ======= which divides 2 merged lines followed by >>>>>>> SECOND branch name + # Decide if you want to keep only your branch's changes, keep only the other branch's changes, or make a brand new change, and edit the file by removing unwanted lines + # Also remove >>>>>>Head & ====== from the lines and make sure that the file has proper code syntax. + Edit the line + SET 'line' TO a line number that has conflict + Return nothing diff --git a/StrategyTracker/js/bundle.js b/StrategyTracker/js/bundle.js index 0d8d1e4..793a586 100755 --- a/StrategyTracker/js/bundle.js +++ b/StrategyTracker/js/bundle.js @@ -243,9 +243,9 @@ if (typeof window !== 'undefined' && window.angular) { if (scope.fadeIn !== undefined) { scope.$watch('fadeIn', function (value) { if (value) { - $(element).fadeIn(500); + $(element).fadeIn(1500); } else { - $(element).fadeOut(100); + $(element).fadeOut(1000); } }); } @@ -2841,4 +2841,4 @@ exports.write = function (buffer, value, offset, isLE, mLen, nBytes) { } },{}]},{},[1]) -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../node_modules/browser-pack/_prelude.js","index.js","models.js","../node_modules/base64-js/index.js","../node_modules/buffer/index.js","../node_modules/clone/clone.js","../node_modules/ieee754/index.js"],"names":[],"mappings":"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CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AClrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC3PA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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})","const models = require('./models.js');\r\n// require('./dataManagement.js');\r\n\r\nvar config = {\r\n    apiKey: \"AIzaSyAXjL6f739BVqLDknymCN2H36-NBDS8LvY\",\r\n    authDomain: \"strategytracker.firebaseapp.com\",\r\n    databaseURL: \"https://strategytracker.firebaseio.com\",\r\n    projectId: \"strategytracker\",\r\n    storageBucket: \"strategytracker.appspot.com\",\r\n    messagingSenderId: \"261249836518\"\r\n};\r\nfirebase.initializeApp(config);\r\n\r\nif (typeof window !== 'undefined' && window.angular) {\r\n    let myapp = angular.module('myapp', ['ngSanitize']);\r\n\r\n    myapp.run(function ($rootScope) {\r\n        ['isArray', 'isDate', 'isDefined', 'isFunction', 'isNumber', 'isObject', 'isString', 'isUndefined'].forEach(function (name) {\r\n            $rootScope[name] = angular[name];\r\n        });\r\n    });\r\n\r\n    myapp.factory('StrategyService', function ($q) {\r\n        let strategies = [];\r\n        let deferred = $q.defer();\r\n        firebase.database().ref('strategies').once('value').then(function (snapshot) {\r\n            snapshot.forEach(function (childStrategy) {\r\n                strategies.push(childStrategy.val());\r\n            });\r\n            deferred.resolve(strategies);\r\n        }).catch(function (err) {\r\n            deferred.reject(err);\r\n        });\r\n\r\n        return {\r\n            getAll: function () {\r\n                return deferred.promise;\r\n            },\r\n        };\r\n    });\r\n\r\n    myapp.controller('MainCtrl', function ($scope, StrategyService, $window, $timeout) {\r\n        \"use strict\";\r\n        let vm = this;\r\n        let myStrat = StrategyService.getAll();\r\n        //Asynchronous : If the records are ready from deffered.promise, then the following steps is run.\r\n        myStrat.then(function (allStrategies) {\r\n            vm.allStrategies = allStrategies;\r\n            let interpreter = null;\r\n            // get the strategy from URL\r\n            let keyval = $window.location.search.replace('?', '').split('=');\r\n            if(keyval[0] == 'strategy') {\r\n                vm.selectedStrategy = allStrategies.filter(function (value) {\r\n                    return value.name == keyval[1];\r\n                })[0];\r\n                interpreter = new models.Interpreter(vm.selectedStrategy.strategies);\r\n                vm.execObj = interpreter.init(vm.selectedStrategy.strategies[0]);\r\n                vm.currentStrategy = vm.execObj.currentStrategy;\r\n                vm.parameters = vm.execObj.variables.filter(function (val) {\r\n                    return val.type == 'parameter';\r\n                });\r\n                // open the modal to input strategy parameters\r\n                $(\"#initialParams\").modal({\r\n                    backdrop: \"static\",\r\n                    keyboard: \"false\",\r\n                });\r\n                vm.myStrategy = vm.selectedStrategy;\r\n            }\r\n            vm.strategyChanged = function () {\r\n                $window.location = $window.location.origin + $window.location.pathname + '?strategy=' + vm.myStrategy.name;\r\n            };\r\n\r\n            vm.proceedToStrategy = function () {\r\n                let flag = true;\r\n                angular.forEach(vm.parameters, function (val, key) {\r\n                    if(val.val == null || val.val.trim() == '') {\r\n                        flag = false;\r\n                    }\r\n                });\r\n\r\n                if(flag == true) {\r\n                    angular.forEach(vm.parameters, function (val, key) {\r\n                        val.visible=true;\r\n                    });\r\n                    $(\"#initialParams\").modal('hide');\r\n                }\r\n            };\r\n\r\n            vm.reset = function () {\r\n                if (vm.selectedStrategy) {\r\n                    interpreter.reset();\r\n                    vm.execObj = interpreter.init(vm.selectedStrategy.strategies[0]);\r\n                    vm.currentStrategy = vm.execObj.currentStrategy;\r\n                    $('#' + vm.currentStrategy.name).collapse('show');\r\n                    vm.selectedStrategy.strategies.forEach(function (strat) {\r\n                        if(vm.currentStrategy.name !== strat.name) $('#' + strat.name).collapse('hide');\r\n                    });\r\n                    // open the modal to input strategy parameters\r\n                    vm.parameters = vm.execObj.variables.filter(function (val) {\r\n                        return val.type == 'parameter';\r\n                    });\r\n                    // open the modal to input strategy parameters\r\n                    $(\"#initialParams\").modal({\r\n                        backdrop: \"static\",\r\n                        keyboard: \"false\",\r\n                    });\r\n                } else {\r\n                    alert(\"please choose a strategy first\");\r\n                }\r\n\r\n            };\r\n            function checkType() {\r\n                if (vm.execObj.currentStatement.type == 'set') {\r\n                    let id = vm.execObj.currentStatement.identifier.replace(/'/g, '');\r\n                    let variable = vm.execObj.variables.find(function (val, index, arr) {\r\n                        return val.name == id;\r\n                    });\r\n                    if (variable.val == null || variable.val.length == 0) {\r\n                        variable.visible = true;\r\n                        vm.execObj.setNeeded = true;\r\n                        $scope.$broadcast(\"EditMe\", id);\r\n                    } else {\r\n                        vm.execObj.setNeeded = false;\r\n                    }\r\n                }\r\n                if (vm.execObj.currentStatement.type == 'foreach' || vm.execObj.currentStatement.type == 'loop') {\r\n                    let list = vm.execObj.variables.find(function (val) {\r\n                        return val.name === vm.execObj.currentStatement.list.replace(/'/g, '');\r\n                    });\r\n\r\n                    let identifier = vm.execObj.variables.find(function (val) {\r\n                        return val.name === vm.execObj.currentStatement.identifier.replace(/'/g, '');\r\n                    });\r\n                    identifier.visible = true;\r\n                    identifier.val = list.val[vm.execObj.currentStatement.counter ? vm.execObj.currentStatement.counter : 0];\r\n                    list.dirtyArray.push(list.val[vm.execObj.currentStatement.counter ? vm.execObj.currentStatement.counter : 0]);\r\n                    //$scope.$apply();\r\n\r\n                }\r\n            }\r\n\r\n            vm.nextStatement = function () {\r\n                vm.execObj = interpreter.execute();\r\n                // vm.execObj.variables.forEach(function (variable) {\r\n                //     console.log(\"Variables:   \" + variable.name);\r\n                // });\r\n                if (vm.execObj == null) {\r\n                    $timeout(function() {\r\n                        alert(\"Congratulation!You have reached end of strategy! If you think you did not finish the task, reset the strategy and start over again. \");\r\n                    }, 100);\r\n                    return;\r\n                }\r\n                checkType();\r\n                if(vm.execObj.strategyChanged) {\r\n                    $timeout(function () {\r\n                        angular.forEach(vm.execObj.variables, function (val, key) {\r\n                            if(val.type == 'parameter') {\r\n                                val.visible = true;\r\n                            }\r\n                        });\r\n                    }, 100);\r\n                }\r\n                if (vm.currentStrategy.name !== vm.execObj.currentStrategy.name) {\r\n                    $('#' + vm.execObj.currentStrategy.name).collapse('show');\r\n                    $('#' + vm.currentStrategy.name).collapse('hide');\r\n                    if (vm.execObj.variables !== null){\r\n                        vm.parameters = vm.execObj.variables.filter(function (val) {\r\n                            return val.type == 'parameter';\r\n                        });\r\n                    }\r\n\r\n                    vm.currentStrategy = vm.execObj.currentStrategy;\r\n                }\r\n            };\r\n\r\n            vm.prevStatement = function () {\r\n                vm.execObj = interpreter.goBack();\r\n                if (vm.execObj === null) return;\r\n                if(vm.execObj.currentStatement.type === 'set') {\r\n                    let id = vm.execObj.currentStatement.identifier.replace(/'/g, '');\r\n                    let variable = vm.execObj.variables.find(function (val, index, arr) {\r\n                        return val.name == id;\r\n                    });\r\n                    console.log(variable);\r\n                    if(variable.dirtyArray !== undefined) variable.dirtyArray = [];\r\n                }\r\n                checkType();\r\n                if (vm.currentStrategy.name !== vm.execObj.currentStrategy.name) {\r\n                    $('#' + vm.execObj.currentStrategy.name).collapse('show');\r\n                    $('#' + vm.currentStrategy.name).collapse('hide');\r\n                    vm.currentStrategy = vm.execObj.currentStrategy;\r\n                }\r\n            };\r\n\r\n            vm.outerStatement = function () {\r\n                vm.execObj = interpreter.execute(false);\r\n\r\n                checkType();\r\n\r\n            };\r\n            vm.innerStatement = function () {\r\n                vm.execObj = interpreter.execute(true);\r\n                checkType();\r\n            };\r\n\r\n            $scope.$on(\"setNeededFalse\", function (args) {\r\n                if(!args.targetScope.model) {\r\n                    vm.execObj.setNeeded = true;\r\n                } else {\r\n                    vm.execObj.setNeeded = false;\r\n                }\r\n            });\r\n\r\n            $scope.$on(\"blockAdd\", function (args, data) {\r\n                interpreter.addLoopBlocks(data.id, data.data);\r\n\r\n            })\r\n        });\r\n    });\r\n\r\n    myapp.directive('variableValue', function ($parse, $timeout) {\r\n        return {\r\n            template:\r\n            '<span ng-show=\"edit\">' +\r\n            '<textarea ng-show=\"isArray \" ng-blur=\"updateModel()\" ng-model=\"var\"></textarea>' +\r\n            '<input type=\"text\" ng-show=\"!isArray \" ng-blur=\"updateModel()\" ng-model=\"model\">' +\r\n            '</span>' +\r\n            '<div class=\"var-outer-border\" ng-show=\"!edit\" ng-attr-id=\"{{modelId}}\">' +\r\n            '<span class=\"showvars\" ng-show=\"isArray && allvar.length \" ng-class=\"dirtyArray.indexOf(myvar) >= 0 ? \\'dirty\\' : \\'\\'\" ng-repeat=\"myvar in allvar track by $index\">{{myvar}}</span>' +\r\n            '<span class=\"showvars\" ng-show=\"isArray && !allvar.length \" ng-click=\"changeEdit()\">nothing</span>' +\r\n            '<span class=\"showvars\" ng-show=\"!isArray && model.length \"  ng-click=\"changeEdit()\">{{model}}</span>' +\r\n            '<span class=\"showvars\" ng-show=\"!isArray && !model.length \" ng-click=\"changeEdit()\">nothing</span>' +\r\n            '<button style=\"margin-left:5px;\" ng-show=\"isArray && allvar.length \" title=\" Add more items\" href=\"#\" ng-click=\"changeEdit()\"><i class=\"glyphicon glyphicon-plus\"></i></button>' +\r\n            '</div>',\r\n            restrict: 'E',\r\n            scope: {\r\n                model: '=',\r\n                isArray: '=',\r\n                modelId: '=',\r\n                parentId: '=',\r\n                dirtyArray: '=',\r\n                prevVar: '=',\r\n                fadeIn: '='\r\n            },\r\n            link: function (scope, element, attrs, controller) {\r\n                scope.edit = false;\r\n                scope.var = '';\r\n                scope.id = null;\r\n                var listener = null;\r\n                scope.$on('EditMe', function (event, data) {\r\n                    if (scope.modelId == data) {\r\n                        scope.id = data;\r\n                        scope.changeEdit();\r\n                    }\r\n                });\r\n                if(scope.fadeIn !== undefined) {\r\n                    scope.$watch('fadeIn', function(value) {\r\n                        if(value) {\r\n                            $(element).fadeIn(500)\r\n                        } else {\r\n                            $(element).fadeOut(100);\r\n                        }\r\n                    });\r\n                }\r\n\r\n                if (scope.isArray) {\r\n                    scope.allvar = scope.model;\r\n                }\r\n\r\n\r\n                scope.changeEdit = function () {\r\n\r\n                    listener = scope.$watch('model', function (newval, oldval) {\r\n                        scope.$emit(\"setNeededFalse\");\r\n                    });\r\n                    scope.edit = !scope.edit;\r\n                    if (scope.isArray) {\r\n                        scope.var = scope.allvar.join(',');\r\n                        $timeout(function () {\r\n                            element[0].firstChild.firstChild.focus();\r\n                        }, 10);\r\n                    }\r\n                    else {\r\n                        $timeout(function () {\r\n                            element[0].firstChild.lastChild.focus();\r\n                        }, 10);\r\n                    }\r\n                };\r\n                scope.updateModel = function () {\r\n                    listener();\r\n                    scope.edit = !scope.edit;\r\n                    if (scope.isArray) {\r\n                        let arr = new Set(scope.var.split(','));\r\n\r\n                        scope.allvar = [];\r\n                        angular.forEach(arr, function (val, key) {\r\n                            val.trim().length ? scope.allvar.push(val.trim()) : null;\r\n                        });\r\n\r\n                        if(scope.dirtyArray.length > 0) {\r\n                            for(let i = 0; i< scope.dirtyArray.length; i++)\r\n                            {\r\n                                if(scope.dirtyArray[i] !== scope.allvar[i]){\r\n                                    scope.allvar = scope.prevVar;\r\n                                    alert(\" You are currently executing a loop. Adding elements are just allowed to the end of collection.  \");\r\n                                    return;\r\n                                }\r\n                            }\r\n                        }\r\n\r\n                        $parse(attrs.model).assign(scope.$parent, scope.allvar);\r\n                        if(scope.prevVar.length !== 0 && scope.prevVar.length < scope.allvar.length) {\r\n                            scope.$emit(\"blockAdd\", {\"data\": scope.allvar.slice(scope.prevVar.length, scope.allvar.length), \"id\": scope.parentId});\r\n                        }\r\n                        //console.log(scope.allvar.length);\r\n\r\n                        scope.prevVar = scope.allvar;\r\n                    }\r\n                    if (scope.id) {\r\n                        scope.$emit(\"setNeededFalse\");\r\n                    }\r\n                };\r\n\r\n            }\r\n        }\r\n    });\r\n\r\n}","'use strict';\r\n\r\nvar clone = require('clone');\r\n\r\n// https://stackoverflow.com/questions/586182/how-to-insert-an-item-into-an-array-at-a-specific-index\r\nArray.prototype.insert = function (index) {\r\n    index = Math.min(index, this.length);\r\n    arguments.length > 1\r\n    && this.splice.apply(this, [index, 0].concat([].pop.call(arguments)))\r\n    && this.insert.apply(this, arguments);\r\n    return this;\r\n};\r\n\r\nclass Interpreter {\r\n\r\n    constructor(strategies) {\r\n        this.executionStack = [];\r\n        this.historyBackward = [];\r\n        this.strategies = strategies;\r\n    }\r\n\r\n    init(currentStrategy) {\r\n        let currentExecutionContext = new FunctionExecContext(currentStrategy);\r\n        this.executionStack.push(currentExecutionContext);\r\n\r\n        return {\r\n            currentStatement: currentExecutionContext.pc,\r\n            currentStrategy: currentExecutionContext.strategy,\r\n            executionStack: this.executionStack,\r\n            activeLines: currentExecutionContext.activeLines,\r\n            //selectionNeeded: currentExecutionContext.pc.type === \"if\",\r\n            //setNeeded: currentExecutionContext.pc.type === 'set',\r\n            variables: currentExecutionContext.variables,\r\n        }\r\n    }\r\n\r\n    reset() {\r\n        this.executionStack = [];\r\n        this.historyBackward = [];\r\n    }\r\n\r\n    findStrategy(strategyname) {\r\n        return this.strategies.find(function (strategy) {\r\n            return strategy.name === strategyname;\r\n        })\r\n    }\r\n\r\n    addLoopBlocks(id, arr) {\r\n        let currentExecutionContext = this.executionStack[this.executionStack.length - 1];\r\n        if (currentExecutionContext.pc && currentExecutionContext.pc.type === 'foreach') return;// if foreach is still in the blocks, then it should work correctly\r\n        let loopStatement = this.findStatementById(id);\r\n        if (loopStatement !== null) {\r\n            let tempBlock = [];\r\n            let listVariable = loopStatement.list.replace(/'/g, '');\r\n            let counter = 0;\r\n            currentExecutionContext.variables.forEach(function (val, index, arr) {\r\n                if (val.name === listVariable) {\r\n                    counter = val.val.length - 1;\r\n                }\r\n            });\r\n            for (let num = 0; num < arr.length; num++) {\r\n                for (let i = loopStatement.statements.length - 1; i >= 0; i--) {\r\n                    tempBlock.unshift(clone(loopStatement.statements[i]));\r\n                }\r\n                // put the foreach statement length minus 1 times\r\n                if (num <= arr.length - 1) {\r\n                    let tempStatement = clone(loopStatement);\r\n                    tempStatement.type = \"loop\";\r\n                    tempStatement.counter = counter--;\r\n                    tempBlock.unshift(clone(tempStatement));\r\n                }\r\n            }\r\n            let allLoopStatements = currentExecutionContext.blocks.filter(function (val) {\r\n                return val.id.includes(id);\r\n            });\r\n            let objId = allLoopStatements.length ? allLoopStatements.pop().id : id;\r\n            // reverse to find the last index of statement\r\n            let index = currentExecutionContext.blocks.slice().reverse().findIndex(function (value, index, array) {\r\n                return value.id === objId;\r\n            });\r\n            index = index >= 0 ? currentExecutionContext.blocks.length - index : 0;\r\n            currentExecutionContext.blocks.insert(index, tempBlock);\r\n        }\r\n    }\r\n\r\n    findStatementById(id) {\r\n        let currentExecutionContext = this.executionStack[this.executionStack.length - 1];\r\n        // locate the statement by parsing the id string and find the index of the statement\r\n        let splitedIndex = id.split('-').splice(1);\r\n        if (splitedIndex.length > 0) {\r\n            let expression = \"currentExecutionContext.strategy\"; // first generate string for locating the statement by the indexes\r\n            splitedIndex.forEach(function (value, index, array) {\r\n                expression += \".statements[\" + value + \"]\"; // gradually append statements string with its index\r\n            });\r\n            // example => currentExecutionContext.strategy.statements[1].statements[2] and so on\r\n            // evaluate the string to return the object\r\n            return eval(expression); // eval is a javascript command to execute a string\r\n        }\r\n        // if it could not find the statement, return null\r\n        return null;\r\n    }\r\n\r\n    execute(branchTaken) {\r\n        if (this.executionStack[this.executionStack.length - 1] &&\r\n            this.executionStack[this.executionStack.length - 1].pc.type === 'end') return null;\r\n        if (this.executionStack.length) {\r\n            this.historyBackward.push(clone(this.executionStack)); // take a snapshot from our current executionStack to our history\r\n        } else {\r\n            return null;\r\n        }\r\n        let currentExecutionContext = this.executionStack.pop();\r\n        let nextType = currentExecutionContext.getNextStatement(currentExecutionContext.pc, branchTaken);\r\n        if (nextType === 'nothing' || nextType === 'return') return this.execute(branchTaken);\r\n        else if (nextType === null) return null;\r\n        else if (nextType === 'new') {\r\n            this.executionStack.push(currentExecutionContext);\r\n            let myArgs = null;\r\n            if (currentExecutionContext.pc.type === 'do') {\r\n                myArgs = currentExecutionContext.pc.call.arguments.map(function (val) {\r\n                    return val.replace(/'/g, '');\r\n                });\r\n            } else {\r\n                myArgs = currentExecutionContext.pc.query.arguments.map(function (val) {\r\n                    return val.replace(/'/g, '');\r\n                });\r\n            }\r\n            let args = [];\r\n            myArgs.forEach(function (value, index, array) {\r\n                //console.log(value);\r\n                let myvar = currentExecutionContext.variables.find(function (val) {\r\n                    //console.log(val);\r\n                    return val.name === value;\r\n                });\r\n                args.push(myvar);\r\n            });\r\n            console.log(\"ARGS\", args);\r\n\r\n            let strategy = this.findStrategy(currentExecutionContext.pc.type === 'do' ? currentExecutionContext.pc.call.name : currentExecutionContext.pc.query.name);\r\n            currentExecutionContext = new FunctionExecContext(strategy);\r\n            currentExecutionContext.variables.forEach(function (value, index, array) {\r\n                if (value.type === 'parameter') {\r\n                    value.val = args[index].val;\r\n                    //value.visible = true;\r\n                }\r\n            });\r\n        } else {\r\n            currentExecutionContext = nextType;\r\n        }\r\n\r\n        this.executionStack.push(currentExecutionContext);\r\n        return {\r\n            currentStatement: currentExecutionContext.pc,\r\n            currentStrategy: currentExecutionContext.strategy,\r\n            executionStack: this.executionStack,\r\n            activeLines: currentExecutionContext.activeLines,\r\n            selectionNeeded: (currentExecutionContext.pc.type === \"if\" || currentExecutionContext.pc.type === \"until\"),\r\n            setNeeded: currentExecutionContext.pc.type === 'set',\r\n            variables: currentExecutionContext.variables,\r\n            strategyChanged: nextType == 'new'\r\n        };\r\n\r\n    }\r\n\r\n    goBack() {\r\n        let stack = this.historyBackward.pop();\r\n        if (stack === undefined) return null;\r\n        this.executionStack = stack;\r\n        let currentExecutionContext = this.executionStack[this.executionStack.length - 1];\r\n        return {\r\n            currentStatement: currentExecutionContext.pc,\r\n            currentStrategy: currentExecutionContext.strategy,\r\n            executionStack: this.executionStack,\r\n            activeLines: currentExecutionContext.activeLines,\r\n            selectionNeeded: (currentExecutionContext.pc.type === \"if\" || currentExecutionContext.pc.type === \"until\"),\r\n            setNeeded: currentExecutionContext.pc.type === 'set',\r\n            variables: currentExecutionContext.variables,\r\n        };\r\n    }\r\n}\r\n\r\nvar globalCounter = {count: 0};\r\n\r\nclass FunctionExecContext {\r\n    constructor(currentStrategy) {\r\n        this.strategy = currentStrategy;\r\n        this.pc = this.strategy;\r\n        this.activeLines = [];\r\n        this.activeLines.push(this.strategy.id);\r\n        this.blocks = [];\r\n        this.blocks = clone(this.strategy.statements);\r\n        this.variables = [];\r\n        if (this.strategy.parameters !== undefined) {\r\n            this.strategy.parameters.forEach(function (currentVal, index, arr) {\r\n                currentVal = currentVal.replace(/'/g, '');\r\n                this.variables.push({\r\n                    \"id\": globalCounter.count++,\r\n                    \"name\": currentVal,\r\n                    \"val\": null,\r\n                    \"type\": \"parameter\",\r\n                    \"visible\": false,\r\n                });\r\n            }, this);\r\n        }\r\n        this.extractVariables(this.strategy.statements, globalCounter, this);\r\n        var uniq = [...new Set(this.variables)];\r\n        uniq.forEach(function (variable) {\r\n            console.log(\"var:   \" + variable.name);\r\n        });\r\n        this.callStack = [];\r\n    }\r\n\r\n\r\n    extractVariables(statements, counter, argThis) {\r\n        statements.forEach(function (currentVal, index, arr) {\r\n            if (currentVal.identifier) {\r\n                let identifier = currentVal.identifier.replace(/'/g, '');\r\n                var found = argThis.variables.some(function (el) {\r\n                    return el.name === identifier;\r\n                });\r\n                if (!found) {\r\n                    argThis.variables.push({\r\n                        \"id\": counter.count++,\r\n                        \"name\": identifier,\r\n                        \"val\": null,\r\n                        \"type\": \"identifier\",\r\n                        \"visible\": false,\r\n                    });\r\n                }\r\n            }\r\n            if (currentVal.type === 'do') {\r\n                if (currentVal.call.arguments) {\r\n                    currentVal.call.arguments.forEach(function (val, ind, array) {\r\n                        val = val.replace(/'/g, '');\r\n                        var found = argThis.variables.some(function (el) {\r\n                            return el.name === val;\r\n                        });\r\n                        if (!found) {\r\n                            argThis.variables.push({\r\n                                \"id\": counter.count++,\r\n                                \"name\": val,\r\n                                \"val\": null,\r\n                                \"type\": \"argument\",\r\n                                \"visible\": false,\r\n                            });\r\n                        }\r\n                    }, argThis);\r\n                }\r\n            }\r\n            if (currentVal.type === 'return') {\r\n                if (currentVal.query.arguments) {\r\n                    currentVal.query.arguments.forEach(function (val, ind, array) {\r\n                        val = val.replace(/'/g, '');\r\n                        var found = argThis.variables.some(function (el) {\r\n                            return el.name === val;\r\n                        });\r\n                        if (!found) {\r\n                            argThis.variables.push({\r\n                                \"id\": counter.count++,\r\n                                \"name\": val,\r\n                                \"val\": null,\r\n                                \"type\": \"argument\",\r\n                                \"visible\": false,\r\n                            });\r\n                        }\r\n                    }, argThis);\r\n                }\r\n            }\r\n            if (currentVal.type === \"foreach\") {\r\n                argThis.variables.forEach(function (val) {\r\n                    if (val.name === (currentVal.list.replace(/'/g, ''))) {\r\n                        val.val = [];\r\n                        val.parentId = currentVal.id;\r\n                        val.dirtyArray = [];\r\n                        val.prevVar = [];\r\n                    }\r\n                });\r\n            }\r\n            if (currentVal.statements) {\r\n                this.extractVariables(currentVal.statements, counter, argThis);\r\n            }\r\n        }, argThis);\r\n    }\r\n\r\n    getNextStatement(currentStatement, branchTaken) {\r\n        this.activeLines = [];\r\n        if (this.callStack.length) {\r\n            this.pc = this.callStack.pop();\r\n            if (this.pc.type === 'return') {\r\n                this.pc.type = 'end';\r\n            } else {\r\n                this.pc = this.blocks.shift();\r\n            }\r\n            this.activeLines.push(this.pc.id);\r\n            return this;\r\n        } else {\r\n            if (currentStatement.type === \"if\" && branchTaken) {\r\n                if (currentStatement.statements !== undefined && currentStatement.statements.length > 0) {\r\n                    for (let i = currentStatement.statements.length - 1; i >= 0; i--) {\r\n                        this.blocks.unshift(clone(currentStatement.statements[i]));\r\n                    }\r\n                }\r\n            } else if (currentStatement.type === \"until\" && branchTaken) {\r\n                if (currentStatement.statements !== undefined && currentStatement.statements.length > 0) {\r\n                    this.blocks.unshift(currentStatement);\r\n                    for (let i = currentStatement.statements.length - 1; i >= 0; i--) {\r\n                        this.blocks.unshift(clone(currentStatement.statements[i]));\r\n                    }\r\n                }\r\n            } else if (currentStatement.type === \"return\") {\r\n                if (currentStatement.query.type === \"call\") {\r\n                    this.callStack.push(this.pc);\r\n                    this.activeLines.push(this.pc.id);\r\n                    return 'new';\r\n                } else if (currentStatement.query.type === 'nothing') {\r\n                    this.activeLines.push(this.pc.id);\r\n                    return 'nothing';\r\n                } else {\r\n                    this.activeLines.push(this.pc.id);\r\n                    return 'return';\r\n                }\r\n            } else if (currentStatement.type === \"do\") {\r\n                if (currentStatement.call !== undefined) {\r\n                    this.callStack.push(this.pc);\r\n                    return 'new';\r\n                }\r\n            } else if (currentStatement.type === \"foreach\") {\r\n                if (currentStatement.statements !== undefined && currentStatement.statements.length > 0) {\r\n                    let loopCountVar = this.variables.find(function (val) {\r\n                        return val.name === currentStatement.list.replace(/'/g, '');\r\n                    });\r\n                    for (let num = 0, count = loopCountVar.val.length; num < loopCountVar.val.length; num++, count--) {\r\n                        for (let i = currentStatement.statements.length - 1; i >= 0; i--) {\r\n                            this.blocks.unshift(clone(currentStatement.statements[i]));\r\n                        }\r\n                        // put the foreach statement length minus 1 times\r\n                        if (num < loopCountVar.val.length - 1) {\r\n                            let tempStatement = clone(currentStatement);\r\n                            tempStatement.type = \"loop\";\r\n                            tempStatement.counter = count - 1;\r\n                            this.blocks.unshift(tempStatement);\r\n                        }\r\n                    }\r\n                }\r\n            } else {\r\n                // if (currentStatement.statements !== undefined && currentStatement.type != \"loop\")\r\n                //     this.blocks.unshift(clone(currentStatement.statements[0]));\r\n            }\r\n\r\n            if (this.blocks.length === 0) {\r\n                return 'nothing';\r\n            } else {\r\n                this.pc = this.blocks.shift();\r\n                this.activeLines.push(this.pc.id);\r\n                return this;\r\n            }\r\n\r\n        }\r\n    }\r\n}\r\n\r\nmodule.exports = {\r\n    Interpreter: Interpreter\r\n};\r\n","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n  lookup[i] = code[i]\n  revLookup[code.charCodeAt(i)] = i\n}\n\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction placeHoldersCount (b64) {\n  var len = b64.length\n  if (len % 4 > 0) {\n    throw new Error('Invalid string. Length must be a multiple of 4')\n  }\n\n  // the number of equal signs (place holders)\n  // if there are two placeholders, than the two characters before it\n  // represent one byte\n  // if there is only one, then the three characters before it represent 2 bytes\n  // this is just a cheap hack to not do indexOf twice\n  return b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0\n}\n\nfunction byteLength (b64) {\n  // base64 is 4/3 + up to two characters of the original data\n  return (b64.length * 3 / 4) - placeHoldersCount(b64)\n}\n\nfunction toByteArray (b64) {\n  var i, l, tmp, placeHolders, arr\n  var len = b64.length\n  placeHolders = placeHoldersCount(b64)\n\n  arr = new Arr((len * 3 / 4) - placeHolders)\n\n  // if there are placeholders, only get up to the last complete 4 chars\n  l = placeHolders > 0 ? len - 4 : len\n\n  var L = 0\n\n  for (i = 0; i < l; i += 4) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)]\n    arr[L++] = (tmp >> 16) & 0xFF\n    arr[L++] = (tmp >> 8) & 0xFF\n    arr[L++] = tmp & 0xFF\n  }\n\n  if (placeHolders === 2) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4)\n    arr[L++] = tmp & 0xFF\n  } else if (placeHolders === 1) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2)\n    arr[L++] = (tmp >> 8) & 0xFF\n    arr[L++] = tmp & 0xFF\n  }\n\n  return arr\n}\n\nfunction tripletToBase64 (num) {\n  return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n  var tmp\n  var output = []\n  for (var i = start; i < end; i += 3) {\n    tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n    output.push(tripletToBase64(tmp))\n  }\n  return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n  var tmp\n  var len = uint8.length\n  var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n  var output = ''\n  var parts = []\n  var maxChunkLength = 16383 // must be multiple of 3\n\n  // go through the array every three bytes, we'll deal with trailing stuff later\n  for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n    parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n  }\n\n  // pad the end with zeros, but make sure to not forget the extra bytes\n  if (extraBytes === 1) {\n    tmp = uint8[len - 1]\n    output += lookup[tmp >> 2]\n    output += lookup[(tmp << 4) & 0x3F]\n    output += '=='\n  } else if (extraBytes === 2) {\n    tmp = (uint8[len - 2] << 8) + (uint8[len - 1])\n    output += lookup[tmp >> 10]\n    output += lookup[(tmp >> 4) & 0x3F]\n    output += lookup[(tmp << 2) & 0x3F]\n    output += '='\n  }\n\n  parts.push(output)\n\n  return parts.join('')\n}\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\nvar K_MAX_LENGTH = 0x7fffffff\nexports.kMaxLength = K_MAX_LENGTH\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n *   === true    Use Uint8Array implementation (fastest)\n *   === false   Print warning and recommend using `buffer` v4.x which has an Object\n *               implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n    typeof console.error === 'function') {\n  console.error(\n    'This browser lacks typed array (Uint8Array) support which is required by ' +\n    '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n  )\n}\n\nfunction typedArraySupport () {\n  // Can typed array instances can be augmented?\n  try {\n    var arr = new Uint8Array(1)\n    arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}\n    return arr.foo() === 42\n  } catch (e) {\n    return false\n  }\n}\n\nfunction createBuffer (length) {\n  if (length > K_MAX_LENGTH) {\n    throw new RangeError('Invalid typed array length')\n  }\n  // Return an augmented `Uint8Array` instance\n  var buf = new Uint8Array(length)\n  buf.__proto__ = Buffer.prototype\n  return buf\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n  // Common case.\n  if (typeof arg === 'number') {\n    if (typeof encodingOrOffset === 'string') {\n      throw new Error(\n        'If encoding is specified then the first argument must be a string'\n      )\n    }\n    return allocUnsafe(arg)\n  }\n  return from(arg, encodingOrOffset, length)\n}\n\n// Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\nif (typeof Symbol !== 'undefined' && Symbol.species &&\n    Buffer[Symbol.species] === Buffer) {\n  Object.defineProperty(Buffer, Symbol.species, {\n    value: null,\n    configurable: true,\n    enumerable: false,\n    writable: false\n  })\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\nfunction from (value, encodingOrOffset, length) {\n  if (typeof value === 'number') {\n    throw new TypeError('\"value\" argument must not be a number')\n  }\n\n  if (isArrayBuffer(value)) {\n    return fromArrayBuffer(value, encodingOrOffset, length)\n  }\n\n  if (typeof value === 'string') {\n    return fromString(value, encodingOrOffset)\n  }\n\n  return fromObject(value)\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n  return from(value, encodingOrOffset, length)\n}\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nBuffer.prototype.__proto__ = Uint8Array.prototype\nBuffer.__proto__ = Uint8Array\n\nfunction assertSize (size) {\n  if (typeof size !== 'number') {\n    throw new TypeError('\"size\" argument must be a number')\n  } else if (size < 0) {\n    throw new RangeError('\"size\" argument must not be negative')\n  }\n}\n\nfunction alloc (size, fill, encoding) {\n  assertSize(size)\n  if (size <= 0) {\n    return createBuffer(size)\n  }\n  if (fill !== undefined) {\n    // Only pay attention to encoding if it's a string. This\n    // prevents accidentally sending in a number that would\n    // be interpretted as a start offset.\n    return typeof encoding === 'string'\n      ? createBuffer(size).fill(fill, encoding)\n      : createBuffer(size).fill(fill)\n  }\n  return createBuffer(size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n  return alloc(size, fill, encoding)\n}\n\nfunction allocUnsafe (size) {\n  assertSize(size)\n  return createBuffer(size < 0 ? 0 : checked(size) | 0)\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n  return allocUnsafe(size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n  return allocUnsafe(size)\n}\n\nfunction fromString (string, encoding) {\n  if (typeof encoding !== 'string' || encoding === '') {\n    encoding = 'utf8'\n  }\n\n  if (!Buffer.isEncoding(encoding)) {\n    throw new TypeError('\"encoding\" must be a valid string encoding')\n  }\n\n  var length = byteLength(string, encoding) | 0\n  var buf = createBuffer(length)\n\n  var actual = buf.write(string, encoding)\n\n  if (actual !== length) {\n    // Writing a hex string, for example, that contains invalid characters will\n    // cause everything after the first invalid character to be ignored. (e.g.\n    // 'abxxcd' will be treated as 'ab')\n    buf = buf.slice(0, actual)\n  }\n\n  return buf\n}\n\nfunction fromArrayLike (array) {\n  var length = array.length < 0 ? 0 : checked(array.length) | 0\n  var buf = createBuffer(length)\n  for (var i = 0; i < length; i += 1) {\n    buf[i] = array[i] & 255\n  }\n  return buf\n}\n\nfunction fromArrayBuffer (array, byteOffset, length) {\n  if (byteOffset < 0 || array.byteLength < byteOffset) {\n    throw new RangeError('\\'offset\\' is out of bounds')\n  }\n\n  if (array.byteLength < byteOffset + (length || 0)) {\n    throw new RangeError('\\'length\\' is out of bounds')\n  }\n\n  var buf\n  if (byteOffset === undefined && length === undefined) {\n    buf = new Uint8Array(array)\n  } else if (length === undefined) {\n    buf = new Uint8Array(array, byteOffset)\n  } else {\n    buf = new Uint8Array(array, byteOffset, length)\n  }\n\n  // Return an augmented `Uint8Array` instance\n  buf.__proto__ = Buffer.prototype\n  return buf\n}\n\nfunction fromObject (obj) {\n  if (Buffer.isBuffer(obj)) {\n    var len = checked(obj.length) | 0\n    var buf = createBuffer(len)\n\n    if (buf.length === 0) {\n      return buf\n    }\n\n    obj.copy(buf, 0, 0, len)\n    return buf\n  }\n\n  if (obj) {\n    if (isArrayBufferView(obj) || 'length' in obj) {\n      if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n        return createBuffer(0)\n      }\n      return fromArrayLike(obj)\n    }\n\n    if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n      return fromArrayLike(obj.data)\n    }\n  }\n\n  throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction checked (length) {\n  // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n  // length is NaN (which is otherwise coerced to zero.)\n  if (length >= K_MAX_LENGTH) {\n    throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n                         'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n  }\n  return length | 0\n}\n\nfunction SlowBuffer (length) {\n  if (+length != length) { // eslint-disable-line eqeqeq\n    length = 0\n  }\n  return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n  return b != null && b._isBuffer === true\n}\n\nBuffer.compare = function compare (a, b) {\n  if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n    throw new TypeError('Arguments must be Buffers')\n  }\n\n  if (a === b) return 0\n\n  var x = a.length\n  var y = b.length\n\n  for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n    if (a[i] !== b[i]) {\n      x = a[i]\n      y = b[i]\n      break\n    }\n  }\n\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n  switch (String(encoding).toLowerCase()) {\n    case 'hex':\n    case 'utf8':\n    case 'utf-8':\n    case 'ascii':\n    case 'latin1':\n    case 'binary':\n    case 'base64':\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      return true\n    default:\n      return false\n  }\n}\n\nBuffer.concat = function concat (list, length) {\n  if (!Array.isArray(list)) {\n    throw new TypeError('\"list\" argument must be an Array of Buffers')\n  }\n\n  if (list.length === 0) {\n    return Buffer.alloc(0)\n  }\n\n  var i\n  if (length === undefined) {\n    length = 0\n    for (i = 0; i < list.length; ++i) {\n      length += list[i].length\n    }\n  }\n\n  var buffer = Buffer.allocUnsafe(length)\n  var pos = 0\n  for (i = 0; i < list.length; ++i) {\n    var buf = list[i]\n    if (!Buffer.isBuffer(buf)) {\n      throw new TypeError('\"list\" argument must be an Array of Buffers')\n    }\n    buf.copy(buffer, pos)\n    pos += buf.length\n  }\n  return buffer\n}\n\nfunction byteLength (string, encoding) {\n  if (Buffer.isBuffer(string)) {\n    return string.length\n  }\n  if (isArrayBufferView(string) || isArrayBuffer(string)) {\n    return string.byteLength\n  }\n  if (typeof string !== 'string') {\n    string = '' + string\n  }\n\n  var len = string.length\n  if (len === 0) return 0\n\n  // Use a for loop to avoid recursion\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'ascii':\n      case 'latin1':\n      case 'binary':\n        return len\n      case 'utf8':\n      case 'utf-8':\n      case undefined:\n        return utf8ToBytes(string).length\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return len * 2\n      case 'hex':\n        return len >>> 1\n      case 'base64':\n        return base64ToBytes(string).length\n      default:\n        if (loweredCase) return utf8ToBytes(string).length // assume utf8\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n  var loweredCase = false\n\n  // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n  // property of a typed array.\n\n  // This behaves neither like String nor Uint8Array in that we set start/end\n  // to their upper/lower bounds if the value passed is out of range.\n  // undefined is handled specially as per ECMA-262 6th Edition,\n  // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n  if (start === undefined || start < 0) {\n    start = 0\n  }\n  // Return early if start > this.length. Done here to prevent potential uint32\n  // coercion fail below.\n  if (start > this.length) {\n    return ''\n  }\n\n  if (end === undefined || end > this.length) {\n    end = this.length\n  }\n\n  if (end <= 0) {\n    return ''\n  }\n\n  // Force coersion to uint32. This will also coerce falsey/NaN values to 0.\n  end >>>= 0\n  start >>>= 0\n\n  if (end <= start) {\n    return ''\n  }\n\n  if (!encoding) encoding = 'utf8'\n\n  while (true) {\n    switch (encoding) {\n      case 'hex':\n        return hexSlice(this, start, end)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Slice(this, start, end)\n\n      case 'ascii':\n        return asciiSlice(this, start, end)\n\n      case 'latin1':\n      case 'binary':\n        return latin1Slice(this, start, end)\n\n      case 'base64':\n        return base64Slice(this, start, end)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return utf16leSlice(this, start, end)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = (encoding + '').toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\n// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n  var i = b[n]\n  b[n] = b[m]\n  b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n  var len = this.length\n  if (len % 2 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 16-bits')\n  }\n  for (var i = 0; i < len; i += 2) {\n    swap(this, i, i + 1)\n  }\n  return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n  var len = this.length\n  if (len % 4 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 32-bits')\n  }\n  for (var i = 0; i < len; i += 4) {\n    swap(this, i, i + 3)\n    swap(this, i + 1, i + 2)\n  }\n  return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n  var len = this.length\n  if (len % 8 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 64-bits')\n  }\n  for (var i = 0; i < len; i += 8) {\n    swap(this, i, i + 7)\n    swap(this, i + 1, i + 6)\n    swap(this, i + 2, i + 5)\n    swap(this, i + 3, i + 4)\n  }\n  return this\n}\n\nBuffer.prototype.toString = function toString () {\n  var length = this.length\n  if (length === 0) return ''\n  if (arguments.length === 0) return utf8Slice(this, 0, length)\n  return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.equals = function equals (b) {\n  if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  if (this === b) return true\n  return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n  var str = ''\n  var max = exports.INSPECT_MAX_BYTES\n  if (this.length > 0) {\n    str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n    if (this.length > max) str += ' ... '\n  }\n  return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n  if (!Buffer.isBuffer(target)) {\n    throw new TypeError('Argument must be a Buffer')\n  }\n\n  if (start === undefined) {\n    start = 0\n  }\n  if (end === undefined) {\n    end = target ? target.length : 0\n  }\n  if (thisStart === undefined) {\n    thisStart = 0\n  }\n  if (thisEnd === undefined) {\n    thisEnd = this.length\n  }\n\n  if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n    throw new RangeError('out of range index')\n  }\n\n  if (thisStart >= thisEnd && start >= end) {\n    return 0\n  }\n  if (thisStart >= thisEnd) {\n    return -1\n  }\n  if (start >= end) {\n    return 1\n  }\n\n  start >>>= 0\n  end >>>= 0\n  thisStart >>>= 0\n  thisEnd >>>= 0\n\n  if (this === target) return 0\n\n  var x = thisEnd - thisStart\n  var y = end - start\n  var len = Math.min(x, y)\n\n  var thisCopy = this.slice(thisStart, thisEnd)\n  var targetCopy = target.slice(start, end)\n\n  for (var i = 0; i < len; ++i) {\n    if (thisCopy[i] !== targetCopy[i]) {\n      x = thisCopy[i]\n      y = targetCopy[i]\n      break\n    }\n  }\n\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n  // Empty buffer means no match\n  if (buffer.length === 0) return -1\n\n  // Normalize byteOffset\n  if (typeof byteOffset === 'string') {\n    encoding = byteOffset\n    byteOffset = 0\n  } else if (byteOffset > 0x7fffffff) {\n    byteOffset = 0x7fffffff\n  } else if (byteOffset < -0x80000000) {\n    byteOffset = -0x80000000\n  }\n  byteOffset = +byteOffset  // Coerce to Number.\n  if (numberIsNaN(byteOffset)) {\n    // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n    byteOffset = dir ? 0 : (buffer.length - 1)\n  }\n\n  // Normalize byteOffset: negative offsets start from the end of the buffer\n  if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n  if (byteOffset >= buffer.length) {\n    if (dir) return -1\n    else byteOffset = buffer.length - 1\n  } else if (byteOffset < 0) {\n    if (dir) byteOffset = 0\n    else return -1\n  }\n\n  // Normalize val\n  if (typeof val === 'string') {\n    val = Buffer.from(val, encoding)\n  }\n\n  // Finally, search either indexOf (if dir is true) or lastIndexOf\n  if (Buffer.isBuffer(val)) {\n    // Special case: looking for empty string/buffer always fails\n    if (val.length === 0) {\n      return -1\n    }\n    return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n  } else if (typeof val === 'number') {\n    val = val & 0xFF // Search for a byte value [0-255]\n    if (typeof Uint8Array.prototype.indexOf === 'function') {\n      if (dir) {\n        return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n      } else {\n        return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n      }\n    }\n    return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)\n  }\n\n  throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n  var indexSize = 1\n  var arrLength = arr.length\n  var valLength = val.length\n\n  if (encoding !== undefined) {\n    encoding = String(encoding).toLowerCase()\n    if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n        encoding === 'utf16le' || encoding === 'utf-16le') {\n      if (arr.length < 2 || val.length < 2) {\n        return -1\n      }\n      indexSize = 2\n      arrLength /= 2\n      valLength /= 2\n      byteOffset /= 2\n    }\n  }\n\n  function read (buf, i) {\n    if (indexSize === 1) {\n      return buf[i]\n    } else {\n      return buf.readUInt16BE(i * indexSize)\n    }\n  }\n\n  var i\n  if (dir) {\n    var foundIndex = -1\n    for (i = byteOffset; i < arrLength; i++) {\n      if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n        if (foundIndex === -1) foundIndex = i\n        if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n      } else {\n        if (foundIndex !== -1) i -= i - foundIndex\n        foundIndex = -1\n      }\n    }\n  } else {\n    if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n    for (i = byteOffset; i >= 0; i--) {\n      var found = true\n      for (var j = 0; j < valLength; j++) {\n        if (read(arr, i + j) !== read(val, j)) {\n          found = false\n          break\n        }\n      }\n      if (found) return i\n    }\n  }\n\n  return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n  return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n  return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n  return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n  offset = Number(offset) || 0\n  var remaining = buf.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n\n  // must be an even number of digits\n  var strLen = string.length\n  if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\n  if (length > strLen / 2) {\n    length = strLen / 2\n  }\n  for (var i = 0; i < length; ++i) {\n    var parsed = parseInt(string.substr(i * 2, 2), 16)\n    if (numberIsNaN(parsed)) return i\n    buf[offset + i] = parsed\n  }\n  return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n  return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n  return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction latin1Write (buf, string, offset, length) {\n  return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n  return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n  return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n  // Buffer#write(string)\n  if (offset === undefined) {\n    encoding = 'utf8'\n    length = this.length\n    offset = 0\n  // Buffer#write(string, encoding)\n  } else if (length === undefined && typeof offset === 'string') {\n    encoding = offset\n    length = this.length\n    offset = 0\n  // Buffer#write(string, offset[, length][, encoding])\n  } else if (isFinite(offset)) {\n    offset = offset >>> 0\n    if (isFinite(length)) {\n      length = length >>> 0\n      if (encoding === undefined) encoding = 'utf8'\n    } else {\n      encoding = length\n      length = undefined\n    }\n  } else {\n    throw new Error(\n      'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n    )\n  }\n\n  var remaining = this.length - offset\n  if (length === undefined || length > remaining) length = remaining\n\n  if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n    throw new RangeError('Attempt to write outside buffer bounds')\n  }\n\n  if (!encoding) encoding = 'utf8'\n\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'hex':\n        return hexWrite(this, string, offset, length)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Write(this, string, offset, length)\n\n      case 'ascii':\n        return asciiWrite(this, string, offset, length)\n\n      case 'latin1':\n      case 'binary':\n        return latin1Write(this, string, offset, length)\n\n      case 'base64':\n        // Warning: maxLength not taken into account in base64Write\n        return base64Write(this, string, offset, length)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return ucs2Write(this, string, offset, length)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n  return {\n    type: 'Buffer',\n    data: Array.prototype.slice.call(this._arr || this, 0)\n  }\n}\n\nfunction base64Slice (buf, start, end) {\n  if (start === 0 && end === buf.length) {\n    return base64.fromByteArray(buf)\n  } else {\n    return base64.fromByteArray(buf.slice(start, end))\n  }\n}\n\nfunction utf8Slice (buf, start, end) {\n  end = Math.min(buf.length, end)\n  var res = []\n\n  var i = start\n  while (i < end) {\n    var firstByte = buf[i]\n    var codePoint = null\n    var bytesPerSequence = (firstByte > 0xEF) ? 4\n      : (firstByte > 0xDF) ? 3\n      : (firstByte > 0xBF) ? 2\n      : 1\n\n    if (i + bytesPerSequence <= end) {\n      var secondByte, thirdByte, fourthByte, tempCodePoint\n\n      switch (bytesPerSequence) {\n        case 1:\n          if (firstByte < 0x80) {\n            codePoint = firstByte\n          }\n          break\n        case 2:\n          secondByte = buf[i + 1]\n          if ((secondByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n            if (tempCodePoint > 0x7F) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 3:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n            if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 4:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          fourthByte = buf[i + 3]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n            if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n              codePoint = tempCodePoint\n            }\n          }\n      }\n    }\n\n    if (codePoint === null) {\n      // we did not generate a valid codePoint so insert a\n      // replacement char (U+FFFD) and advance only 1 byte\n      codePoint = 0xFFFD\n      bytesPerSequence = 1\n    } else if (codePoint > 0xFFFF) {\n      // encode to utf16 (surrogate pair dance)\n      codePoint -= 0x10000\n      res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n      codePoint = 0xDC00 | codePoint & 0x3FF\n    }\n\n    res.push(codePoint)\n    i += bytesPerSequence\n  }\n\n  return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n  var len = codePoints.length\n  if (len <= MAX_ARGUMENTS_LENGTH) {\n    return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n  }\n\n  // Decode in chunks to avoid \"call stack size exceeded\".\n  var res = ''\n  var i = 0\n  while (i < len) {\n    res += String.fromCharCode.apply(\n      String,\n      codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n    )\n  }\n  return res\n}\n\nfunction asciiSlice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; ++i) {\n    ret += String.fromCharCode(buf[i] & 0x7F)\n  }\n  return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; ++i) {\n    ret += String.fromCharCode(buf[i])\n  }\n  return ret\n}\n\nfunction hexSlice (buf, start, end) {\n  var len = buf.length\n\n  if (!start || start < 0) start = 0\n  if (!end || end < 0 || end > len) end = len\n\n  var out = ''\n  for (var i = start; i < end; ++i) {\n    out += toHex(buf[i])\n  }\n  return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n  var bytes = buf.slice(start, end)\n  var res = ''\n  for (var i = 0; i < bytes.length; i += 2) {\n    res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256))\n  }\n  return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n  var len = this.length\n  start = ~~start\n  end = end === undefined ? len : ~~end\n\n  if (start < 0) {\n    start += len\n    if (start < 0) start = 0\n  } else if (start > len) {\n    start = len\n  }\n\n  if (end < 0) {\n    end += len\n    if (end < 0) end = 0\n  } else if (end > len) {\n    end = len\n  }\n\n  if (end < start) end = start\n\n  var newBuf = this.subarray(start, end)\n  // Return an augmented `Uint8Array` instance\n  newBuf.__proto__ = Buffer.prototype\n  return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n  if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n  if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n  offset = offset >>> 0\n  byteLength = byteLength >>> 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n  offset = offset >>> 0\n  byteLength = byteLength >>> 0\n  if (!noAssert) {\n    checkOffset(offset, byteLength, this.length)\n  }\n\n  var val = this[offset + --byteLength]\n  var mul = 1\n  while (byteLength > 0 && (mul *= 0x100)) {\n    val += this[offset + --byteLength] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return ((this[offset]) |\n      (this[offset + 1] << 8) |\n      (this[offset + 2] << 16)) +\n      (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset] * 0x1000000) +\n    ((this[offset + 1] << 16) |\n    (this[offset + 2] << 8) |\n    this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n  offset = offset >>> 0\n  byteLength = byteLength >>> 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n  offset = offset >>> 0\n  byteLength = byteLength >>> 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var i = byteLength\n  var mul = 1\n  var val = this[offset + --i]\n  while (i > 0 && (mul *= 0x100)) {\n    val += this[offset + --i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  if (!(this[offset] & 0x80)) return (this[offset])\n  return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  var val = this[offset] | (this[offset + 1] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  var val = this[offset + 1] | (this[offset] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset]) |\n    (this[offset + 1] << 8) |\n    (this[offset + 2] << 16) |\n    (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset] << 24) |\n    (this[offset + 1] << 16) |\n    (this[offset + 2] << 8) |\n    (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n  if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n  if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n  if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  byteLength = byteLength >>> 0\n  if (!noAssert) {\n    var maxBytes = Math.pow(2, 8 * byteLength) - 1\n    checkInt(this, value, offset, byteLength, maxBytes, 0)\n  }\n\n  var mul = 1\n  var i = 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  byteLength = byteLength >>> 0\n  if (!noAssert) {\n    var maxBytes = Math.pow(2, 8 * byteLength) - 1\n    checkInt(this, value, offset, byteLength, maxBytes, 0)\n  }\n\n  var i = byteLength - 1\n  var mul = 1\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n  this[offset] = (value & 0xff)\n  return offset + 1\n}\n\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  this[offset] = (value & 0xff)\n  this[offset + 1] = (value >>> 8)\n  return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  this[offset] = (value >>> 8)\n  this[offset + 1] = (value & 0xff)\n  return offset + 2\n}\n\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n  this[offset + 3] = (value >>> 24)\n  this[offset + 2] = (value >>> 16)\n  this[offset + 1] = (value >>> 8)\n  this[offset] = (value & 0xff)\n  return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n  this[offset] = (value >>> 24)\n  this[offset + 1] = (value >>> 16)\n  this[offset + 2] = (value >>> 8)\n  this[offset + 3] = (value & 0xff)\n  return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) {\n    var limit = Math.pow(2, (8 * byteLength) - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = 0\n  var mul = 1\n  var sub = 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n      sub = 1\n    }\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) {\n    var limit = Math.pow(2, (8 * byteLength) - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = byteLength - 1\n  var mul = 1\n  var sub = 0\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n      sub = 1\n    }\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n  if (value < 0) value = 0xff + value + 1\n  this[offset] = (value & 0xff)\n  return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  this[offset] = (value & 0xff)\n  this[offset + 1] = (value >>> 8)\n  return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  this[offset] = (value >>> 8)\n  this[offset + 1] = (value & 0xff)\n  return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  this[offset] = (value & 0xff)\n  this[offset + 1] = (value >>> 8)\n  this[offset + 2] = (value >>> 16)\n  this[offset + 3] = (value >>> 24)\n  return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (value < 0) value = 0xffffffff + value + 1\n  this[offset] = (value >>> 24)\n  this[offset + 1] = (value >>> 16)\n  this[offset + 2] = (value >>> 8)\n  this[offset + 3] = (value & 0xff)\n  return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n  if (offset + ext > buf.length) throw new RangeError('Index out of range')\n  if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) {\n    checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n  }\n  ieee754.write(buf, value, offset, littleEndian, 23, 4)\n  return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) {\n    checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n  }\n  ieee754.write(buf, value, offset, littleEndian, 52, 8)\n  return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n  if (!start) start = 0\n  if (!end && end !== 0) end = this.length\n  if (targetStart >= target.length) targetStart = target.length\n  if (!targetStart) targetStart = 0\n  if (end > 0 && end < start) end = start\n\n  // Copy 0 bytes; we're done\n  if (end === start) return 0\n  if (target.length === 0 || this.length === 0) return 0\n\n  // Fatal error conditions\n  if (targetStart < 0) {\n    throw new RangeError('targetStart out of bounds')\n  }\n  if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n  if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n  // Are we oob?\n  if (end > this.length) end = this.length\n  if (target.length - targetStart < end - start) {\n    end = target.length - targetStart + start\n  }\n\n  var len = end - start\n  var i\n\n  if (this === target && start < targetStart && targetStart < end) {\n    // descending copy from end\n    for (i = len - 1; i >= 0; --i) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else if (len < 1000) {\n    // ascending copy from start\n    for (i = 0; i < len; ++i) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else {\n    Uint8Array.prototype.set.call(\n      target,\n      this.subarray(start, start + len),\n      targetStart\n    )\n  }\n\n  return len\n}\n\n// Usage:\n//    buffer.fill(number[, offset[, end]])\n//    buffer.fill(buffer[, offset[, end]])\n//    buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n  // Handle string cases:\n  if (typeof val === 'string') {\n    if (typeof start === 'string') {\n      encoding = start\n      start = 0\n      end = this.length\n    } else if (typeof end === 'string') {\n      encoding = end\n      end = this.length\n    }\n    if (val.length === 1) {\n      var code = val.charCodeAt(0)\n      if (code < 256) {\n        val = code\n      }\n    }\n    if (encoding !== undefined && typeof encoding !== 'string') {\n      throw new TypeError('encoding must be a string')\n    }\n    if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n      throw new TypeError('Unknown encoding: ' + encoding)\n    }\n  } else if (typeof val === 'number') {\n    val = val & 255\n  }\n\n  // Invalid ranges are not set to a default, so can range check early.\n  if (start < 0 || this.length < start || this.length < end) {\n    throw new RangeError('Out of range index')\n  }\n\n  if (end <= start) {\n    return this\n  }\n\n  start = start >>> 0\n  end = end === undefined ? this.length : end >>> 0\n\n  if (!val) val = 0\n\n  var i\n  if (typeof val === 'number') {\n    for (i = start; i < end; ++i) {\n      this[i] = val\n    }\n  } else {\n    var bytes = Buffer.isBuffer(val)\n      ? val\n      : new Buffer(val, encoding)\n    var len = bytes.length\n    for (i = 0; i < end - start; ++i) {\n      this[i + start] = bytes[i % len]\n    }\n  }\n\n  return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n  // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n  str = str.trim().replace(INVALID_BASE64_RE, '')\n  // Node converts strings with length < 2 to ''\n  if (str.length < 2) return ''\n  // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n  while (str.length % 4 !== 0) {\n    str = str + '='\n  }\n  return str\n}\n\nfunction toHex (n) {\n  if (n < 16) return '0' + n.toString(16)\n  return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n  units = units || Infinity\n  var codePoint\n  var length = string.length\n  var leadSurrogate = null\n  var bytes = []\n\n  for (var i = 0; i < length; ++i) {\n    codePoint = string.charCodeAt(i)\n\n    // is surrogate component\n    if (codePoint > 0xD7FF && codePoint < 0xE000) {\n      // last char was a lead\n      if (!leadSurrogate) {\n        // no lead yet\n        if (codePoint > 0xDBFF) {\n          // unexpected trail\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        } else if (i + 1 === length) {\n          // unpaired lead\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        }\n\n        // valid lead\n        leadSurrogate = codePoint\n\n        continue\n      }\n\n      // 2 leads in a row\n      if (codePoint < 0xDC00) {\n        if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n        leadSurrogate = codePoint\n        continue\n      }\n\n      // valid surrogate pair\n      codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n    } else if (leadSurrogate) {\n      // valid bmp char, but last char was a lead\n      if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n    }\n\n    leadSurrogate = null\n\n    // encode utf8\n    if (codePoint < 0x80) {\n      if ((units -= 1) < 0) break\n      bytes.push(codePoint)\n    } else if (codePoint < 0x800) {\n      if ((units -= 2) < 0) break\n      bytes.push(\n        codePoint >> 0x6 | 0xC0,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x10000) {\n      if ((units -= 3) < 0) break\n      bytes.push(\n        codePoint >> 0xC | 0xE0,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x110000) {\n      if ((units -= 4) < 0) break\n      bytes.push(\n        codePoint >> 0x12 | 0xF0,\n        codePoint >> 0xC & 0x3F | 0x80,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else {\n      throw new Error('Invalid code point')\n    }\n  }\n\n  return bytes\n}\n\nfunction asciiToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; ++i) {\n    // Node's code seems to be doing this and not & 0x7F..\n    byteArray.push(str.charCodeAt(i) & 0xFF)\n  }\n  return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n  var c, hi, lo\n  var byteArray = []\n  for (var i = 0; i < str.length; ++i) {\n    if ((units -= 2) < 0) break\n\n    c = str.charCodeAt(i)\n    hi = c >> 8\n    lo = c % 256\n    byteArray.push(lo)\n    byteArray.push(hi)\n  }\n\n  return byteArray\n}\n\nfunction base64ToBytes (str) {\n  return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n  for (var i = 0; i < length; ++i) {\n    if ((i + offset >= dst.length) || (i >= src.length)) break\n    dst[i + offset] = src[i]\n  }\n  return i\n}\n\n// ArrayBuffers from another context (i.e. an iframe) do not pass the `instanceof` check\n// but they should be treated as valid. See: https://github.com/feross/buffer/issues/166\nfunction isArrayBuffer (obj) {\n  return obj instanceof ArrayBuffer ||\n    (obj != null && obj.constructor != null && obj.constructor.name === 'ArrayBuffer' &&\n      typeof obj.byteLength === 'number')\n}\n\n// Node 0.10 supports `ArrayBuffer` but lacks `ArrayBuffer.isView`\nfunction isArrayBufferView (obj) {\n  return (typeof ArrayBuffer.isView === 'function') && ArrayBuffer.isView(obj)\n}\n\nfunction numberIsNaN (obj) {\n  return obj !== obj // eslint-disable-line no-self-compare\n}\n","var clone = (function() {\n'use strict';\n\nfunction _instanceof(obj, type) {\n  return type != null && obj instanceof type;\n}\n\nvar nativeMap;\ntry {\n  nativeMap = Map;\n} catch(_) {\n  // maybe a reference error because no `Map`. Give it a dummy value that no\n  // value will ever be an instanceof.\n  nativeMap = function() {};\n}\n\nvar nativeSet;\ntry {\n  nativeSet = Set;\n} catch(_) {\n  nativeSet = function() {};\n}\n\nvar nativePromise;\ntry {\n  nativePromise = Promise;\n} catch(_) {\n  nativePromise = function() {};\n}\n\n/**\n * Clones (copies) an Object using deep copying.\n *\n * This function supports circular references by default, but if you are certain\n * there are no circular references in your object, you can save some CPU time\n * by calling clone(obj, false).\n *\n * Caution: if `circular` is false and `parent` contains circular references,\n * your program may enter an infinite loop and crash.\n *\n * @param `parent` - the object to be cloned\n * @param `circular` - set to true if the object to be cloned may contain\n *    circular references. (optional - true by default)\n * @param `depth` - set to a number if the object is only to be cloned to\n *    a particular depth. (optional - defaults to Infinity)\n * @param `prototype` - sets the prototype to be used when cloning an object.\n *    (optional - defaults to parent prototype).\n * @param `includeNonEnumerable` - set to true if the non-enumerable properties\n *    should be cloned as well. Non-enumerable properties on the prototype\n *    chain will be ignored. (optional - false by default)\n*/\nfunction clone(parent, circular, depth, prototype, includeNonEnumerable) {\n  if (typeof circular === 'object') {\n    depth = circular.depth;\n    prototype = circular.prototype;\n    includeNonEnumerable = circular.includeNonEnumerable;\n    circular = circular.circular;\n  }\n  // maintain two arrays for circular references, where corresponding parents\n  // and children have the same index\n  var allParents = [];\n  var allChildren = [];\n\n  var useBuffer = typeof Buffer != 'undefined';\n\n  if (typeof circular == 'undefined')\n    circular = true;\n\n  if (typeof depth == 'undefined')\n    depth = Infinity;\n\n  // recurse this function so we don't reset allParents and allChildren\n  function _clone(parent, depth) {\n    // cloning null always returns null\n    if (parent === null)\n      return null;\n\n    if (depth === 0)\n      return parent;\n\n    var child;\n    var proto;\n    if (typeof parent != 'object') {\n      return parent;\n    }\n\n    if (_instanceof(parent, nativeMap)) {\n      child = new nativeMap();\n    } else if (_instanceof(parent, nativeSet)) {\n      child = new nativeSet();\n    } else if (_instanceof(parent, nativePromise)) {\n      child = new nativePromise(function (resolve, reject) {\n        parent.then(function(value) {\n          resolve(_clone(value, depth - 1));\n        }, function(err) {\n          reject(_clone(err, depth - 1));\n        });\n      });\n    } else if (clone.__isArray(parent)) {\n      child = [];\n    } else if (clone.__isRegExp(parent)) {\n      child = new RegExp(parent.source, __getRegExpFlags(parent));\n      if (parent.lastIndex) child.lastIndex = parent.lastIndex;\n    } else if (clone.__isDate(parent)) {\n      child = new Date(parent.getTime());\n    } else if (useBuffer && Buffer.isBuffer(parent)) {\n      child = new Buffer(parent.length);\n      parent.copy(child);\n      return child;\n    } else if (_instanceof(parent, Error)) {\n      child = Object.create(parent);\n    } else {\n      if (typeof prototype == 'undefined') {\n        proto = Object.getPrototypeOf(parent);\n        child = Object.create(proto);\n      }\n      else {\n        child = Object.create(prototype);\n        proto = prototype;\n      }\n    }\n\n    if (circular) {\n      var index = allParents.indexOf(parent);\n\n      if (index != -1) {\n        return allChildren[index];\n      }\n      allParents.push(parent);\n      allChildren.push(child);\n    }\n\n    if (_instanceof(parent, nativeMap)) {\n      parent.forEach(function(value, key) {\n        var keyChild = _clone(key, depth - 1);\n        var valueChild = _clone(value, depth - 1);\n        child.set(keyChild, valueChild);\n      });\n    }\n    if (_instanceof(parent, nativeSet)) {\n      parent.forEach(function(value) {\n        var entryChild = _clone(value, depth - 1);\n        child.add(entryChild);\n      });\n    }\n\n    for (var i in parent) {\n      var attrs;\n      if (proto) {\n        attrs = Object.getOwnPropertyDescriptor(proto, i);\n      }\n\n      if (attrs && attrs.set == null) {\n        continue;\n      }\n      child[i] = _clone(parent[i], depth - 1);\n    }\n\n    if (Object.getOwnPropertySymbols) {\n      var symbols = Object.getOwnPropertySymbols(parent);\n      for (var i = 0; i < symbols.length; i++) {\n        // Don't need to worry about cloning a symbol because it is a primitive,\n        // like a number or string.\n        var symbol = symbols[i];\n        var descriptor = Object.getOwnPropertyDescriptor(parent, symbol);\n        if (descriptor && !descriptor.enumerable && !includeNonEnumerable) {\n          continue;\n        }\n        child[symbol] = _clone(parent[symbol], depth - 1);\n        if (!descriptor.enumerable) {\n          Object.defineProperty(child, symbol, {\n            enumerable: false\n          });\n        }\n      }\n    }\n\n    if (includeNonEnumerable) {\n      var allPropertyNames = Object.getOwnPropertyNames(parent);\n      for (var i = 0; i < allPropertyNames.length; i++) {\n        var propertyName = allPropertyNames[i];\n        var descriptor = Object.getOwnPropertyDescriptor(parent, propertyName);\n        if (descriptor && descriptor.enumerable) {\n          continue;\n        }\n        child[propertyName] = _clone(parent[propertyName], depth - 1);\n        Object.defineProperty(child, propertyName, {\n          enumerable: false\n        });\n      }\n    }\n\n    return child;\n  }\n\n  return _clone(parent, depth);\n}\n\n/**\n * Simple flat clone using prototype, accepts only objects, usefull for property\n * override on FLAT configuration object (no nested props).\n *\n * USE WITH CAUTION! This may not behave as you wish if you do not know how this\n * works.\n */\nclone.clonePrototype = function clonePrototype(parent) {\n  if (parent === null)\n    return null;\n\n  var c = function () {};\n  c.prototype = parent;\n  return new c();\n};\n\n// private utility functions\n\nfunction __objToStr(o) {\n  return Object.prototype.toString.call(o);\n}\nclone.__objToStr = __objToStr;\n\nfunction __isDate(o) {\n  return typeof o === 'object' && __objToStr(o) === '[object Date]';\n}\nclone.__isDate = __isDate;\n\nfunction __isArray(o) {\n  return typeof o === 'object' && __objToStr(o) === '[object Array]';\n}\nclone.__isArray = __isArray;\n\nfunction __isRegExp(o) {\n  return typeof o === 'object' && __objToStr(o) === '[object RegExp]';\n}\nclone.__isRegExp = __isRegExp;\n\nfunction __getRegExpFlags(re) {\n  var flags = '';\n  if (re.global) flags += 'g';\n  if (re.ignoreCase) flags += 'i';\n  if (re.multiline) flags += 'm';\n  return flags;\n}\nclone.__getRegExpFlags = __getRegExpFlags;\n\nreturn clone;\n})();\n\nif (typeof module === 'object' && module.exports) {\n  module.exports = clone;\n}\n","exports.read = function (buffer, offset, isLE, mLen, nBytes) {\n  var e, m\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var nBits = -7\n  var i = isLE ? (nBytes - 1) : 0\n  var d = isLE ? -1 : 1\n  var s = buffer[offset + i]\n\n  i += d\n\n  e = s & ((1 << (-nBits)) - 1)\n  s >>= (-nBits)\n  nBits += eLen\n  for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  m = e & ((1 << (-nBits)) - 1)\n  e >>= (-nBits)\n  nBits += mLen\n  for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  if (e === 0) {\n    e = 1 - eBias\n  } else if (e === eMax) {\n    return m ? NaN : ((s ? -1 : 1) * Infinity)\n  } else {\n    m = m + Math.pow(2, mLen)\n    e = e - eBias\n  }\n  return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n  var e, m, c\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n  var i = isLE ? 0 : (nBytes - 1)\n  var d = isLE ? 1 : -1\n  var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n  value = Math.abs(value)\n\n  if (isNaN(value) || value === Infinity) {\n    m = isNaN(value) ? 1 : 0\n    e = eMax\n  } else {\n    e = Math.floor(Math.log(value) / Math.LN2)\n    if (value * (c = Math.pow(2, -e)) < 1) {\n      e--\n      c *= 2\n    }\n    if (e + eBias >= 1) {\n      value += rt / c\n    } else {\n      value += rt * Math.pow(2, 1 - eBias)\n    }\n    if (value * c >= 2) {\n      e++\n      c /= 2\n    }\n\n    if (e + eBias >= eMax) {\n      m = 0\n      e = eMax\n    } else if (e + eBias >= 1) {\n      m = (value * c - 1) * Math.pow(2, mLen)\n      e = e + eBias\n    } else {\n      m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n      e = 0\n    }\n  }\n\n  for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n  e = (e << mLen) | m\n  eLen += mLen\n  for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n  buffer[offset + i - d] |= s * 128\n}\n"]} +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../node_modules/browser-pack/_prelude.js","index.js","models.js","../node_modules/base64-js/index.js","../node_modules/buffer/index.js","../node_modules/clone/clone.js","../node_modules/ieee754/index.js"],"names":[],"mappings":"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CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AClHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AClrDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;AC3PA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;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})","const models = require('./models.js');\r\n// require('./dataManagement.js');\r\n\r\nvar config = {\r\n    apiKey: \"AIzaSyAXjL6f739BVqLDknymCN2H36-NBDS8LvY\",\r\n    authDomain: \"strategytracker.firebaseapp.com\",\r\n    databaseURL: \"https://strategytracker.firebaseio.com\",\r\n    projectId: \"strategytracker\",\r\n    storageBucket: \"strategytracker.appspot.com\",\r\n    messagingSenderId: \"261249836518\"\r\n};\r\nfirebase.initializeApp(config);\r\n\r\nif (typeof window !== 'undefined' && window.angular) {\r\n    let myapp = angular.module('myapp', ['ngSanitize']);\r\n\r\n    myapp.run(function ($rootScope) {\r\n        ['isArray', 'isDate', 'isDefined', 'isFunction', 'isNumber', 'isObject', 'isString', 'isUndefined'].forEach(function (name) {\r\n            $rootScope[name] = angular[name];\r\n        });\r\n    });\r\n\r\n    myapp.factory('StrategyService', function ($q) {\r\n        let strategies = [];\r\n        let deferred = $q.defer();\r\n        firebase.database().ref('strategies').once('value').then(function (snapshot) {\r\n            snapshot.forEach(function (childStrategy) {\r\n                strategies.push(childStrategy.val());\r\n            });\r\n            deferred.resolve(strategies);\r\n        }).catch(function (err) {\r\n            deferred.reject(err);\r\n        });\r\n\r\n        return {\r\n            getAll: function () {\r\n                return deferred.promise;\r\n            },\r\n        };\r\n    });\r\n\r\n    myapp.controller('MainCtrl', function ($scope, StrategyService, $window, $timeout) {\r\n        \"use strict\";\r\n        let vm = this;\r\n        let myStrat = StrategyService.getAll();\r\n        //Asynchronous : If the records are ready from deffered.promise, then the following steps is run.\r\n        myStrat.then(function (allStrategies) {\r\n            vm.allStrategies = allStrategies;\r\n            let interpreter = null;\r\n            // get the strategy from URL\r\n            let keyval = $window.location.search.replace('?', '').split('=');\r\n            if(keyval[0] == 'strategy') {\r\n                vm.selectedStrategy = allStrategies.filter(function (value) {\r\n                    return value.name == keyval[1];\r\n                })[0];\r\n                interpreter = new models.Interpreter(vm.selectedStrategy.strategies);\r\n                vm.execObj = interpreter.init(vm.selectedStrategy.strategies[0]);\r\n                vm.currentStrategy = vm.execObj.currentStrategy;\r\n                vm.parameters = vm.execObj.variables.filter(function (val) {\r\n                    return val.type == 'parameter';\r\n                });\r\n                // open the modal to input strategy parameters\r\n                $(\"#initialParams\").modal({\r\n                    backdrop: \"static\",\r\n                    keyboard: \"false\",\r\n                });\r\n                vm.myStrategy = vm.selectedStrategy;\r\n            }\r\n            vm.strategyChanged = function () {\r\n                $window.location = $window.location.origin + $window.location.pathname + '?strategy=' + vm.myStrategy.name;\r\n            };\r\n\r\n            vm.proceedToStrategy = function () {\r\n                let flag = true;\r\n                angular.forEach(vm.parameters, function (val, key) {\r\n                    if(val.val == null || val.val.trim() == '') {\r\n                        flag = false;\r\n                    }\r\n                });\r\n\r\n                if(flag == true) {\r\n                    angular.forEach(vm.parameters, function (val, key) {\r\n                        val.visible=true;\r\n                    });\r\n                    $(\"#initialParams\").modal('hide');\r\n                }\r\n            };\r\n\r\n            vm.reset = function () {\r\n                if (vm.selectedStrategy) {\r\n                    interpreter.reset();\r\n                    vm.execObj = interpreter.init(vm.selectedStrategy.strategies[0]);\r\n                    vm.currentStrategy = vm.execObj.currentStrategy;\r\n                    $('#' + vm.currentStrategy.name).collapse('show');\r\n                    vm.selectedStrategy.strategies.forEach(function (strat) {\r\n                        if(vm.currentStrategy.name !== strat.name) $('#' + strat.name).collapse('hide');\r\n                    });\r\n                    // open the modal to input strategy parameters\r\n                    vm.parameters = vm.execObj.variables.filter(function (val) {\r\n                        return val.type == 'parameter';\r\n                    });\r\n                    // open the modal to input strategy parameters\r\n                    $(\"#initialParams\").modal({\r\n                        backdrop: \"static\",\r\n                        keyboard: \"false\",\r\n                    });\r\n                } else {\r\n                    alert(\"please choose a strategy first\");\r\n                }\r\n\r\n            };\r\n            function checkType() {\r\n                if (vm.execObj.currentStatement.type == 'set') {\r\n                    let id = vm.execObj.currentStatement.identifier.replace(/'/g, '');\r\n                    let variable = vm.execObj.variables.find(function (val, index, arr) {\r\n                        return val.name == id;\r\n                    });\r\n                    if (variable.val == null || variable.val.length == 0) {\r\n                        variable.visible = true;\r\n                        vm.execObj.setNeeded = true;\r\n                        $scope.$broadcast(\"EditMe\", id);\r\n                    } else {\r\n                        vm.execObj.setNeeded = false;\r\n                    }\r\n                }\r\n                if (vm.execObj.currentStatement.type == 'foreach' || vm.execObj.currentStatement.type == 'loop') {\r\n                    let list = vm.execObj.variables.find(function (val) {\r\n                        return val.name === vm.execObj.currentStatement.list.replace(/'/g, '');\r\n                    });\r\n\r\n                    let identifier = vm.execObj.variables.find(function (val) {\r\n                        return val.name === vm.execObj.currentStatement.identifier.replace(/'/g, '');\r\n                    });\r\n                    identifier.visible = true;\r\n                    identifier.val = list.val[vm.execObj.currentStatement.counter ? vm.execObj.currentStatement.counter : 0];\r\n                    list.dirtyArray.push(list.val[vm.execObj.currentStatement.counter ? vm.execObj.currentStatement.counter : 0]);\r\n                    //$scope.$apply();\r\n\r\n                }\r\n            }\r\n\r\n            vm.nextStatement = function () {\r\n                vm.execObj = interpreter.execute();\r\n                // vm.execObj.variables.forEach(function (variable) {\r\n                //     console.log(\"Variables:   \" + variable.name);\r\n                // });\r\n                if (vm.execObj == null) {\r\n                    $timeout(function() {\r\n                        alert(\"Congratulation!You have reached end of strategy! If you think you did not finish the task, reset the strategy and start over again. \");\r\n                    }, 100);\r\n                    return;\r\n                }\r\n                checkType();\r\n                if(vm.execObj.strategyChanged) {\r\n                    $timeout(function () {\r\n                        angular.forEach(vm.execObj.variables, function (val, key) {\r\n                            if(val.type == 'parameter') {\r\n                                val.visible = true;\r\n                            }\r\n                        });\r\n                    }, 100);\r\n                }\r\n                if (vm.currentStrategy.name !== vm.execObj.currentStrategy.name) {\r\n                    $('#' + vm.execObj.currentStrategy.name).collapse('show');\r\n                    $('#' + vm.currentStrategy.name).collapse('hide');\r\n                    if (vm.execObj.variables !== null){\r\n                        vm.parameters = vm.execObj.variables.filter(function (val) {\r\n                            return val.type == 'parameter';\r\n                        });\r\n                    }\r\n\r\n                    vm.currentStrategy = vm.execObj.currentStrategy;\r\n                }\r\n            };\r\n\r\n            vm.prevStatement = function () {\r\n                vm.execObj = interpreter.goBack();\r\n                if (vm.execObj === null) return;\r\n                if(vm.execObj.currentStatement.type === 'set') {\r\n                    let id = vm.execObj.currentStatement.identifier.replace(/'/g, '');\r\n                    let variable = vm.execObj.variables.find(function (val, index, arr) {\r\n                        return val.name == id;\r\n                    });\r\n                    console.log(variable);\r\n                    if(variable.dirtyArray !== undefined) variable.dirtyArray = [];\r\n                }\r\n                checkType();\r\n                if (vm.currentStrategy.name !== vm.execObj.currentStrategy.name) {\r\n                    $('#' + vm.execObj.currentStrategy.name).collapse('show');\r\n                    $('#' + vm.currentStrategy.name).collapse('hide');\r\n                    vm.currentStrategy = vm.execObj.currentStrategy;\r\n                }\r\n            };\r\n\r\n            vm.outerStatement = function () {\r\n                vm.execObj = interpreter.execute(false);\r\n\r\n                checkType();\r\n\r\n            };\r\n            vm.innerStatement = function () {\r\n                vm.execObj = interpreter.execute(true);\r\n                checkType();\r\n            };\r\n\r\n            $scope.$on(\"setNeededFalse\", function (args) {\r\n                if(!args.targetScope.model) {\r\n                    vm.execObj.setNeeded = true;\r\n                } else {\r\n                    vm.execObj.setNeeded = false;\r\n                }\r\n            });\r\n\r\n            $scope.$on(\"blockAdd\", function (args, data) {\r\n                interpreter.addLoopBlocks(data.id, data.data);\r\n\r\n            })\r\n        });\r\n    });\r\n\r\n    myapp.directive('variableValue', function ($parse, $timeout) {\r\n        return {\r\n            template:\r\n            '<span ng-show=\"edit\">' +\r\n            '<textarea ng-show=\"isArray \" ng-blur=\"updateModel()\" ng-model=\"var\"></textarea>' +\r\n            '<input type=\"text\" ng-show=\"!isArray \" ng-blur=\"updateModel()\" ng-model=\"model\">' +\r\n            '</span>' +\r\n            '<div class=\"var-outer-border\" ng-show=\"!edit\" ng-attr-id=\"{{modelId}}\">' +\r\n            '<span class=\"showvars\" ng-show=\"isArray && allvar.length \" ng-class=\"dirtyArray.indexOf(myvar) >= 0 ? \\'dirty\\' : \\'\\'\" ng-repeat=\"myvar in allvar track by $index\">{{myvar}}</span>' +\r\n            '<span class=\"showvars\" ng-show=\"isArray && !allvar.length \" ng-click=\"changeEdit()\">nothing</span>' +\r\n            '<span class=\"showvars\" ng-show=\"!isArray && model.length \"  ng-click=\"changeEdit()\">{{model}}</span>' +\r\n            '<span class=\"showvars\" ng-show=\"!isArray && !model.length \" ng-click=\"changeEdit()\">nothing</span>' +\r\n            '<button style=\"margin-left:5px;\" ng-show=\"isArray && allvar.length \" title=\" Add more items\" href=\"#\" ng-click=\"changeEdit()\"><i class=\"glyphicon glyphicon-plus\"></i></button>' +\r\n            '</div>',\r\n            restrict: 'E',\r\n            scope: {\r\n                model: '=',\r\n                isArray: '=',\r\n                modelId: '=',\r\n                parentId: '=',\r\n                dirtyArray: '=',\r\n                prevVar: '=',\r\n                fadeIn: '='\r\n            },\r\n            link: function (scope, element, attrs, controller) {\r\n                scope.edit = false;\r\n                scope.var = '';\r\n                scope.id = null;\r\n                var listener = null;\r\n                scope.$on('EditMe', function (event, data) {\r\n                    if (scope.modelId == data) {\r\n                        scope.id = data;\r\n                        scope.changeEdit();\r\n                    }\r\n                });\r\n                if(scope.fadeIn !== undefined) {\r\n                    scope.$watch('fadeIn', function(value) {\r\n                        if(value) {\r\n                            $(element).fadeIn(1500);\r\n\r\n                        } else {\r\n                            $(element).fadeOut(1000);\r\n\r\n                        }\r\n                    });\r\n                }\r\n\r\n                if (scope.isArray) {\r\n                    scope.allvar = scope.model;\r\n                }\r\n\r\n\r\n                scope.changeEdit = function () {\r\n\r\n                    listener = scope.$watch('model', function (newval, oldval) {\r\n                        scope.$emit(\"setNeededFalse\");\r\n                    });\r\n                    scope.edit = !scope.edit;\r\n                    if (scope.isArray) {\r\n                        scope.var = scope.allvar.join(',');\r\n                        $timeout(function () {\r\n                            element[0].firstChild.firstChild.focus();\r\n                        }, 10);\r\n                    }\r\n                    else {\r\n                        $timeout(function () {\r\n                            element[0].firstChild.lastChild.focus();\r\n                        }, 10);\r\n                    }\r\n                };\r\n                scope.updateModel = function () {\r\n                    listener();\r\n                    scope.edit = !scope.edit;\r\n                    if (scope.isArray) {\r\n                        let arr = new Set(scope.var.split(','));\r\n\r\n                        scope.allvar = [];\r\n                        angular.forEach(arr, function (val, key) {\r\n                            val.trim().length ? scope.allvar.push(val.trim()) : null;\r\n                        });\r\n\r\n                        if(scope.dirtyArray.length > 0) {\r\n                            for(let i = 0; i< scope.dirtyArray.length; i++)\r\n                            {\r\n                                if(scope.dirtyArray[i] !== scope.allvar[i]){\r\n                                    scope.allvar = scope.prevVar;\r\n                                    alert(\" You are currently executing a loop. Adding elements are just allowed to the end of collection.  \");\r\n                                    return;\r\n                                }\r\n                            }\r\n                        }\r\n\r\n                        $parse(attrs.model).assign(scope.$parent, scope.allvar);\r\n                        if(scope.prevVar.length !== 0 && scope.prevVar.length < scope.allvar.length) {\r\n                            scope.$emit(\"blockAdd\", {\"data\": scope.allvar.slice(scope.prevVar.length, scope.allvar.length), \"id\": scope.parentId});\r\n                        }\r\n                        //console.log(scope.allvar.length);\r\n\r\n                        scope.prevVar = scope.allvar;\r\n                    }\r\n                    if (scope.id) {\r\n                        scope.$emit(\"setNeededFalse\");\r\n                    }\r\n                };\r\n\r\n            }\r\n        }\r\n    });\r\n\r\n}","'use strict';\r\n\r\nvar clone = require('clone');\r\n\r\n// https://stackoverflow.com/questions/586182/how-to-insert-an-item-into-an-array-at-a-specific-index\r\nArray.prototype.insert = function (index) {\r\n    index = Math.min(index, this.length);\r\n    arguments.length > 1\r\n    && this.splice.apply(this, [index, 0].concat([].pop.call(arguments)))\r\n    && this.insert.apply(this, arguments);\r\n    return this;\r\n};\r\n\r\nclass Interpreter {\r\n\r\n    constructor(strategies) {\r\n        this.executionStack = [];\r\n        this.historyBackward = [];\r\n        this.strategies = strategies;\r\n    }\r\n\r\n    init(currentStrategy) {\r\n        let currentExecutionContext = new FunctionExecContext(currentStrategy);\r\n        this.executionStack.push(currentExecutionContext);\r\n\r\n        return {\r\n            currentStatement: currentExecutionContext.pc,\r\n            currentStrategy: currentExecutionContext.strategy,\r\n            executionStack: this.executionStack,\r\n            activeLines: currentExecutionContext.activeLines,\r\n            //selectionNeeded: currentExecutionContext.pc.type === \"if\",\r\n            //setNeeded: currentExecutionContext.pc.type === 'set',\r\n            variables: currentExecutionContext.variables,\r\n        }\r\n    }\r\n\r\n    reset() {\r\n        this.executionStack = [];\r\n        this.historyBackward = [];\r\n    }\r\n\r\n    findStrategy(strategyname) {\r\n        return this.strategies.find(function (strategy) {\r\n            return strategy.name === strategyname;\r\n        })\r\n    }\r\n\r\n    addLoopBlocks(id, arr) {\r\n        let currentExecutionContext = this.executionStack[this.executionStack.length - 1];\r\n        if (currentExecutionContext.pc && currentExecutionContext.pc.type === 'foreach') return;// if foreach is still in the blocks, then it should work correctly\r\n        let loopStatement = this.findStatementById(id);\r\n        if (loopStatement !== null) {\r\n            let tempBlock = [];\r\n            let listVariable = loopStatement.list.replace(/'/g, '');\r\n            let counter = 0;\r\n            currentExecutionContext.variables.forEach(function (val, index, arr) {\r\n                if (val.name === listVariable) {\r\n                    counter = val.val.length - 1;\r\n                }\r\n            });\r\n            for (let num = 0; num < arr.length; num++) {\r\n                for (let i = loopStatement.statements.length - 1; i >= 0; i--) {\r\n                    tempBlock.unshift(clone(loopStatement.statements[i]));\r\n                }\r\n                // put the foreach statement length minus 1 times\r\n                if (num <= arr.length - 1) {\r\n                    let tempStatement = clone(loopStatement);\r\n                    tempStatement.type = \"loop\";\r\n                    tempStatement.counter = counter--;\r\n                    tempBlock.unshift(clone(tempStatement));\r\n                }\r\n            }\r\n            let allLoopStatements = currentExecutionContext.blocks.filter(function (val) {\r\n                return val.id.includes(id);\r\n            });\r\n            let objId = allLoopStatements.length ? allLoopStatements.pop().id : id;\r\n            // reverse to find the last index of statement\r\n            let index = currentExecutionContext.blocks.slice().reverse().findIndex(function (value, index, array) {\r\n                return value.id === objId;\r\n            });\r\n            index = index >= 0 ? currentExecutionContext.blocks.length - index : 0;\r\n            currentExecutionContext.blocks.insert(index, tempBlock);\r\n        }\r\n    }\r\n\r\n    findStatementById(id) {\r\n        let currentExecutionContext = this.executionStack[this.executionStack.length - 1];\r\n        // locate the statement by parsing the id string and find the index of the statement\r\n        let splitedIndex = id.split('-').splice(1);\r\n        if (splitedIndex.length > 0) {\r\n            let expression = \"currentExecutionContext.strategy\"; // first generate string for locating the statement by the indexes\r\n            splitedIndex.forEach(function (value, index, array) {\r\n                expression += \".statements[\" + value + \"]\"; // gradually append statements string with its index\r\n            });\r\n            // example => currentExecutionContext.strategy.statements[1].statements[2] and so on\r\n            // evaluate the string to return the object\r\n            return eval(expression); // eval is a javascript command to execute a string\r\n        }\r\n        // if it could not find the statement, return null\r\n        return null;\r\n    }\r\n\r\n    execute(branchTaken) {\r\n        if (this.executionStack[this.executionStack.length - 1] &&\r\n            this.executionStack[this.executionStack.length - 1].pc.type === 'end') return null;\r\n        if (this.executionStack.length) {\r\n            this.historyBackward.push(clone(this.executionStack)); // take a snapshot from our current executionStack to our history\r\n        } else {\r\n            return null;\r\n        }\r\n        let currentExecutionContext = this.executionStack.pop();\r\n        let nextType = currentExecutionContext.getNextStatement(currentExecutionContext.pc, branchTaken);\r\n        if (nextType === 'nothing' || nextType === 'return') return this.execute(branchTaken);\r\n        else if (nextType === null) return null;\r\n        else if (nextType === 'new') {\r\n            this.executionStack.push(currentExecutionContext);\r\n            let myArgs = null;\r\n            if (currentExecutionContext.pc.type === 'do') {\r\n                myArgs = currentExecutionContext.pc.call.arguments.map(function (val) {\r\n                    return val.replace(/'/g, '');\r\n                });\r\n            } else {\r\n                myArgs = currentExecutionContext.pc.query.arguments.map(function (val) {\r\n                    return val.replace(/'/g, '');\r\n                });\r\n            }\r\n            let args = [];\r\n            myArgs.forEach(function (value, index, array) {\r\n                //console.log(value);\r\n                let myvar = currentExecutionContext.variables.find(function (val) {\r\n                    //console.log(val);\r\n                    return val.name === value;\r\n                });\r\n                args.push(myvar);\r\n            });\r\n            console.log(\"ARGS\", args);\r\n\r\n            let strategy = this.findStrategy(currentExecutionContext.pc.type === 'do' ? currentExecutionContext.pc.call.name : currentExecutionContext.pc.query.name);\r\n            currentExecutionContext = new FunctionExecContext(strategy);\r\n            currentExecutionContext.variables.forEach(function (value, index, array) {\r\n                if (value.type === 'parameter') {\r\n                    value.val = args[index].val;\r\n                    //value.visible = true;\r\n                }\r\n            });\r\n        } else {\r\n            currentExecutionContext = nextType;\r\n        }\r\n\r\n        this.executionStack.push(currentExecutionContext);\r\n        return {\r\n            currentStatement: currentExecutionContext.pc,\r\n            currentStrategy: currentExecutionContext.strategy,\r\n            executionStack: this.executionStack,\r\n            activeLines: currentExecutionContext.activeLines,\r\n            selectionNeeded: (currentExecutionContext.pc.type === \"if\" || currentExecutionContext.pc.type === \"until\"),\r\n            setNeeded: currentExecutionContext.pc.type === 'set',\r\n            variables: currentExecutionContext.variables,\r\n            strategyChanged: nextType == 'new'\r\n        };\r\n\r\n    }\r\n\r\n    goBack() {\r\n        let stack = this.historyBackward.pop();\r\n        if (stack === undefined) return null;\r\n        this.executionStack = stack;\r\n        let currentExecutionContext = this.executionStack[this.executionStack.length - 1];\r\n        return {\r\n            currentStatement: currentExecutionContext.pc,\r\n            currentStrategy: currentExecutionContext.strategy,\r\n            executionStack: this.executionStack,\r\n            activeLines: currentExecutionContext.activeLines,\r\n            selectionNeeded: (currentExecutionContext.pc.type === \"if\" || currentExecutionContext.pc.type === \"until\"),\r\n            setNeeded: currentExecutionContext.pc.type === 'set',\r\n            variables: currentExecutionContext.variables,\r\n        };\r\n    }\r\n}\r\n\r\nvar globalCounter = {count: 0};\r\n\r\nclass FunctionExecContext {\r\n    constructor(currentStrategy) {\r\n        this.strategy = currentStrategy;\r\n        this.pc = this.strategy;\r\n        this.activeLines = [];\r\n        this.activeLines.push(this.strategy.id);\r\n        this.blocks = [];\r\n        this.blocks = clone(this.strategy.statements);\r\n        this.variables = [];\r\n        if (this.strategy.parameters !== undefined) {\r\n            this.strategy.parameters.forEach(function (currentVal, index, arr) {\r\n                currentVal = currentVal.replace(/'/g, '');\r\n                this.variables.push({\r\n                    \"id\": globalCounter.count++,\r\n                    \"name\": currentVal,\r\n                    \"val\": null,\r\n                    \"type\": \"parameter\",\r\n                    \"visible\": false,\r\n                });\r\n            }, this);\r\n        }\r\n        this.extractVariables(this.strategy.statements, globalCounter, this);\r\n        var uniq = [...new Set(this.variables)];\r\n        uniq.forEach(function (variable) {\r\n            console.log(\"var:   \" + variable.name);\r\n        });\r\n        this.callStack = [];\r\n    }\r\n\r\n\r\n    extractVariables(statements, counter, argThis) {\r\n        statements.forEach(function (currentVal, index, arr) {\r\n            if (currentVal.identifier) {\r\n                let identifier = currentVal.identifier.replace(/'/g, '');\r\n                var found = argThis.variables.some(function (el) {\r\n                    return el.name === identifier;\r\n                });\r\n                if (!found) {\r\n                    argThis.variables.push({\r\n                        \"id\": counter.count++,\r\n                        \"name\": identifier,\r\n                        \"val\": null,\r\n                        \"type\": \"identifier\",\r\n                        \"visible\": false,\r\n                    });\r\n                }\r\n            }\r\n            if (currentVal.type === 'do') {\r\n                if (currentVal.call.arguments) {\r\n                    currentVal.call.arguments.forEach(function (val, ind, array) {\r\n                        val = val.replace(/'/g, '');\r\n                        var found = argThis.variables.some(function (el) {\r\n                            return el.name === val;\r\n                        });\r\n                        if (!found) {\r\n                            argThis.variables.push({\r\n                                \"id\": counter.count++,\r\n                                \"name\": val,\r\n                                \"val\": null,\r\n                                \"type\": \"argument\",\r\n                                \"visible\": false,\r\n                            });\r\n                        }\r\n                    }, argThis);\r\n                }\r\n            }\r\n            if (currentVal.type === 'return') {\r\n                if (currentVal.query.arguments) {\r\n                    currentVal.query.arguments.forEach(function (val, ind, array) {\r\n                        val = val.replace(/'/g, '');\r\n                        var found = argThis.variables.some(function (el) {\r\n                            return el.name === val;\r\n                        });\r\n                        if (!found) {\r\n                            argThis.variables.push({\r\n                                \"id\": counter.count++,\r\n                                \"name\": val,\r\n                                \"val\": null,\r\n                                \"type\": \"argument\",\r\n                                \"visible\": false,\r\n                            });\r\n                        }\r\n                    }, argThis);\r\n                }\r\n            }\r\n            if (currentVal.type === \"foreach\") {\r\n                argThis.variables.forEach(function (val) {\r\n                    if (val.name === (currentVal.list.replace(/'/g, ''))) {\r\n                        val.val = [];\r\n                        val.parentId = currentVal.id;\r\n                        val.dirtyArray = [];\r\n                        val.prevVar = [];\r\n                    }\r\n                });\r\n            }\r\n            if (currentVal.statements) {\r\n                this.extractVariables(currentVal.statements, counter, argThis);\r\n            }\r\n        }, argThis);\r\n    }\r\n\r\n    getNextStatement(currentStatement, branchTaken) {\r\n        this.activeLines = [];\r\n        if (this.callStack.length) {\r\n            this.pc = this.callStack.pop();\r\n            if (this.pc.type === 'return') {\r\n                this.pc.type = 'end';\r\n            } else {\r\n                this.pc = this.blocks.shift();\r\n            }\r\n            this.activeLines.push(this.pc.id);\r\n            return this;\r\n        } else {\r\n            if (currentStatement.type === \"if\" && branchTaken) {\r\n                if (currentStatement.statements !== undefined && currentStatement.statements.length > 0) {\r\n                    for (let i = currentStatement.statements.length - 1; i >= 0; i--) {\r\n                        this.blocks.unshift(clone(currentStatement.statements[i]));\r\n                    }\r\n                }\r\n            } else if (currentStatement.type === \"until\" && branchTaken) {\r\n                if (currentStatement.statements !== undefined && currentStatement.statements.length > 0) {\r\n                    this.blocks.unshift(currentStatement);\r\n                    for (let i = currentStatement.statements.length - 1; i >= 0; i--) {\r\n                        this.blocks.unshift(clone(currentStatement.statements[i]));\r\n                    }\r\n                }\r\n            } else if (currentStatement.type === \"return\") {\r\n                if (currentStatement.query.type === \"call\") {\r\n                    this.callStack.push(this.pc);\r\n                    this.activeLines.push(this.pc.id);\r\n                    return 'new';\r\n                } else if (currentStatement.query.type === 'nothing') {\r\n                    this.activeLines.push(this.pc.id);\r\n                    return 'nothing';\r\n                } else {\r\n                    this.activeLines.push(this.pc.id);\r\n                    return 'return';\r\n                }\r\n            } else if (currentStatement.type === \"do\") {\r\n                if (currentStatement.call !== undefined) {\r\n                    this.callStack.push(this.pc);\r\n                    return 'new';\r\n                }\r\n            } else if (currentStatement.type === \"foreach\") {\r\n                if (currentStatement.statements !== undefined && currentStatement.statements.length > 0) {\r\n                    let loopCountVar = this.variables.find(function (val) {\r\n                        return val.name === currentStatement.list.replace(/'/g, '');\r\n                    });\r\n                    for (let num = 0, count = loopCountVar.val.length; num < loopCountVar.val.length; num++, count--) {\r\n                        for (let i = currentStatement.statements.length - 1; i >= 0; i--) {\r\n                            this.blocks.unshift(clone(currentStatement.statements[i]));\r\n                        }\r\n                        // put the foreach statement length minus 1 times\r\n                        if (num < loopCountVar.val.length - 1) {\r\n                            let tempStatement = clone(currentStatement);\r\n                            tempStatement.type = \"loop\";\r\n                            tempStatement.counter = count - 1;\r\n                            this.blocks.unshift(tempStatement);\r\n                        }\r\n                    }\r\n                }\r\n            } else {\r\n                // if (currentStatement.statements !== undefined && currentStatement.type != \"loop\")\r\n                //     this.blocks.unshift(clone(currentStatement.statements[0]));\r\n            }\r\n\r\n            if (this.blocks.length === 0) {\r\n                return 'nothing';\r\n            } else {\r\n                this.pc = this.blocks.shift();\r\n                this.activeLines.push(this.pc.id);\r\n                return this;\r\n            }\r\n\r\n        }\r\n    }\r\n}\r\n\r\nmodule.exports = {\r\n    Interpreter: Interpreter\r\n};\r\n","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n  lookup[i] = code[i]\n  revLookup[code.charCodeAt(i)] = i\n}\n\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction placeHoldersCount (b64) {\n  var len = b64.length\n  if (len % 4 > 0) {\n    throw new Error('Invalid string. Length must be a multiple of 4')\n  }\n\n  // the number of equal signs (place holders)\n  // if there are two placeholders, than the two characters before it\n  // represent one byte\n  // if there is only one, then the three characters before it represent 2 bytes\n  // this is just a cheap hack to not do indexOf twice\n  return b64[len - 2] === '=' ? 2 : b64[len - 1] === '=' ? 1 : 0\n}\n\nfunction byteLength (b64) {\n  // base64 is 4/3 + up to two characters of the original data\n  return (b64.length * 3 / 4) - placeHoldersCount(b64)\n}\n\nfunction toByteArray (b64) {\n  var i, l, tmp, placeHolders, arr\n  var len = b64.length\n  placeHolders = placeHoldersCount(b64)\n\n  arr = new Arr((len * 3 / 4) - placeHolders)\n\n  // if there are placeholders, only get up to the last complete 4 chars\n  l = placeHolders > 0 ? len - 4 : len\n\n  var L = 0\n\n  for (i = 0; i < l; i += 4) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 18) | (revLookup[b64.charCodeAt(i + 1)] << 12) | (revLookup[b64.charCodeAt(i + 2)] << 6) | revLookup[b64.charCodeAt(i + 3)]\n    arr[L++] = (tmp >> 16) & 0xFF\n    arr[L++] = (tmp >> 8) & 0xFF\n    arr[L++] = tmp & 0xFF\n  }\n\n  if (placeHolders === 2) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 2) | (revLookup[b64.charCodeAt(i + 1)] >> 4)\n    arr[L++] = tmp & 0xFF\n  } else if (placeHolders === 1) {\n    tmp = (revLookup[b64.charCodeAt(i)] << 10) | (revLookup[b64.charCodeAt(i + 1)] << 4) | (revLookup[b64.charCodeAt(i + 2)] >> 2)\n    arr[L++] = (tmp >> 8) & 0xFF\n    arr[L++] = tmp & 0xFF\n  }\n\n  return arr\n}\n\nfunction tripletToBase64 (num) {\n  return lookup[num >> 18 & 0x3F] + lookup[num >> 12 & 0x3F] + lookup[num >> 6 & 0x3F] + lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n  var tmp\n  var output = []\n  for (var i = start; i < end; i += 3) {\n    tmp = (uint8[i] << 16) + (uint8[i + 1] << 8) + (uint8[i + 2])\n    output.push(tripletToBase64(tmp))\n  }\n  return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n  var tmp\n  var len = uint8.length\n  var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n  var output = ''\n  var parts = []\n  var maxChunkLength = 16383 // must be multiple of 3\n\n  // go through the array every three bytes, we'll deal with trailing stuff later\n  for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n    parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n  }\n\n  // pad the end with zeros, but make sure to not forget the extra bytes\n  if (extraBytes === 1) {\n    tmp = uint8[len - 1]\n    output += lookup[tmp >> 2]\n    output += lookup[(tmp << 4) & 0x3F]\n    output += '=='\n  } else if (extraBytes === 2) {\n    tmp = (uint8[len - 2] << 8) + (uint8[len - 1])\n    output += lookup[tmp >> 10]\n    output += lookup[(tmp >> 4) & 0x3F]\n    output += lookup[(tmp << 2) & 0x3F]\n    output += '='\n  }\n\n  parts.push(output)\n\n  return parts.join('')\n}\n","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author   Feross Aboukhadijeh <feross@feross.org> <http://feross.org>\n * @license  MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nvar base64 = require('base64-js')\nvar ieee754 = require('ieee754')\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\nvar K_MAX_LENGTH = 0x7fffffff\nexports.kMaxLength = K_MAX_LENGTH\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n *   === true    Use Uint8Array implementation (fastest)\n *   === false   Print warning and recommend using `buffer` v4.x which has an Object\n *               implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n    typeof console.error === 'function') {\n  console.error(\n    'This browser lacks typed array (Uint8Array) support which is required by ' +\n    '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n  )\n}\n\nfunction typedArraySupport () {\n  // Can typed array instances can be augmented?\n  try {\n    var arr = new Uint8Array(1)\n    arr.__proto__ = {__proto__: Uint8Array.prototype, foo: function () { return 42 }}\n    return arr.foo() === 42\n  } catch (e) {\n    return false\n  }\n}\n\nfunction createBuffer (length) {\n  if (length > K_MAX_LENGTH) {\n    throw new RangeError('Invalid typed array length')\n  }\n  // Return an augmented `Uint8Array` instance\n  var buf = new Uint8Array(length)\n  buf.__proto__ = Buffer.prototype\n  return buf\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n  // Common case.\n  if (typeof arg === 'number') {\n    if (typeof encodingOrOffset === 'string') {\n      throw new Error(\n        'If encoding is specified then the first argument must be a string'\n      )\n    }\n    return allocUnsafe(arg)\n  }\n  return from(arg, encodingOrOffset, length)\n}\n\n// Fix subarray() in ES2016. See: https://github.com/feross/buffer/pull/97\nif (typeof Symbol !== 'undefined' && Symbol.species &&\n    Buffer[Symbol.species] === Buffer) {\n  Object.defineProperty(Buffer, Symbol.species, {\n    value: null,\n    configurable: true,\n    enumerable: false,\n    writable: false\n  })\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\nfunction from (value, encodingOrOffset, length) {\n  if (typeof value === 'number') {\n    throw new TypeError('\"value\" argument must not be a number')\n  }\n\n  if (isArrayBuffer(value)) {\n    return fromArrayBuffer(value, encodingOrOffset, length)\n  }\n\n  if (typeof value === 'string') {\n    return fromString(value, encodingOrOffset)\n  }\n\n  return fromObject(value)\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n  return from(value, encodingOrOffset, length)\n}\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nBuffer.prototype.__proto__ = Uint8Array.prototype\nBuffer.__proto__ = Uint8Array\n\nfunction assertSize (size) {\n  if (typeof size !== 'number') {\n    throw new TypeError('\"size\" argument must be a number')\n  } else if (size < 0) {\n    throw new RangeError('\"size\" argument must not be negative')\n  }\n}\n\nfunction alloc (size, fill, encoding) {\n  assertSize(size)\n  if (size <= 0) {\n    return createBuffer(size)\n  }\n  if (fill !== undefined) {\n    // Only pay attention to encoding if it's a string. This\n    // prevents accidentally sending in a number that would\n    // be interpretted as a start offset.\n    return typeof encoding === 'string'\n      ? createBuffer(size).fill(fill, encoding)\n      : createBuffer(size).fill(fill)\n  }\n  return createBuffer(size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n  return alloc(size, fill, encoding)\n}\n\nfunction allocUnsafe (size) {\n  assertSize(size)\n  return createBuffer(size < 0 ? 0 : checked(size) | 0)\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n  return allocUnsafe(size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n  return allocUnsafe(size)\n}\n\nfunction fromString (string, encoding) {\n  if (typeof encoding !== 'string' || encoding === '') {\n    encoding = 'utf8'\n  }\n\n  if (!Buffer.isEncoding(encoding)) {\n    throw new TypeError('\"encoding\" must be a valid string encoding')\n  }\n\n  var length = byteLength(string, encoding) | 0\n  var buf = createBuffer(length)\n\n  var actual = buf.write(string, encoding)\n\n  if (actual !== length) {\n    // Writing a hex string, for example, that contains invalid characters will\n    // cause everything after the first invalid character to be ignored. (e.g.\n    // 'abxxcd' will be treated as 'ab')\n    buf = buf.slice(0, actual)\n  }\n\n  return buf\n}\n\nfunction fromArrayLike (array) {\n  var length = array.length < 0 ? 0 : checked(array.length) | 0\n  var buf = createBuffer(length)\n  for (var i = 0; i < length; i += 1) {\n    buf[i] = array[i] & 255\n  }\n  return buf\n}\n\nfunction fromArrayBuffer (array, byteOffset, length) {\n  if (byteOffset < 0 || array.byteLength < byteOffset) {\n    throw new RangeError('\\'offset\\' is out of bounds')\n  }\n\n  if (array.byteLength < byteOffset + (length || 0)) {\n    throw new RangeError('\\'length\\' is out of bounds')\n  }\n\n  var buf\n  if (byteOffset === undefined && length === undefined) {\n    buf = new Uint8Array(array)\n  } else if (length === undefined) {\n    buf = new Uint8Array(array, byteOffset)\n  } else {\n    buf = new Uint8Array(array, byteOffset, length)\n  }\n\n  // Return an augmented `Uint8Array` instance\n  buf.__proto__ = Buffer.prototype\n  return buf\n}\n\nfunction fromObject (obj) {\n  if (Buffer.isBuffer(obj)) {\n    var len = checked(obj.length) | 0\n    var buf = createBuffer(len)\n\n    if (buf.length === 0) {\n      return buf\n    }\n\n    obj.copy(buf, 0, 0, len)\n    return buf\n  }\n\n  if (obj) {\n    if (isArrayBufferView(obj) || 'length' in obj) {\n      if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n        return createBuffer(0)\n      }\n      return fromArrayLike(obj)\n    }\n\n    if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n      return fromArrayLike(obj.data)\n    }\n  }\n\n  throw new TypeError('First argument must be a string, Buffer, ArrayBuffer, Array, or array-like object.')\n}\n\nfunction checked (length) {\n  // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n  // length is NaN (which is otherwise coerced to zero.)\n  if (length >= K_MAX_LENGTH) {\n    throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n                         'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n  }\n  return length | 0\n}\n\nfunction SlowBuffer (length) {\n  if (+length != length) { // eslint-disable-line eqeqeq\n    length = 0\n  }\n  return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n  return b != null && b._isBuffer === true\n}\n\nBuffer.compare = function compare (a, b) {\n  if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n    throw new TypeError('Arguments must be Buffers')\n  }\n\n  if (a === b) return 0\n\n  var x = a.length\n  var y = b.length\n\n  for (var i = 0, len = Math.min(x, y); i < len; ++i) {\n    if (a[i] !== b[i]) {\n      x = a[i]\n      y = b[i]\n      break\n    }\n  }\n\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n  switch (String(encoding).toLowerCase()) {\n    case 'hex':\n    case 'utf8':\n    case 'utf-8':\n    case 'ascii':\n    case 'latin1':\n    case 'binary':\n    case 'base64':\n    case 'ucs2':\n    case 'ucs-2':\n    case 'utf16le':\n    case 'utf-16le':\n      return true\n    default:\n      return false\n  }\n}\n\nBuffer.concat = function concat (list, length) {\n  if (!Array.isArray(list)) {\n    throw new TypeError('\"list\" argument must be an Array of Buffers')\n  }\n\n  if (list.length === 0) {\n    return Buffer.alloc(0)\n  }\n\n  var i\n  if (length === undefined) {\n    length = 0\n    for (i = 0; i < list.length; ++i) {\n      length += list[i].length\n    }\n  }\n\n  var buffer = Buffer.allocUnsafe(length)\n  var pos = 0\n  for (i = 0; i < list.length; ++i) {\n    var buf = list[i]\n    if (!Buffer.isBuffer(buf)) {\n      throw new TypeError('\"list\" argument must be an Array of Buffers')\n    }\n    buf.copy(buffer, pos)\n    pos += buf.length\n  }\n  return buffer\n}\n\nfunction byteLength (string, encoding) {\n  if (Buffer.isBuffer(string)) {\n    return string.length\n  }\n  if (isArrayBufferView(string) || isArrayBuffer(string)) {\n    return string.byteLength\n  }\n  if (typeof string !== 'string') {\n    string = '' + string\n  }\n\n  var len = string.length\n  if (len === 0) return 0\n\n  // Use a for loop to avoid recursion\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'ascii':\n      case 'latin1':\n      case 'binary':\n        return len\n      case 'utf8':\n      case 'utf-8':\n      case undefined:\n        return utf8ToBytes(string).length\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return len * 2\n      case 'hex':\n        return len >>> 1\n      case 'base64':\n        return base64ToBytes(string).length\n      default:\n        if (loweredCase) return utf8ToBytes(string).length // assume utf8\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n  var loweredCase = false\n\n  // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n  // property of a typed array.\n\n  // This behaves neither like String nor Uint8Array in that we set start/end\n  // to their upper/lower bounds if the value passed is out of range.\n  // undefined is handled specially as per ECMA-262 6th Edition,\n  // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n  if (start === undefined || start < 0) {\n    start = 0\n  }\n  // Return early if start > this.length. Done here to prevent potential uint32\n  // coercion fail below.\n  if (start > this.length) {\n    return ''\n  }\n\n  if (end === undefined || end > this.length) {\n    end = this.length\n  }\n\n  if (end <= 0) {\n    return ''\n  }\n\n  // Force coersion to uint32. This will also coerce falsey/NaN values to 0.\n  end >>>= 0\n  start >>>= 0\n\n  if (end <= start) {\n    return ''\n  }\n\n  if (!encoding) encoding = 'utf8'\n\n  while (true) {\n    switch (encoding) {\n      case 'hex':\n        return hexSlice(this, start, end)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Slice(this, start, end)\n\n      case 'ascii':\n        return asciiSlice(this, start, end)\n\n      case 'latin1':\n      case 'binary':\n        return latin1Slice(this, start, end)\n\n      case 'base64':\n        return base64Slice(this, start, end)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return utf16leSlice(this, start, end)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = (encoding + '').toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\n// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n  var i = b[n]\n  b[n] = b[m]\n  b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n  var len = this.length\n  if (len % 2 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 16-bits')\n  }\n  for (var i = 0; i < len; i += 2) {\n    swap(this, i, i + 1)\n  }\n  return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n  var len = this.length\n  if (len % 4 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 32-bits')\n  }\n  for (var i = 0; i < len; i += 4) {\n    swap(this, i, i + 3)\n    swap(this, i + 1, i + 2)\n  }\n  return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n  var len = this.length\n  if (len % 8 !== 0) {\n    throw new RangeError('Buffer size must be a multiple of 64-bits')\n  }\n  for (var i = 0; i < len; i += 8) {\n    swap(this, i, i + 7)\n    swap(this, i + 1, i + 6)\n    swap(this, i + 2, i + 5)\n    swap(this, i + 3, i + 4)\n  }\n  return this\n}\n\nBuffer.prototype.toString = function toString () {\n  var length = this.length\n  if (length === 0) return ''\n  if (arguments.length === 0) return utf8Slice(this, 0, length)\n  return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.equals = function equals (b) {\n  if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n  if (this === b) return true\n  return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n  var str = ''\n  var max = exports.INSPECT_MAX_BYTES\n  if (this.length > 0) {\n    str = this.toString('hex', 0, max).match(/.{2}/g).join(' ')\n    if (this.length > max) str += ' ... '\n  }\n  return '<Buffer ' + str + '>'\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n  if (!Buffer.isBuffer(target)) {\n    throw new TypeError('Argument must be a Buffer')\n  }\n\n  if (start === undefined) {\n    start = 0\n  }\n  if (end === undefined) {\n    end = target ? target.length : 0\n  }\n  if (thisStart === undefined) {\n    thisStart = 0\n  }\n  if (thisEnd === undefined) {\n    thisEnd = this.length\n  }\n\n  if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n    throw new RangeError('out of range index')\n  }\n\n  if (thisStart >= thisEnd && start >= end) {\n    return 0\n  }\n  if (thisStart >= thisEnd) {\n    return -1\n  }\n  if (start >= end) {\n    return 1\n  }\n\n  start >>>= 0\n  end >>>= 0\n  thisStart >>>= 0\n  thisEnd >>>= 0\n\n  if (this === target) return 0\n\n  var x = thisEnd - thisStart\n  var y = end - start\n  var len = Math.min(x, y)\n\n  var thisCopy = this.slice(thisStart, thisEnd)\n  var targetCopy = target.slice(start, end)\n\n  for (var i = 0; i < len; ++i) {\n    if (thisCopy[i] !== targetCopy[i]) {\n      x = thisCopy[i]\n      y = targetCopy[i]\n      break\n    }\n  }\n\n  if (x < y) return -1\n  if (y < x) return 1\n  return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n  // Empty buffer means no match\n  if (buffer.length === 0) return -1\n\n  // Normalize byteOffset\n  if (typeof byteOffset === 'string') {\n    encoding = byteOffset\n    byteOffset = 0\n  } else if (byteOffset > 0x7fffffff) {\n    byteOffset = 0x7fffffff\n  } else if (byteOffset < -0x80000000) {\n    byteOffset = -0x80000000\n  }\n  byteOffset = +byteOffset  // Coerce to Number.\n  if (numberIsNaN(byteOffset)) {\n    // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n    byteOffset = dir ? 0 : (buffer.length - 1)\n  }\n\n  // Normalize byteOffset: negative offsets start from the end of the buffer\n  if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n  if (byteOffset >= buffer.length) {\n    if (dir) return -1\n    else byteOffset = buffer.length - 1\n  } else if (byteOffset < 0) {\n    if (dir) byteOffset = 0\n    else return -1\n  }\n\n  // Normalize val\n  if (typeof val === 'string') {\n    val = Buffer.from(val, encoding)\n  }\n\n  // Finally, search either indexOf (if dir is true) or lastIndexOf\n  if (Buffer.isBuffer(val)) {\n    // Special case: looking for empty string/buffer always fails\n    if (val.length === 0) {\n      return -1\n    }\n    return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n  } else if (typeof val === 'number') {\n    val = val & 0xFF // Search for a byte value [0-255]\n    if (typeof Uint8Array.prototype.indexOf === 'function') {\n      if (dir) {\n        return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n      } else {\n        return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n      }\n    }\n    return arrayIndexOf(buffer, [ val ], byteOffset, encoding, dir)\n  }\n\n  throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n  var indexSize = 1\n  var arrLength = arr.length\n  var valLength = val.length\n\n  if (encoding !== undefined) {\n    encoding = String(encoding).toLowerCase()\n    if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n        encoding === 'utf16le' || encoding === 'utf-16le') {\n      if (arr.length < 2 || val.length < 2) {\n        return -1\n      }\n      indexSize = 2\n      arrLength /= 2\n      valLength /= 2\n      byteOffset /= 2\n    }\n  }\n\n  function read (buf, i) {\n    if (indexSize === 1) {\n      return buf[i]\n    } else {\n      return buf.readUInt16BE(i * indexSize)\n    }\n  }\n\n  var i\n  if (dir) {\n    var foundIndex = -1\n    for (i = byteOffset; i < arrLength; i++) {\n      if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n        if (foundIndex === -1) foundIndex = i\n        if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n      } else {\n        if (foundIndex !== -1) i -= i - foundIndex\n        foundIndex = -1\n      }\n    }\n  } else {\n    if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n    for (i = byteOffset; i >= 0; i--) {\n      var found = true\n      for (var j = 0; j < valLength; j++) {\n        if (read(arr, i + j) !== read(val, j)) {\n          found = false\n          break\n        }\n      }\n      if (found) return i\n    }\n  }\n\n  return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n  return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n  return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n  return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n  offset = Number(offset) || 0\n  var remaining = buf.length - offset\n  if (!length) {\n    length = remaining\n  } else {\n    length = Number(length)\n    if (length > remaining) {\n      length = remaining\n    }\n  }\n\n  // must be an even number of digits\n  var strLen = string.length\n  if (strLen % 2 !== 0) throw new TypeError('Invalid hex string')\n\n  if (length > strLen / 2) {\n    length = strLen / 2\n  }\n  for (var i = 0; i < length; ++i) {\n    var parsed = parseInt(string.substr(i * 2, 2), 16)\n    if (numberIsNaN(parsed)) return i\n    buf[offset + i] = parsed\n  }\n  return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n  return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n  return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction latin1Write (buf, string, offset, length) {\n  return asciiWrite(buf, string, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n  return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n  return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n  // Buffer#write(string)\n  if (offset === undefined) {\n    encoding = 'utf8'\n    length = this.length\n    offset = 0\n  // Buffer#write(string, encoding)\n  } else if (length === undefined && typeof offset === 'string') {\n    encoding = offset\n    length = this.length\n    offset = 0\n  // Buffer#write(string, offset[, length][, encoding])\n  } else if (isFinite(offset)) {\n    offset = offset >>> 0\n    if (isFinite(length)) {\n      length = length >>> 0\n      if (encoding === undefined) encoding = 'utf8'\n    } else {\n      encoding = length\n      length = undefined\n    }\n  } else {\n    throw new Error(\n      'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n    )\n  }\n\n  var remaining = this.length - offset\n  if (length === undefined || length > remaining) length = remaining\n\n  if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n    throw new RangeError('Attempt to write outside buffer bounds')\n  }\n\n  if (!encoding) encoding = 'utf8'\n\n  var loweredCase = false\n  for (;;) {\n    switch (encoding) {\n      case 'hex':\n        return hexWrite(this, string, offset, length)\n\n      case 'utf8':\n      case 'utf-8':\n        return utf8Write(this, string, offset, length)\n\n      case 'ascii':\n        return asciiWrite(this, string, offset, length)\n\n      case 'latin1':\n      case 'binary':\n        return latin1Write(this, string, offset, length)\n\n      case 'base64':\n        // Warning: maxLength not taken into account in base64Write\n        return base64Write(this, string, offset, length)\n\n      case 'ucs2':\n      case 'ucs-2':\n      case 'utf16le':\n      case 'utf-16le':\n        return ucs2Write(this, string, offset, length)\n\n      default:\n        if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n        encoding = ('' + encoding).toLowerCase()\n        loweredCase = true\n    }\n  }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n  return {\n    type: 'Buffer',\n    data: Array.prototype.slice.call(this._arr || this, 0)\n  }\n}\n\nfunction base64Slice (buf, start, end) {\n  if (start === 0 && end === buf.length) {\n    return base64.fromByteArray(buf)\n  } else {\n    return base64.fromByteArray(buf.slice(start, end))\n  }\n}\n\nfunction utf8Slice (buf, start, end) {\n  end = Math.min(buf.length, end)\n  var res = []\n\n  var i = start\n  while (i < end) {\n    var firstByte = buf[i]\n    var codePoint = null\n    var bytesPerSequence = (firstByte > 0xEF) ? 4\n      : (firstByte > 0xDF) ? 3\n      : (firstByte > 0xBF) ? 2\n      : 1\n\n    if (i + bytesPerSequence <= end) {\n      var secondByte, thirdByte, fourthByte, tempCodePoint\n\n      switch (bytesPerSequence) {\n        case 1:\n          if (firstByte < 0x80) {\n            codePoint = firstByte\n          }\n          break\n        case 2:\n          secondByte = buf[i + 1]\n          if ((secondByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n            if (tempCodePoint > 0x7F) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 3:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n            if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n              codePoint = tempCodePoint\n            }\n          }\n          break\n        case 4:\n          secondByte = buf[i + 1]\n          thirdByte = buf[i + 2]\n          fourthByte = buf[i + 3]\n          if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n            tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n            if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n              codePoint = tempCodePoint\n            }\n          }\n      }\n    }\n\n    if (codePoint === null) {\n      // we did not generate a valid codePoint so insert a\n      // replacement char (U+FFFD) and advance only 1 byte\n      codePoint = 0xFFFD\n      bytesPerSequence = 1\n    } else if (codePoint > 0xFFFF) {\n      // encode to utf16 (surrogate pair dance)\n      codePoint -= 0x10000\n      res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n      codePoint = 0xDC00 | codePoint & 0x3FF\n    }\n\n    res.push(codePoint)\n    i += bytesPerSequence\n  }\n\n  return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nvar MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n  var len = codePoints.length\n  if (len <= MAX_ARGUMENTS_LENGTH) {\n    return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n  }\n\n  // Decode in chunks to avoid \"call stack size exceeded\".\n  var res = ''\n  var i = 0\n  while (i < len) {\n    res += String.fromCharCode.apply(\n      String,\n      codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n    )\n  }\n  return res\n}\n\nfunction asciiSlice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; ++i) {\n    ret += String.fromCharCode(buf[i] & 0x7F)\n  }\n  return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n  var ret = ''\n  end = Math.min(buf.length, end)\n\n  for (var i = start; i < end; ++i) {\n    ret += String.fromCharCode(buf[i])\n  }\n  return ret\n}\n\nfunction hexSlice (buf, start, end) {\n  var len = buf.length\n\n  if (!start || start < 0) start = 0\n  if (!end || end < 0 || end > len) end = len\n\n  var out = ''\n  for (var i = start; i < end; ++i) {\n    out += toHex(buf[i])\n  }\n  return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n  var bytes = buf.slice(start, end)\n  var res = ''\n  for (var i = 0; i < bytes.length; i += 2) {\n    res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256))\n  }\n  return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n  var len = this.length\n  start = ~~start\n  end = end === undefined ? len : ~~end\n\n  if (start < 0) {\n    start += len\n    if (start < 0) start = 0\n  } else if (start > len) {\n    start = len\n  }\n\n  if (end < 0) {\n    end += len\n    if (end < 0) end = 0\n  } else if (end > len) {\n    end = len\n  }\n\n  if (end < start) end = start\n\n  var newBuf = this.subarray(start, end)\n  // Return an augmented `Uint8Array` instance\n  newBuf.__proto__ = Buffer.prototype\n  return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n  if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n  if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n  offset = offset >>> 0\n  byteLength = byteLength >>> 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n  offset = offset >>> 0\n  byteLength = byteLength >>> 0\n  if (!noAssert) {\n    checkOffset(offset, byteLength, this.length)\n  }\n\n  var val = this[offset + --byteLength]\n  var mul = 1\n  while (byteLength > 0 && (mul *= 0x100)) {\n    val += this[offset + --byteLength] * mul\n  }\n\n  return val\n}\n\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  return this[offset]\n}\n\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return ((this[offset]) |\n      (this[offset + 1] << 8) |\n      (this[offset + 2] << 16)) +\n      (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset] * 0x1000000) +\n    ((this[offset + 1] << 16) |\n    (this[offset + 2] << 8) |\n    this[offset + 3])\n}\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n  offset = offset >>> 0\n  byteLength = byteLength >>> 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var val = this[offset]\n  var mul = 1\n  var i = 0\n  while (++i < byteLength && (mul *= 0x100)) {\n    val += this[offset + i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n  offset = offset >>> 0\n  byteLength = byteLength >>> 0\n  if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n  var i = byteLength\n  var mul = 1\n  var val = this[offset + --i]\n  while (i > 0 && (mul *= 0x100)) {\n    val += this[offset + --i] * mul\n  }\n  mul *= 0x80\n\n  if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n  return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 1, this.length)\n  if (!(this[offset] & 0x80)) return (this[offset])\n  return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  var val = this[offset] | (this[offset + 1] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 2, this.length)\n  var val = this[offset + 1] | (this[offset] << 8)\n  return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset]) |\n    (this[offset + 1] << 8) |\n    (this[offset + 2] << 16) |\n    (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 4, this.length)\n\n  return (this[offset] << 24) |\n    (this[offset + 1] << 16) |\n    (this[offset + 2] << 8) |\n    (this[offset + 3])\n}\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 4, this.length)\n  return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n  offset = offset >>> 0\n  if (!noAssert) checkOffset(offset, 8, this.length)\n  return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n  if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n  if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n  if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  byteLength = byteLength >>> 0\n  if (!noAssert) {\n    var maxBytes = Math.pow(2, 8 * byteLength) - 1\n    checkInt(this, value, offset, byteLength, maxBytes, 0)\n  }\n\n  var mul = 1\n  var i = 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  byteLength = byteLength >>> 0\n  if (!noAssert) {\n    var maxBytes = Math.pow(2, 8 * byteLength) - 1\n    checkInt(this, value, offset, byteLength, maxBytes, 0)\n  }\n\n  var i = byteLength - 1\n  var mul = 1\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    this[offset + i] = (value / mul) & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n  this[offset] = (value & 0xff)\n  return offset + 1\n}\n\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  this[offset] = (value & 0xff)\n  this[offset + 1] = (value >>> 8)\n  return offset + 2\n}\n\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n  this[offset] = (value >>> 8)\n  this[offset + 1] = (value & 0xff)\n  return offset + 2\n}\n\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n  this[offset + 3] = (value >>> 24)\n  this[offset + 2] = (value >>> 16)\n  this[offset + 1] = (value >>> 8)\n  this[offset] = (value & 0xff)\n  return offset + 4\n}\n\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n  this[offset] = (value >>> 24)\n  this[offset + 1] = (value >>> 16)\n  this[offset + 2] = (value >>> 8)\n  this[offset + 3] = (value & 0xff)\n  return offset + 4\n}\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) {\n    var limit = Math.pow(2, (8 * byteLength) - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = 0\n  var mul = 1\n  var sub = 0\n  this[offset] = value & 0xFF\n  while (++i < byteLength && (mul *= 0x100)) {\n    if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n      sub = 1\n    }\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) {\n    var limit = Math.pow(2, (8 * byteLength) - 1)\n\n    checkInt(this, value, offset, byteLength, limit - 1, -limit)\n  }\n\n  var i = byteLength - 1\n  var mul = 1\n  var sub = 0\n  this[offset + i] = value & 0xFF\n  while (--i >= 0 && (mul *= 0x100)) {\n    if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n      sub = 1\n    }\n    this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n  }\n\n  return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n  if (value < 0) value = 0xff + value + 1\n  this[offset] = (value & 0xff)\n  return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  this[offset] = (value & 0xff)\n  this[offset + 1] = (value >>> 8)\n  return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n  this[offset] = (value >>> 8)\n  this[offset + 1] = (value & 0xff)\n  return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  this[offset] = (value & 0xff)\n  this[offset + 1] = (value >>> 8)\n  this[offset + 2] = (value >>> 16)\n  this[offset + 3] = (value >>> 24)\n  return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n  if (value < 0) value = 0xffffffff + value + 1\n  this[offset] = (value >>> 24)\n  this[offset + 1] = (value >>> 16)\n  this[offset + 2] = (value >>> 8)\n  this[offset + 3] = (value & 0xff)\n  return offset + 4\n}\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n  if (offset + ext > buf.length) throw new RangeError('Index out of range')\n  if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) {\n    checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n  }\n  ieee754.write(buf, value, offset, littleEndian, 23, 4)\n  return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n  return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n  value = +value\n  offset = offset >>> 0\n  if (!noAssert) {\n    checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n  }\n  ieee754.write(buf, value, offset, littleEndian, 52, 8)\n  return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n  return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n  if (!start) start = 0\n  if (!end && end !== 0) end = this.length\n  if (targetStart >= target.length) targetStart = target.length\n  if (!targetStart) targetStart = 0\n  if (end > 0 && end < start) end = start\n\n  // Copy 0 bytes; we're done\n  if (end === start) return 0\n  if (target.length === 0 || this.length === 0) return 0\n\n  // Fatal error conditions\n  if (targetStart < 0) {\n    throw new RangeError('targetStart out of bounds')\n  }\n  if (start < 0 || start >= this.length) throw new RangeError('sourceStart out of bounds')\n  if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n  // Are we oob?\n  if (end > this.length) end = this.length\n  if (target.length - targetStart < end - start) {\n    end = target.length - targetStart + start\n  }\n\n  var len = end - start\n  var i\n\n  if (this === target && start < targetStart && targetStart < end) {\n    // descending copy from end\n    for (i = len - 1; i >= 0; --i) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else if (len < 1000) {\n    // ascending copy from start\n    for (i = 0; i < len; ++i) {\n      target[i + targetStart] = this[i + start]\n    }\n  } else {\n    Uint8Array.prototype.set.call(\n      target,\n      this.subarray(start, start + len),\n      targetStart\n    )\n  }\n\n  return len\n}\n\n// Usage:\n//    buffer.fill(number[, offset[, end]])\n//    buffer.fill(buffer[, offset[, end]])\n//    buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n  // Handle string cases:\n  if (typeof val === 'string') {\n    if (typeof start === 'string') {\n      encoding = start\n      start = 0\n      end = this.length\n    } else if (typeof end === 'string') {\n      encoding = end\n      end = this.length\n    }\n    if (val.length === 1) {\n      var code = val.charCodeAt(0)\n      if (code < 256) {\n        val = code\n      }\n    }\n    if (encoding !== undefined && typeof encoding !== 'string') {\n      throw new TypeError('encoding must be a string')\n    }\n    if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n      throw new TypeError('Unknown encoding: ' + encoding)\n    }\n  } else if (typeof val === 'number') {\n    val = val & 255\n  }\n\n  // Invalid ranges are not set to a default, so can range check early.\n  if (start < 0 || this.length < start || this.length < end) {\n    throw new RangeError('Out of range index')\n  }\n\n  if (end <= start) {\n    return this\n  }\n\n  start = start >>> 0\n  end = end === undefined ? this.length : end >>> 0\n\n  if (!val) val = 0\n\n  var i\n  if (typeof val === 'number') {\n    for (i = start; i < end; ++i) {\n      this[i] = val\n    }\n  } else {\n    var bytes = Buffer.isBuffer(val)\n      ? val\n      : new Buffer(val, encoding)\n    var len = bytes.length\n    for (i = 0; i < end - start; ++i) {\n      this[i + start] = bytes[i % len]\n    }\n  }\n\n  return this\n}\n\n// HELPER FUNCTIONS\n// ================\n\nvar INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n  // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n  str = str.trim().replace(INVALID_BASE64_RE, '')\n  // Node converts strings with length < 2 to ''\n  if (str.length < 2) return ''\n  // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n  while (str.length % 4 !== 0) {\n    str = str + '='\n  }\n  return str\n}\n\nfunction toHex (n) {\n  if (n < 16) return '0' + n.toString(16)\n  return n.toString(16)\n}\n\nfunction utf8ToBytes (string, units) {\n  units = units || Infinity\n  var codePoint\n  var length = string.length\n  var leadSurrogate = null\n  var bytes = []\n\n  for (var i = 0; i < length; ++i) {\n    codePoint = string.charCodeAt(i)\n\n    // is surrogate component\n    if (codePoint > 0xD7FF && codePoint < 0xE000) {\n      // last char was a lead\n      if (!leadSurrogate) {\n        // no lead yet\n        if (codePoint > 0xDBFF) {\n          // unexpected trail\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        } else if (i + 1 === length) {\n          // unpaired lead\n          if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n          continue\n        }\n\n        // valid lead\n        leadSurrogate = codePoint\n\n        continue\n      }\n\n      // 2 leads in a row\n      if (codePoint < 0xDC00) {\n        if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n        leadSurrogate = codePoint\n        continue\n      }\n\n      // valid surrogate pair\n      codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n    } else if (leadSurrogate) {\n      // valid bmp char, but last char was a lead\n      if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n    }\n\n    leadSurrogate = null\n\n    // encode utf8\n    if (codePoint < 0x80) {\n      if ((units -= 1) < 0) break\n      bytes.push(codePoint)\n    } else if (codePoint < 0x800) {\n      if ((units -= 2) < 0) break\n      bytes.push(\n        codePoint >> 0x6 | 0xC0,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x10000) {\n      if ((units -= 3) < 0) break\n      bytes.push(\n        codePoint >> 0xC | 0xE0,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else if (codePoint < 0x110000) {\n      if ((units -= 4) < 0) break\n      bytes.push(\n        codePoint >> 0x12 | 0xF0,\n        codePoint >> 0xC & 0x3F | 0x80,\n        codePoint >> 0x6 & 0x3F | 0x80,\n        codePoint & 0x3F | 0x80\n      )\n    } else {\n      throw new Error('Invalid code point')\n    }\n  }\n\n  return bytes\n}\n\nfunction asciiToBytes (str) {\n  var byteArray = []\n  for (var i = 0; i < str.length; ++i) {\n    // Node's code seems to be doing this and not & 0x7F..\n    byteArray.push(str.charCodeAt(i) & 0xFF)\n  }\n  return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n  var c, hi, lo\n  var byteArray = []\n  for (var i = 0; i < str.length; ++i) {\n    if ((units -= 2) < 0) break\n\n    c = str.charCodeAt(i)\n    hi = c >> 8\n    lo = c % 256\n    byteArray.push(lo)\n    byteArray.push(hi)\n  }\n\n  return byteArray\n}\n\nfunction base64ToBytes (str) {\n  return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n  for (var i = 0; i < length; ++i) {\n    if ((i + offset >= dst.length) || (i >= src.length)) break\n    dst[i + offset] = src[i]\n  }\n  return i\n}\n\n// ArrayBuffers from another context (i.e. an iframe) do not pass the `instanceof` check\n// but they should be treated as valid. See: https://github.com/feross/buffer/issues/166\nfunction isArrayBuffer (obj) {\n  return obj instanceof ArrayBuffer ||\n    (obj != null && obj.constructor != null && obj.constructor.name === 'ArrayBuffer' &&\n      typeof obj.byteLength === 'number')\n}\n\n// Node 0.10 supports `ArrayBuffer` but lacks `ArrayBuffer.isView`\nfunction isArrayBufferView (obj) {\n  return (typeof ArrayBuffer.isView === 'function') && ArrayBuffer.isView(obj)\n}\n\nfunction numberIsNaN (obj) {\n  return obj !== obj // eslint-disable-line no-self-compare\n}\n","var clone = (function() {\n'use strict';\n\nfunction _instanceof(obj, type) {\n  return type != null && obj instanceof type;\n}\n\nvar nativeMap;\ntry {\n  nativeMap = Map;\n} catch(_) {\n  // maybe a reference error because no `Map`. Give it a dummy value that no\n  // value will ever be an instanceof.\n  nativeMap = function() {};\n}\n\nvar nativeSet;\ntry {\n  nativeSet = Set;\n} catch(_) {\n  nativeSet = function() {};\n}\n\nvar nativePromise;\ntry {\n  nativePromise = Promise;\n} catch(_) {\n  nativePromise = function() {};\n}\n\n/**\n * Clones (copies) an Object using deep copying.\n *\n * This function supports circular references by default, but if you are certain\n * there are no circular references in your object, you can save some CPU time\n * by calling clone(obj, false).\n *\n * Caution: if `circular` is false and `parent` contains circular references,\n * your program may enter an infinite loop and crash.\n *\n * @param `parent` - the object to be cloned\n * @param `circular` - set to true if the object to be cloned may contain\n *    circular references. (optional - true by default)\n * @param `depth` - set to a number if the object is only to be cloned to\n *    a particular depth. (optional - defaults to Infinity)\n * @param `prototype` - sets the prototype to be used when cloning an object.\n *    (optional - defaults to parent prototype).\n * @param `includeNonEnumerable` - set to true if the non-enumerable properties\n *    should be cloned as well. Non-enumerable properties on the prototype\n *    chain will be ignored. (optional - false by default)\n*/\nfunction clone(parent, circular, depth, prototype, includeNonEnumerable) {\n  if (typeof circular === 'object') {\n    depth = circular.depth;\n    prototype = circular.prototype;\n    includeNonEnumerable = circular.includeNonEnumerable;\n    circular = circular.circular;\n  }\n  // maintain two arrays for circular references, where corresponding parents\n  // and children have the same index\n  var allParents = [];\n  var allChildren = [];\n\n  var useBuffer = typeof Buffer != 'undefined';\n\n  if (typeof circular == 'undefined')\n    circular = true;\n\n  if (typeof depth == 'undefined')\n    depth = Infinity;\n\n  // recurse this function so we don't reset allParents and allChildren\n  function _clone(parent, depth) {\n    // cloning null always returns null\n    if (parent === null)\n      return null;\n\n    if (depth === 0)\n      return parent;\n\n    var child;\n    var proto;\n    if (typeof parent != 'object') {\n      return parent;\n    }\n\n    if (_instanceof(parent, nativeMap)) {\n      child = new nativeMap();\n    } else if (_instanceof(parent, nativeSet)) {\n      child = new nativeSet();\n    } else if (_instanceof(parent, nativePromise)) {\n      child = new nativePromise(function (resolve, reject) {\n        parent.then(function(value) {\n          resolve(_clone(value, depth - 1));\n        }, function(err) {\n          reject(_clone(err, depth - 1));\n        });\n      });\n    } else if (clone.__isArray(parent)) {\n      child = [];\n    } else if (clone.__isRegExp(parent)) {\n      child = new RegExp(parent.source, __getRegExpFlags(parent));\n      if (parent.lastIndex) child.lastIndex = parent.lastIndex;\n    } else if (clone.__isDate(parent)) {\n      child = new Date(parent.getTime());\n    } else if (useBuffer && Buffer.isBuffer(parent)) {\n      child = new Buffer(parent.length);\n      parent.copy(child);\n      return child;\n    } else if (_instanceof(parent, Error)) {\n      child = Object.create(parent);\n    } else {\n      if (typeof prototype == 'undefined') {\n        proto = Object.getPrototypeOf(parent);\n        child = Object.create(proto);\n      }\n      else {\n        child = Object.create(prototype);\n        proto = prototype;\n      }\n    }\n\n    if (circular) {\n      var index = allParents.indexOf(parent);\n\n      if (index != -1) {\n        return allChildren[index];\n      }\n      allParents.push(parent);\n      allChildren.push(child);\n    }\n\n    if (_instanceof(parent, nativeMap)) {\n      parent.forEach(function(value, key) {\n        var keyChild = _clone(key, depth - 1);\n        var valueChild = _clone(value, depth - 1);\n        child.set(keyChild, valueChild);\n      });\n    }\n    if (_instanceof(parent, nativeSet)) {\n      parent.forEach(function(value) {\n        var entryChild = _clone(value, depth - 1);\n        child.add(entryChild);\n      });\n    }\n\n    for (var i in parent) {\n      var attrs;\n      if (proto) {\n        attrs = Object.getOwnPropertyDescriptor(proto, i);\n      }\n\n      if (attrs && attrs.set == null) {\n        continue;\n      }\n      child[i] = _clone(parent[i], depth - 1);\n    }\n\n    if (Object.getOwnPropertySymbols) {\n      var symbols = Object.getOwnPropertySymbols(parent);\n      for (var i = 0; i < symbols.length; i++) {\n        // Don't need to worry about cloning a symbol because it is a primitive,\n        // like a number or string.\n        var symbol = symbols[i];\n        var descriptor = Object.getOwnPropertyDescriptor(parent, symbol);\n        if (descriptor && !descriptor.enumerable && !includeNonEnumerable) {\n          continue;\n        }\n        child[symbol] = _clone(parent[symbol], depth - 1);\n        if (!descriptor.enumerable) {\n          Object.defineProperty(child, symbol, {\n            enumerable: false\n          });\n        }\n      }\n    }\n\n    if (includeNonEnumerable) {\n      var allPropertyNames = Object.getOwnPropertyNames(parent);\n      for (var i = 0; i < allPropertyNames.length; i++) {\n        var propertyName = allPropertyNames[i];\n        var descriptor = Object.getOwnPropertyDescriptor(parent, propertyName);\n        if (descriptor && descriptor.enumerable) {\n          continue;\n        }\n        child[propertyName] = _clone(parent[propertyName], depth - 1);\n        Object.defineProperty(child, propertyName, {\n          enumerable: false\n        });\n      }\n    }\n\n    return child;\n  }\n\n  return _clone(parent, depth);\n}\n\n/**\n * Simple flat clone using prototype, accepts only objects, usefull for property\n * override on FLAT configuration object (no nested props).\n *\n * USE WITH CAUTION! This may not behave as you wish if you do not know how this\n * works.\n */\nclone.clonePrototype = function clonePrototype(parent) {\n  if (parent === null)\n    return null;\n\n  var c = function () {};\n  c.prototype = parent;\n  return new c();\n};\n\n// private utility functions\n\nfunction __objToStr(o) {\n  return Object.prototype.toString.call(o);\n}\nclone.__objToStr = __objToStr;\n\nfunction __isDate(o) {\n  return typeof o === 'object' && __objToStr(o) === '[object Date]';\n}\nclone.__isDate = __isDate;\n\nfunction __isArray(o) {\n  return typeof o === 'object' && __objToStr(o) === '[object Array]';\n}\nclone.__isArray = __isArray;\n\nfunction __isRegExp(o) {\n  return typeof o === 'object' && __objToStr(o) === '[object RegExp]';\n}\nclone.__isRegExp = __isRegExp;\n\nfunction __getRegExpFlags(re) {\n  var flags = '';\n  if (re.global) flags += 'g';\n  if (re.ignoreCase) flags += 'i';\n  if (re.multiline) flags += 'm';\n  return flags;\n}\nclone.__getRegExpFlags = __getRegExpFlags;\n\nreturn clone;\n})();\n\nif (typeof module === 'object' && module.exports) {\n  module.exports = clone;\n}\n","exports.read = function (buffer, offset, isLE, mLen, nBytes) {\n  var e, m\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var nBits = -7\n  var i = isLE ? (nBytes - 1) : 0\n  var d = isLE ? -1 : 1\n  var s = buffer[offset + i]\n\n  i += d\n\n  e = s & ((1 << (-nBits)) - 1)\n  s >>= (-nBits)\n  nBits += eLen\n  for (; nBits > 0; e = e * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  m = e & ((1 << (-nBits)) - 1)\n  e >>= (-nBits)\n  nBits += mLen\n  for (; nBits > 0; m = m * 256 + buffer[offset + i], i += d, nBits -= 8) {}\n\n  if (e === 0) {\n    e = 1 - eBias\n  } else if (e === eMax) {\n    return m ? NaN : ((s ? -1 : 1) * Infinity)\n  } else {\n    m = m + Math.pow(2, mLen)\n    e = e - eBias\n  }\n  return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n  var e, m, c\n  var eLen = nBytes * 8 - mLen - 1\n  var eMax = (1 << eLen) - 1\n  var eBias = eMax >> 1\n  var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n  var i = isLE ? 0 : (nBytes - 1)\n  var d = isLE ? 1 : -1\n  var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n  value = Math.abs(value)\n\n  if (isNaN(value) || value === Infinity) {\n    m = isNaN(value) ? 1 : 0\n    e = eMax\n  } else {\n    e = Math.floor(Math.log(value) / Math.LN2)\n    if (value * (c = Math.pow(2, -e)) < 1) {\n      e--\n      c *= 2\n    }\n    if (e + eBias >= 1) {\n      value += rt / c\n    } else {\n      value += rt * Math.pow(2, 1 - eBias)\n    }\n    if (value * c >= 2) {\n      e++\n      c /= 2\n    }\n\n    if (e + eBias >= eMax) {\n      m = 0\n      e = eMax\n    } else if (e + eBias >= 1) {\n      m = (value * c - 1) * Math.pow(2, mLen)\n      e = e + eBias\n    } else {\n      m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n      e = 0\n    }\n  }\n\n  for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n  e = (e << mLen) | m\n  eLen += mLen\n  for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n  buffer[offset + i - d] |= s * 128\n}\n"]} diff --git a/StrategyTracker/js/index.js b/StrategyTracker/js/index.js index f5c6fa2..b6327be 100644 --- a/StrategyTracker/js/index.js +++ b/StrategyTracker/js/index.js @@ -256,9 +256,11 @@ if (typeof window !== 'undefined' && window.angular) { if(scope.fadeIn !== undefined) { scope.$watch('fadeIn', function(value) { if(value) { - $(element).fadeIn(500) + $(element).fadeIn(1500); + } else { - $(element).fadeOut(100); + $(element).fadeOut(1000); + } }); }